Enable first implementation of value change in varialbles view.
[phpeclipse.git] / archive / net.sourceforge.phpeclipse.wiki / src / net / sourceforge / phpeclipse / wiki / actions / CreateFilesJob.java
index 82f7769..7b3cad2 100644 (file)
@@ -3,6 +3,7 @@ import java.io.ByteArrayInputStream;
 
 import net.sourceforge.phpeclipse.wiki.editor.WikiEditorPlugin;
 import net.sourceforge.phpeclipse.wiki.preferences.Util;
+import net.sourceforge.phpeclipse.wiki.xml.Page;
 
 import org.eclipse.core.resources.IContainer;
 import org.eclipse.core.resources.IFile;
@@ -17,24 +18,30 @@ import org.eclipse.ui.progress.IProgressConstants;
 
 public class CreateFilesJob extends WorkspaceJob {
   IFile[] files;
+  String[] wikiTitles;
 
-  public CreateFilesJob(IFile[] files) {
+  public CreateFilesJob(IFile[] files, String[] wikiTitles) {
     super("Create Wiki Files Job");
     this.files = files;
+    this.wikiTitles = wikiTitles;
   }
 
   public IStatus runInWorkspace(IProgressMonitor monitor) {
     try {
       monitor.beginTask("Create Wiki Files", 100);
       IFile file;
+      String wikiTitle;
       int partOfWork = 100 / files.length;
       int work = 0;
       String newText = WikiEditorPlugin.AUTOMATICALLY_CREATED;
       byte[] buffer = newText.getBytes();
       ByteArrayInputStream source = new ByteArrayInputStream(buffer);
       ProblemConsole console = new ProblemConsole();
+      boolean showConsole = WikiEditorPlugin.getDefault().getPreferenceStore().getBoolean(WikiEditorPlugin.CONSOLE_OUTPUT);
+      
       for (int i = 0; i < files.length; i++) {
         file = files[i];
+        wikiTitle = wikiTitles[i];
 
         IContainer parent = file.getParent();
         if (parent instanceof IFolder && (!((IFolder) parent).exists())) {
@@ -42,9 +49,17 @@ public class CreateFilesJob extends WorkspaceJob {
         }
         try {
           if (!file.exists()) {
+            monitor.subTask("Create File: "+file.getLocation().toString());
             file.create(source, true, monitor);
+            Page page = new Page("", wikiTitle, "");
+            page.createXMLFile(file, false);
+            if (showConsole) {
+              console.println("Title: "+wikiTitle+" =>File: " + file.getLocation().toString() + "created\n");
+            }
           } else {
-            console.println("File: " + file.getLocation().toString() + "\n==>file already exists!");
+            String message = "File: " + file.getLocation().toString() + "\n==>file already exists!";
+            monitor.subTask(message);
+            console.println(message);
           }
         } catch (CoreException e) {
           if (file != null) {
@@ -60,7 +75,6 @@ public class CreateFilesJob extends WorkspaceJob {
 
       if (isModal(this)) {
         // The progress dialog is still open show the message
-        console.reportError();
       } else {
         setProperty(IProgressConstants.KEEP_PROPERTY, Boolean.TRUE);
         //            setProperty(IProgressConstants.ACTION_PROPERTY, getWikisCompletedAction());