X-Git-Url: http://secure.phpeclipse.com
diff --git a/archive/net.sourceforge.phpeclipse.wiki/src/net/sourceforge/phpeclipse/wiki/editor/WikiEditorPlugin.java b/archive/net.sourceforge.phpeclipse.wiki/src/net/sourceforge/phpeclipse/wiki/editor/WikiEditorPlugin.java
index ee2c4ab..915af72 100644
--- a/archive/net.sourceforge.phpeclipse.wiki/src/net/sourceforge/phpeclipse/wiki/editor/WikiEditorPlugin.java
+++ b/archive/net.sourceforge.phpeclipse.wiki/src/net/sourceforge/phpeclipse/wiki/editor/WikiEditorPlugin.java
@@ -1,23 +1,33 @@
package net.sourceforge.phpeclipse.wiki.editor;
import java.io.IOException;
+import java.io.InputStream;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
import java.net.MalformedURLException;
import java.net.URL;
import java.sql.SQLException;
import java.text.MessageFormat;
+import java.util.ArrayList;
+import java.util.Enumeration;
import java.util.Hashtable;
import java.util.List;
import java.util.MissingResourceException;
+import java.util.PropertyResourceBundle;
import java.util.ResourceBundle;
+import net.sourceforge.phpeclipse.wiki.actions.mediawiki.config.IWikipedia;
import net.sourceforge.phpeclipse.wiki.internal.ConfigurationManager;
import net.sourceforge.phpeclipse.wiki.internal.IConfigurationWorkingCopy;
import net.sourceforge.phpeclipse.wiki.sql.WikipediaDB;
+import org.eclipse.core.resources.IWorkspace;
+import org.eclipse.core.resources.ResourcesPlugin;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IExtension;
import org.eclipse.core.runtime.IPluginDescriptor;
import org.eclipse.core.runtime.IStatus;
+import org.eclipse.core.runtime.Path;
import org.eclipse.core.runtime.Platform;
import org.eclipse.core.runtime.Status;
import org.eclipse.jface.dialogs.MessageDialog;
@@ -39,19 +49,76 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
private static WikiEditorPlugin fgPlugin;
- public static final String HTTP_QUERY = "HTTP Query";
+ public final static String AUTOMATICALLY_CREATED = "";
+
+ public final static String WP_EXTENSION = "wp";
+
+ public final static String XML_START_1 = "\n" + "\n";
+
+ public final static String XML_END = "\n";
+
+ public static final String PREFIX_LOAD = "Load ";
+
+ public static final String PREFIX_STORE = "Store ";
- public static final String WIKIPEDIA_GET_TEXT = "Wikipedia-Load Text";
+ public static final String HTTP_QUERY = "HTTP Query";
- public static final String WIKIPEDIA_SET_TEXT = "Wikipedia-Store Text";
-
+ // public static final String WIKIPEDIA_GET_TEXT = "Load WikipediaEN";
+ //
+ // public static final String WIKIPEDIA_SET_TEXT = "Store WikipediaEN";
public static final String WIKIPEDIA_SQL = "Wikipedia SQL access";
-
+
public static final String BLOG_A_WIKI = "Blog as Wiki Text";
public static final String BLOG_A_HTML = "Blog as HTML Text";
- public static final String[] CONFIGURATION_TYPES = { HTTP_QUERY, WIKIPEDIA_GET_TEXT, WIKIPEDIA_SET_TEXT, WIKIPEDIA_SQL, BLOG_A_WIKI, BLOG_A_HTML };
+ public static final String PLOG4U_DE_LOAD = PREFIX_LOAD + "Plog4UDE";
+
+ public static final String PLOG4U_DE_STORE = PREFIX_STORE + "Plog4UDE";
+
+ public static final String PLOG4U_ORG_LOAD = PREFIX_LOAD + "Plog4UORG";
+
+ public static final String PLOG4U_ORG_STORE = PREFIX_STORE + "Plog4UORG";
+
+ public static final String[] PREDEFINED_TYPES = {
+ HTTP_QUERY,
+ WIKIPEDIA_SQL,
+ PLOG4U_DE_LOAD,
+ PLOG4U_DE_STORE,
+ PLOG4U_ORG_LOAD,
+ PLOG4U_ORG_STORE,
+ BLOG_A_WIKI,
+ BLOG_A_HTML };
+
+ public static final String[] PREDEFINED_WIKIS = {
+ "WikibooksDE",
+ "WikibooksEN",
+ "WikinewsDE",
+ "WikinewsEN",
+ "WikipediaAR",
+ "WikipediaCA",
+ "WikipediaDE",
+ "WikipediaEN",
+ "WikipediaEO",
+ "WikipediaES",
+ "WikipediaET",
+ "WikipediaFI",
+ "WikipediaFR",
+ "WikipediaHE",
+ "WikipediaIA",
+ "WikipediaIT",
+ "WikipediaJA",
+ "WikipediaNL",
+ "WikipediaPL",
+ "WikipediaPT",
+ "WikipediaRO",
+ "WikipediaSL",
+ "WikipediaSV",
+ "WikipediaZH" };
+
+ public static final ArrayList CONFIGURATION_TYPES = new ArrayList();
//image paths
public static final String ICON_PATH = "icons/full/"; //$NON-NLS-1$
@@ -70,15 +137,37 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
public final static String EXPORT_CSS_URL = "__export_css_url";
- public final static String PREF_STRING_CONFIGURATIONS = "__configurations1";
+ public final static String PREF_STRING_CONFIGURATIONS = "__configurations4";
+
+ public final static String CONSOLE_OUTPUT = "__console_output";
+
+ public final static String HTTP_TIMEOUT = "http.timeout";
+
+ public final static String HTTP_PROXYHOST = "http.proxyHost";
+
+ public final static String HTTP_PROXYPORT = "http.proxyPort";
- public final static String CONFIG_MEMENTO = ""
- + ""
+ public final static String HTTP_PROXYUSERNAME = "http.proxyUserName";
+
+ public final static String HTTP_PROXYPASSWORD = "http.proxyPassword";
+
+ public final static String CONFIG_MEMENTO = "" + ""
+ ""
+ ""
+ ""
- + ""
- + ""
+
+ + "" + ""
+ + ""
+ + ""
+
+ + "" + ""
+ + "" + ""
+ ""
+ "";
@@ -174,6 +263,16 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
super(descriptor);
initializeImages();
fgPlugin = this;
+ for (int i = 0; i < PREDEFINED_TYPES.length; i++) {
+ CONFIGURATION_TYPES.add(PREDEFINED_TYPES[i]);
+ }
+
+ for (int i = 0; i < PREDEFINED_WIKIS.length; i++) {
+ CONFIGURATION_TYPES.add(PREFIX_LOAD + PREDEFINED_WIKIS[i]);
+ }
+ for (int i = 0; i < PREDEFINED_WIKIS.length; i++) {
+ CONFIGURATION_TYPES.add(PREFIX_STORE + PREDEFINED_WIKIS[i]);
+ }
manager = ConfigurationManager.getInstance();
try {
fResourceBundle = ResourceBundle.getBundle("net.sourceforge.phpeclipse.wiki.editor.WikiEditorMessages");
@@ -237,6 +336,17 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
return fTemplateStore;
}
+ private static boolean isDefined(String test) {
+ if (test != null && test.length() > 0) {
+ for (int i = 0; i < test.length(); i++) {
+ if (!Character.isWhitespace(test.charAt(i))) {
+ return false;
+ }
+ }
+ }
+ return true;
+ }
+
/*
* (non-Javadoc)
*
@@ -244,6 +354,81 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
*/
protected void initializeDefaultPreferences(IPreferenceStore store) {
store.setDefault(PREF_STRING_CONFIGURATIONS, CONFIG_MEMENTO);
+ store.setDefault(CONSOLE_OUTPUT, "true");
+
+ String operatingSystem = Platform.getOS();
+ // operatingSystem ==> maxosx, linux, solaris, win32,...
+ try {
+ InputStream is = getDefault().openStream(new Path("prefs/default_" + operatingSystem + ".properties"));
+ PropertyResourceBundle resourceBundle = new PropertyResourceBundle(is);
+
+ String key = HTTP_TIMEOUT;
+ try {
+ String timeout = resourceBundle.getString(key);
+ int val = Integer.parseInt(timeout);
+ if (val > 0) {
+ val *= 1000;
+ } else {
+ val = 30000;
+ }
+ store.setDefault(key, Integer.toString(val));
+ } catch (Exception e) {
+ store.setDefault(key, "30000"); // 30 seconds timeout
+ }
+
+ key = HTTP_PROXYHOST;
+ try {
+ String proxyHost = resourceBundle.getString(key);
+ if (isDefined(proxyHost)) {
+ store.setDefault(key, proxyHost);
+ } else {
+ store.setDefault(key, System.getProperty(key, ""));
+ }
+ } catch (Exception e) {
+ store.setDefault(key, System.getProperty(key, ""));
+ }
+
+ key = HTTP_PROXYPORT;
+ try {
+ String proxyPort = resourceBundle.getString(key);
+ if (isDefined(proxyPort)) {
+ // check for integer parse exception:
+ Integer.parseInt(proxyPort);
+ store.setDefault(key, proxyPort);
+ } else {
+ store.setDefault(key, System.getProperty(key, "80"));
+ }
+ } catch (Exception e) {
+ store.setDefault(key, System.getProperty(key, "80"));
+ }
+
+ key = HTTP_PROXYUSERNAME;
+ try {
+ String proxyUserName = resourceBundle.getString(key);
+ if (isDefined(proxyUserName)) {
+ store.setDefault(key, proxyUserName);
+ } else {
+ store.setDefault(key, System.getProperty(key, ""));
+ }
+ } catch (Exception e) {
+ store.setDefault(key, System.getProperty(key, ""));
+ }
+
+ key = HTTP_PROXYPASSWORD;
+ try {
+ String proxyPassWord = resourceBundle.getString(key);
+ if (isDefined(proxyPassWord)) {
+ store.setDefault(key, proxyPassWord);
+ } else {
+ store.setDefault(key, System.getProperty(key, ""));
+ }
+ } catch (Exception e) {
+ store.setDefault(key, System.getProperty(key, ""));
+ }
+
+ } catch (Exception e) {
+ }
+
}
/*
@@ -298,8 +483,8 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
public void reportError(String title, String message) {
try {
- Shell shell = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell();
- MessageDialog.openError(shell, title, message);
+ // Shell shell = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell();
+ MessageDialog.openError(null, title, message);
} catch (RuntimeException e) {
log(e.getLocalizedMessage(), e);
}
@@ -376,10 +561,14 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
return manager.createConfiguration();
}
- public static String[] getTypes() {
+ public static ArrayList getTypes() {
return CONFIGURATION_TYPES;
}
+ public static void addType(String type) {
+ CONFIGURATION_TYPES.add(type);
+ }
+
/*
* (non-Javadoc)
*
@@ -394,7 +583,7 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
}
super.shutdown();
}
-
+
public static void log(int severity, String message) {
Status status = new Status(severity, PLUGIN_ID, IStatus.OK, message, null);
log(status);
@@ -408,4 +597,48 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
log(new Status(IStatus.ERROR, PLUGIN_ID, IStatus.ERROR, "PHPeclipsePlugin.internalErrorOccurred", e)); //$NON-NLS-1$
}
+ /**
+ * Get a IWikpedia singleton instance through reflection (i.e. Method#invoke() )
+ *
+ * @param wikiLocale
+ * @return
+ * @throws NoSuchMethodException
+ * @throws IllegalAccessException
+ * @throws ClassNotFoundException
+ * @throws InvocationTargetException
+ */
+ public static IWikipedia getWikiInstance(String wikiLocale) throws NoSuchMethodException, IllegalAccessException,
+ ClassNotFoundException, InvocationTargetException {
+ String className = "net.sourceforge.phpeclipse.wiki.actions.mediawiki.config." + wikiLocale;
+ Class cls = Class.forName(className);
+ Method method = cls.getMethod("getInstance", new Class[0]);
+ return (IWikipedia) method.invoke(null, new Object[0]);
+ }
+
+ /**
+ * Returns the workspace instance.
+ */
+ public static IWorkspace getWorkspace() {
+ return ResourcesPlugin.getWorkspace();
+ }
+
+ // test code
+ // public static void main(String[] args) {
+ // try {
+ // getWikiInstance("WikipediaEN");
+ // } catch (NoSuchMethodException e) {
+ // // TODO Auto-generated catch block
+ // e.printStackTrace();
+ // } catch (IllegalAccessException e) {
+ // // TODO Auto-generated catch block
+ // e.printStackTrace();
+ // } catch (ClassNotFoundException e) {
+ // // TODO Auto-generated catch block
+ // e.printStackTrace();
+ // } catch (InvocationTargetException e) {
+ // // TODO Auto-generated catch block
+ // e.printStackTrace();
+ // }
+ // }
+
}
\ No newline at end of file