Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'org.eclipse.m2e.core.ui/src/org/eclipse/m2e/core/ui/internal/preferences/RemoteArchetypeCatalogDialog.java')
-rw-r--r--org.eclipse.m2e.core.ui/src/org/eclipse/m2e/core/ui/internal/preferences/RemoteArchetypeCatalogDialog.java20
1 files changed, 17 insertions, 3 deletions
diff --git a/org.eclipse.m2e.core.ui/src/org/eclipse/m2e/core/ui/internal/preferences/RemoteArchetypeCatalogDialog.java b/org.eclipse.m2e.core.ui/src/org/eclipse/m2e/core/ui/internal/preferences/RemoteArchetypeCatalogDialog.java
index 55f0b709..afedca3e 100644
--- a/org.eclipse.m2e.core.ui/src/org/eclipse/m2e/core/ui/internal/preferences/RemoteArchetypeCatalogDialog.java
+++ b/org.eclipse.m2e.core.ui/src/org/eclipse/m2e/core/ui/internal/preferences/RemoteArchetypeCatalogDialog.java
@@ -11,6 +11,7 @@
package org.eclipse.m2e.core.ui.internal.preferences;
+import java.net.URL;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
@@ -279,13 +280,26 @@ public class RemoteArchetypeCatalogDialog extends TitleAreaDialog {
setMessage(null, IStatus.WARNING);
String url = catalogUrlCombo.getText().trim();
- boolean isValid = !url.isEmpty();
- if(!isValid) {
+ boolean isValid = false;
+ if(url.isEmpty()) {
setErrorMessage(Messages.RemoteArchetypeCatalogDialog_error_required);
+ } else if(!isWellFormedUrl(url)) {
+ setErrorMessage(NLS.bind(Messages.RemoteArchetypeCatalogDialog_error_invalidUrl, url));
+ } else {
+ isValid = true;
}
-
verifyButton.setEnabled(isValid);
return isValid;
}
+ public boolean isWellFormedUrl(String url) {
+ try {
+ new URL(url).toURI();
+ return true;
+ } catch(Exception O_o) {
+ //Not good enough
+ }
+ return false;
+ }
+
}

Back to the top