]> git.proxmox.com Git - mirror_edk2.git/blobdiff - Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/FrameworkWizardUI.java
Adding a dialog for setting the Build Preferences in the target.txt file.
[mirror_edk2.git] / Tools / Source / FrameworkWizard / src / org / tianocore / frameworkwizard / FrameworkWizardUI.java
index 6041472c5fd77ce3d003239741e1b0801dd057af..ec826817da5bb652eec8e6cd76e1a5eecde8a2bc 100644 (file)
@@ -17,7 +17,6 @@ package org.tianocore.frameworkwizard;
 \r
 import java.awt.event.ActionEvent;\r
 import java.awt.event.ComponentEvent;\r
-import java.awt.event.ComponentListener;\r
 import java.awt.event.MouseEvent;\r
 import java.awt.event.MouseListener;\r
 import java.awt.event.WindowEvent;\r
@@ -44,22 +43,18 @@ import javax.swing.event.TreeSelectionEvent;
 import javax.swing.event.TreeSelectionListener;\r
 \r
 import org.apache.xmlbeans.XmlException;\r
-import org.tianocore.ModuleSurfaceAreaDocument;\r
 import org.tianocore.PackageSurfaceAreaDocument;\r
-import org.tianocore.PlatformSurfaceAreaDocument;\r
 import org.tianocore.frameworkwizard.common.DataType;\r
+import org.tianocore.frameworkwizard.common.GlobalData;\r
 import org.tianocore.frameworkwizard.common.IFileFilter;\r
 import org.tianocore.frameworkwizard.common.Log;\r
-import org.tianocore.frameworkwizard.common.OpenFile;\r
 import org.tianocore.frameworkwizard.common.SaveFile;\r
 import org.tianocore.frameworkwizard.common.Tools;\r
 import org.tianocore.frameworkwizard.common.Identifications.Identification;\r
-import org.tianocore.frameworkwizard.common.Identifications.OpeningModuleList;\r
 import org.tianocore.frameworkwizard.common.Identifications.OpeningModuleType;\r
-import org.tianocore.frameworkwizard.common.Identifications.OpeningPackageList;\r
 import org.tianocore.frameworkwizard.common.Identifications.OpeningPackageType;\r
-import org.tianocore.frameworkwizard.common.Identifications.OpeningPlatformList;\r
 import org.tianocore.frameworkwizard.common.Identifications.OpeningPlatformType;\r
+//import org.tianocore.frameworkwizard.common.find.FindPPIsResult;\r
 import org.tianocore.frameworkwizard.common.ui.IDefaultMutableTreeNode;\r
 import org.tianocore.frameworkwizard.common.ui.IDesktopManager;\r
 import org.tianocore.frameworkwizard.common.ui.IFrame;\r
@@ -71,7 +66,6 @@ import org.tianocore.frameworkwizard.far.updateui.UpdateStepOne;
 import org.tianocore.frameworkwizard.module.Identifications.ModuleIdentification;\r
 import org.tianocore.frameworkwizard.module.ui.ModuleBootModes;\r
 import org.tianocore.frameworkwizard.module.ui.ModuleDataHubs;\r
-import org.tianocore.frameworkwizard.module.ui.ModuleDefinitions;\r
 import org.tianocore.frameworkwizard.module.ui.ModuleEvents;\r
 import org.tianocore.frameworkwizard.module.ui.ModuleExterns;\r
 import org.tianocore.frameworkwizard.module.ui.ModuleGuids;\r
@@ -105,34 +99,22 @@ import org.tianocore.frameworkwizard.platform.ui.FpdPlatformDefs;
 import org.tianocore.frameworkwizard.workspace.Workspace;\r
 import org.tianocore.frameworkwizard.workspace.WorkspaceTools;\r
 import org.tianocore.frameworkwizard.workspace.ui.SwitchWorkspace;\r
+import org.tianocore.frameworkwizard.toolchain.Preferences;\r
 \r
 /**\r
  The class is used to show main GUI of FrameworkWizard\r
  It extends IFrame implements MouseListener, TreeSelectionListener, ComponentListener and MenuListener\r
 \r
  **/\r
-public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSelectionListener, ComponentListener,\r
-                                             MenuListener {\r
+public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSelectionListener, MenuListener {\r
     ///\r
     /// Define class Serial Version UID\r
     ///\r
     private static final long serialVersionUID = -7103240960573031772L;\r
 \r
     ///\r
-    /// Used to save information of all files\r
+    /// Used to record current operation target\r
     ///\r
-    private Vector<ModuleIdentification> vModuleList = new Vector<ModuleIdentification>();\r
-\r
-    private Vector<PackageIdentification> vPackageList = new Vector<PackageIdentification>();\r
-\r
-    private Vector<PlatformIdentification> vPlatformList = new Vector<PlatformIdentification>();\r
-\r
-    private OpeningModuleList openingModuleList = new OpeningModuleList();\r
-\r
-    private OpeningPackageList openingPackageList = new OpeningPackageList();\r
-\r
-    private OpeningPlatformList openingPlatformList = new OpeningPlatformList();\r
-\r
     private int currentOpeningModuleIndex = -1;\r
 \r
     private int currentOpeningPackageIndex = -1;\r
@@ -235,8 +217,6 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
 \r
     private JMenuItem jMenuItemEditSelectAll = null;\r
 \r
-    private JMenuItem jMenuItemEditFind = null;\r
-\r
     private JMenuItem jMenuItemEditFindNext = null;\r
 \r
     private JMenu jMenuView = null;\r
@@ -259,11 +239,11 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
 \r
     private JMenuItem jMenuItemProjectChangeWorkspace = null;\r
 \r
-    private JMenu jMenuProjectBuildTargets = null;\r
+    private JMenuItem jMenuItemToolsBuildPreferences = null;\r
 \r
-    private JCheckBoxMenuItem jCheckBoxMenuItemProjectBuildTargetsDebug = null;\r
+//    private JCheckBoxMenuItem jCheckBoxMenuItemProjectBuildTargetsDebug = null;\r
 \r
-    private JCheckBoxMenuItem jCheckBoxMenuItemProjectBuildTargetsRelease = null;\r
+//    private JCheckBoxMenuItem jCheckBoxMenuItemProjectBuildTargetsRelease = null;\r
 \r
     private JMenuItem jMenuItemToolsToolChainConfiguration = null;\r
 \r
@@ -299,6 +279,20 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
 \r
     private JMenuItem jMenuItemProjectCreateFar = null;\r
 \r
+    private JMenu jMenuEditFind = null;\r
+\r
+    private JMenuItem jMenuItemEditFindPcd = null;\r
+\r
+    private JMenuItem jMenuItemEditFindLibraryClass = null;\r
+\r
+    private JMenuItem jMenuItemEditFindPpi = null;\r
+\r
+    private JMenuItem jMenuItemEditFindProtocol = null;\r
+\r
+    private JMenuItem jMenuItemEditFindGuid = null;\r
+\r
+    private JMenuItem jMenuItemEditFindLibraryInstance = null;\r
+\r
     ///\r
     /// A static definition for this class itself\r
     ///\r
@@ -495,18 +489,18 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             //\r
             jMenuEdit.add(getJMenuItemEditUndo());\r
             jMenuEdit.add(getJMenuItemEditRedo());\r
-            jMenuEdit.addSeparator();\r
+            //jMenuEdit.addSeparator();\r
 \r
             jMenuEdit.add(getJMenuItemEditCut());\r
             jMenuEdit.add(getJMenuItemEditCopy());\r
             jMenuEdit.add(getJMenuItemEditPaste());\r
             jMenuEdit.add(getJMenuItemEditDelete());\r
-            jMenuEdit.addSeparator();\r
+            //jMenuEdit.addSeparator();\r
 \r
             jMenuEdit.add(getJMenuItemEditSelectAll());\r
-            jMenuEdit.add(getJMenuItemEditFind());\r
+            jMenuEdit.add(getJMenuEditFind());\r
             jMenuEdit.add(getJMenuItemEditFindNext());\r
-            jMenuEdit.addSeparator();\r
+            //jMenuEdit.addSeparator();\r
         }\r
         return jMenuEdit;\r
     }\r
@@ -672,6 +666,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             jMenuItemEditDelete = new JMenuItem();\r
             jMenuItemEditDelete.setText("Delete");\r
             jMenuItemEditDelete.setMnemonic('D');\r
+            jMenuItemEditDelete.setVisible(false);\r
+            jMenuItemEditDelete.setEnabled(false);\r
             jMenuItemEditDelete.addActionListener(this);\r
             //\r
             //Disabled first when no module is open\r
@@ -751,11 +747,13 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             //\r
             // Add sub menu items\r
             //\r
-            jMenuTools.add(getJMenuItemToolsToolChainConfiguration());\r
-            jMenuTools.addSeparator();\r
 \r
             jMenuTools.add(getJMenuItemToolsClone());\r
             jMenuTools.add(getJMenuItemToolsCodeScan());\r
+            jMenuTools.addSeparator();\r
+            \r
+            jMenuTools.add(getJMenuItemToolsToolChainConfiguration());\r
+            jMenuTools.add(getJMenuItemToolsBuildPreferences());\r
         }\r
         return jMenuTools;\r
     }\r
@@ -1003,6 +1001,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             jMenuItemEditUndo.setText("Undo");\r
             jMenuItemEditUndo.setMnemonic('U');\r
             jMenuItemEditUndo.setEnabled(false);\r
+            jMenuItemEditUndo.setVisible(false);\r
             jMenuItemEditUndo.addActionListener(this);\r
         }\r
         return jMenuItemEditUndo;\r
@@ -1020,6 +1019,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             jMenuItemEditRedo.setText("Redo");\r
             jMenuItemEditRedo.setMnemonic('R');\r
             jMenuItemEditRedo.setEnabled(false);\r
+            jMenuItemEditRedo.setVisible(false);\r
             jMenuItemEditRedo.addActionListener(this);\r
         }\r
         return jMenuItemEditRedo;\r
@@ -1037,6 +1037,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             jMenuItemEditCut.setText("Cut");\r
             jMenuItemEditCut.setMnemonic('t');\r
             jMenuItemEditCut.setEnabled(false);\r
+            jMenuItemEditCut.setVisible(false);\r
             jMenuItemEditCut.addActionListener(this);\r
         }\r
         return jMenuItemEditCut;\r
@@ -1054,6 +1055,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             jMenuItemEditCopy.setText("Copy");\r
             jMenuItemEditCopy.setMnemonic('C');\r
             jMenuItemEditCopy.setEnabled(false);\r
+            jMenuItemEditCopy.setVisible(false);\r
             jMenuItemEditCopy.addActionListener(this);\r
         }\r
         return jMenuItemEditCopy;\r
@@ -1071,6 +1073,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             jMenuItemEditPaste.setText("Paste");\r
             jMenuItemEditPaste.setMnemonic('P');\r
             jMenuItemEditPaste.setEnabled(false);\r
+            jMenuItemEditPaste.setVisible(false);\r
             jMenuItemEditPaste.addActionListener(this);\r
         }\r
         return jMenuItemEditPaste;\r
@@ -1088,28 +1091,12 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             jMenuItemEditSelectAll.setText("Select All");\r
             jMenuItemEditSelectAll.setMnemonic('A');\r
             jMenuItemEditSelectAll.setEnabled(false);\r
+            jMenuItemEditSelectAll.setVisible(false);\r
             jMenuItemEditSelectAll.addActionListener(this);\r
         }\r
         return jMenuItemEditSelectAll;\r
     }\r
 \r
-    /**\r
-     This method initializes jMenuItemEditFind \r
-     \r
-     @return javax.swing.JMenuItem     \r
-     \r
-     **/\r
-    private JMenuItem getJMenuItemEditFind() {\r
-        if (jMenuItemEditFind == null) {\r
-            jMenuItemEditFind = new JMenuItem();\r
-            jMenuItemEditFind.setText("Find");\r
-            jMenuItemEditFind.setMnemonic('F');\r
-            jMenuItemEditFind.setEnabled(false);\r
-            jMenuItemEditFind.addActionListener(this);\r
-        }\r
-        return jMenuItemEditFind;\r
-    }\r
-\r
     /**\r
      This method initializes jMenuItemEditFindNext     \r
      \r
@@ -1122,6 +1109,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             jMenuItemEditFindNext.setText("Find Next");\r
             jMenuItemEditFindNext.setMnemonic('n');\r
             jMenuItemEditFindNext.setEnabled(false);\r
+            jMenuItemEditFindNext.setVisible(false);\r
             jMenuItemEditFindNext.addActionListener(this);\r
         }\r
         return jMenuItemEditFindNext;\r
@@ -1283,7 +1271,6 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             jMenuProject.add(getJMenuItemProjectUpdateFar());\r
             jMenuProject.add(getJMenuItemProjectRemoveFar());\r
 \r
-            jMenuProject.add(getJMenuProjectBuildTargets());\r
         }\r
         return jMenuProject;\r
     }\r
@@ -1324,52 +1311,20 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
     }\r
 \r
     /**\r
-     This method initializes jMenuProjectBuildTargets  \r
+     This method initializes jMenuProjectBuildPreferences      \r
      \r
      @return javax.swing.JMenu \r
      \r
      **/\r
-    private JMenu getJMenuProjectBuildTargets() {\r
-        if (jMenuProjectBuildTargets == null) {\r
-            jMenuProjectBuildTargets = new JMenu();\r
-            jMenuProjectBuildTargets.setText("Build Targets");\r
-            jMenuProjectBuildTargets.setMnemonic('T');\r
-            jMenuProjectBuildTargets.setVisible(false);\r
-\r
-            jMenuProjectBuildTargets.add(getJCheckBoxMenuItemProjectBuildTargetsDebug());\r
-            jMenuProjectBuildTargets.add(getJCheckBoxMenuItemProjectBuildTargetsRelease());\r
+    private JMenuItem getJMenuItemToolsBuildPreferences() {\r
+        if (jMenuItemToolsBuildPreferences == null) {\r
+            jMenuItemToolsBuildPreferences = new JMenuItem();\r
+            jMenuItemToolsBuildPreferences.setText("Build Preferences");\r
+            jMenuItemToolsBuildPreferences.setMnemonic('P');\r
+            jMenuItemToolsBuildPreferences.setEnabled(true);\r
+            jMenuItemToolsBuildPreferences.addActionListener(this);\r
         }\r
-        return jMenuProjectBuildTargets;\r
-    }\r
-\r
-    /**\r
-     This method initializes jCheckBoxMenuItemProjectBuildTargetsDebug \r
-     \r
-     @return javax.swing.JCheckBoxMenuItem     \r
-     \r
-     **/\r
-    private JCheckBoxMenuItem getJCheckBoxMenuItemProjectBuildTargetsDebug() {\r
-        if (jCheckBoxMenuItemProjectBuildTargetsDebug == null) {\r
-            jCheckBoxMenuItemProjectBuildTargetsDebug = new JCheckBoxMenuItem();\r
-            jCheckBoxMenuItemProjectBuildTargetsDebug.setText("Debug");\r
-            jCheckBoxMenuItemProjectBuildTargetsDebug.setEnabled(false);\r
-        }\r
-        return jCheckBoxMenuItemProjectBuildTargetsDebug;\r
-    }\r
-\r
-    /**\r
-     This method initializes jCheckBoxMenuItemProjectBuildTargetsRelease       \r
-     \r
-     @return javax.swing.JCheckBoxMenuItem     \r
-     \r
-     **/\r
-    private JCheckBoxMenuItem getJCheckBoxMenuItemProjectBuildTargetsRelease() {\r
-        if (jCheckBoxMenuItemProjectBuildTargetsRelease == null) {\r
-            jCheckBoxMenuItemProjectBuildTargetsRelease = new JCheckBoxMenuItem();\r
-            jCheckBoxMenuItemProjectBuildTargetsRelease.setText("Release");\r
-            jCheckBoxMenuItemProjectBuildTargetsRelease.setEnabled(false);\r
-        }\r
-        return jCheckBoxMenuItemProjectBuildTargetsRelease;\r
+        return jMenuItemToolsBuildPreferences;\r
     }\r
 \r
     /**\r
@@ -1660,6 +1615,119 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         return jMenuItemProjectCreateFar;\r
     }\r
 \r
+    /**\r
+     * This method initializes jMenuEditFind   \r
+     *         \r
+     * @return javax.swing.JMenu       \r
+     */\r
+    private JMenu getJMenuEditFind() {\r
+        if (jMenuEditFind == null) {\r
+            jMenuEditFind = new JMenu();\r
+            jMenuEditFind.setText("Find");\r
+            jMenuEditFind.setMnemonic('F');\r
+\r
+            jMenuEditFind.add(getJMenuItemEditFindPpi());\r
+            jMenuEditFind.add(getJMenuItemEditFindProtocol());\r
+            jMenuEditFind.add(getJMenuItemEditFindGuid());\r
+            jMenuEditFind.add(getJMenuItemEditFindPcd());\r
+            jMenuEditFind.addSeparator();\r
+\r
+            jMenuEditFind.add(getJMenuItemEditFindLibraryClass());\r
+            jMenuEditFind.add(getJMenuItemEditFindLibraryInstance());\r
+        }\r
+        return jMenuEditFind;\r
+    }\r
+\r
+    /**\r
+     * This method initializes jMenuItemEditFindPcd    \r
+     *         \r
+     * @return javax.swing.JMenuItem   \r
+     */\r
+    private JMenuItem getJMenuItemEditFindPcd() {\r
+        if (jMenuItemEditFindPcd == null) {\r
+            jMenuItemEditFindPcd = new JMenuItem();\r
+            jMenuItemEditFindPcd.setText("All PCD entries");\r
+            jMenuItemEditFindPcd.setMnemonic('P');\r
+            jMenuItemEditFindPcd.addActionListener(this);\r
+        }\r
+        return jMenuItemEditFindPcd;\r
+    }\r
+\r
+    /**\r
+     * This method initializes jMenuItemEditFindLibraryClass   \r
+     *         \r
+     * @return javax.swing.JMenuItem   \r
+     */\r
+    private JMenuItem getJMenuItemEditFindLibraryClass() {\r
+        if (jMenuItemEditFindLibraryClass == null) {\r
+            jMenuItemEditFindLibraryClass = new JMenuItem();\r
+            jMenuItemEditFindLibraryClass.setText("All Library Classes");\r
+            jMenuItemEditFindLibraryClass.setMnemonic('C');\r
+            jMenuItemEditFindLibraryClass.addActionListener(this);\r
+        }\r
+        return jMenuItemEditFindLibraryClass;\r
+    }\r
+\r
+    /**\r
+     * This method initializes jMenuItemEditFindPpi    \r
+     *         \r
+     * @return javax.swing.JMenuItem   \r
+     */\r
+    private JMenuItem getJMenuItemEditFindPpi() {\r
+        if (jMenuItemEditFindPpi == null) {\r
+            jMenuItemEditFindPpi = new JMenuItem();\r
+            jMenuItemEditFindPpi.setText("All PPIs");\r
+            jMenuItemEditFindPpi.setMnemonic('I');\r
+            jMenuItemEditFindPpi.addActionListener(this);\r
+        }\r
+        return jMenuItemEditFindPpi;\r
+    }\r
+\r
+    /**\r
+     * This method initializes jMenuItemEditFindProtocol       \r
+     *         \r
+     * @return javax.swing.JMenuItem   \r
+     */\r
+    private JMenuItem getJMenuItemEditFindProtocol() {\r
+        if (jMenuItemEditFindProtocol == null) {\r
+            jMenuItemEditFindProtocol = new JMenuItem();\r
+            jMenuItemEditFindProtocol.setText("All Protocols");\r
+            jMenuItemEditFindProtocol.setMnemonic('r');\r
+            jMenuItemEditFindProtocol.addActionListener(this);\r
+        }\r
+        return jMenuItemEditFindProtocol;\r
+    }\r
+\r
+    /**\r
+     * This method initializes jMenuItemEditFindGuid   \r
+     *         \r
+     * @return javax.swing.JMenuItem   \r
+     */\r
+    private JMenuItem getJMenuItemEditFindGuid() {\r
+        if (jMenuItemEditFindGuid == null) {\r
+            jMenuItemEditFindGuid = new JMenuItem();\r
+            jMenuItemEditFindGuid.setText("All GUIDs");\r
+            jMenuItemEditFindGuid.setMnemonic('G');\r
+            jMenuItemEditFindGuid.addActionListener(this);\r
+        }\r
+        return jMenuItemEditFindGuid;\r
+    }\r
+\r
+    /**\r
+     * This method initializes jMenuItemEditFindLibraryInstance        \r
+     *         \r
+     * @return javax.swing.JMenuItem   \r
+     */\r
+    private JMenuItem getJMenuItemEditFindLibraryInstance() {\r
+        if (jMenuItemEditFindLibraryInstance == null) {\r
+            jMenuItemEditFindLibraryInstance = new JMenuItem();\r
+            jMenuItemEditFindLibraryInstance.setText("All Library Instances");\r
+            jMenuItemEditFindLibraryInstance.setMnemonic('n');\r
+            jMenuItemEditFindLibraryInstance.addActionListener(this);\r
+        }\r
+        return jMenuItemEditFindLibraryInstance;\r
+    }\r
+\r
     /* (non-Javadoc)\r
      * @see org.tianocore.packaging.common.ui.IFrame#main(java.lang.String[])\r
      *\r
@@ -1699,11 +1767,17 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             System.exit(0);\r
         }\r
 \r
+        //\r
+        // Init Global Data\r
+        //\r
+        GlobalData.init();\r
+\r
+        //\r
+        // Init the frame\r
+        //\r
         this.setSize(DataType.MAIN_FRAME_PREFERRED_SIZE_WIDTH, DataType.MAIN_FRAME_PREFERRED_SIZE_HEIGHT);\r
         this.setResizable(true);\r
         this.setJMenuBar(getjJMenuBar());\r
-        this.addComponentListener(this);\r
-        this.getCompontentsFromFrameworkDatabase();\r
         this.setContentPane(getJContentPane());\r
         this.setTitle(DataType.PROJECT_NAME + " " + DataType.PROJECT_VERSION + " " + "- ["\r
                       + Workspace.getCurrentWorkspace() + "]");\r
@@ -1741,67 +1815,75 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         // Operations of Menu\r
         //\r
-        if (arg0.getSource() == jMenuItemFileNew) {\r
+        if (arg0.getSource() == this.jMenuItemFileNew) {\r
             this.fileNew();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemFileOpen) {\r
+        if (arg0.getSource() == this.jMenuItemFileOpen) {\r
             this.open();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemFileClose) {\r
+        if (arg0.getSource() == this.jMenuItemFileClose) {\r
             this.close();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemFileCloseAll) {\r
+        if (arg0.getSource() == this.jMenuItemFileCloseAll) {\r
             this.closeAll();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemFileSave) {\r
+        if (arg0.getSource() == this.jMenuItemFileSave) {\r
             this.save();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemFileSaveAs) {\r
+        if (arg0.getSource() == this.jMenuItemFileSaveAs) {\r
             this.saveAs();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemFileSaveAll) {\r
+        if (arg0.getSource() == this.jMenuItemFileSaveAll) {\r
             this.saveAll();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemFileExit) {\r
+        if (arg0.getSource() == this.jMenuItemFileExit) {\r
             this.exit();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemProjectChangeWorkspace) {\r
-            changeWorkspace();\r
+        if (arg0.getSource() == this.jMenuItemEditFindPpi) {\r
+//            this.findPpi();\r
+        }\r
+        \r
+        if (arg0.getSource() == jMenuItemToolsBuildPreferences) {\r
+            configBuildPreferences();\r
+        }\r
+\r
+        if (arg0.getSource() == this.jMenuItemProjectChangeWorkspace) {\r
+            this.changeWorkspace();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemProjectCreateFar) {\r
-            createFar();\r
+        if (arg0.getSource() == this.jMenuItemProjectCreateFar) {\r
+            this.createFar();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemProjectInstallFar) {\r
-            installFar();\r
+        if (arg0.getSource() == this.jMenuItemProjectInstallFar) {\r
+            this.installFar();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemProjectRemoveFar) {\r
-            removeFar();\r
+        if (arg0.getSource() == this.jMenuItemProjectRemoveFar) {\r
+            this.removeFar();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemProjectUpdateFar) {\r
-            updateFar();\r
+        if (arg0.getSource() == this.jMenuItemProjectUpdateFar) {\r
+            this.updateFar();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemToolsClone) {\r
-            cloneItem();\r
+        if (arg0.getSource() == this.jMenuItemToolsClone) {\r
+            this.cloneItem();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemToolsToolChainConfiguration) {\r
-            setupToolChainConfiguration();\r
+        if (arg0.getSource() == this.jMenuItemToolsToolChainConfiguration) {\r
+            this.setupToolChainConfiguration();\r
         }\r
 \r
-        if (arg0.getSource() == jMenuItemHelpAbout) {\r
+        if (arg0.getSource() == this.jMenuItemHelpAbout) {\r
             About a = new About(this, true);\r
             int result = a.showDialog();\r
             if (result == DataType.RETURN_TYPE_OK) {\r
@@ -1828,34 +1910,34 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         // First add package\r
         //\r
-        if (this.vPackageList.size() > 0) {\r
-            for (int index = 0; index < this.vPackageList.size(); index++) {\r
+        if (GlobalData.vPackageList.size() > 0) {\r
+            for (int index = 0; index < GlobalData.vPackageList.size(); index++) {\r
                 IDefaultMutableTreeNode dmtnModulePackage = null;\r
                 IDefaultMutableTreeNode dmtnModulePackageLibrary = null;\r
                 IDefaultMutableTreeNode dmtnModulePackageModule = null;\r
 \r
-                dmtnModulePackage = new IDefaultMutableTreeNode(this.vPackageList.elementAt(index).getName(),\r
+                dmtnModulePackage = new IDefaultMutableTreeNode(GlobalData.vPackageList.elementAt(index).getName(),\r
                                                                 IDefaultMutableTreeNode.MODULE_PACKAGE, false,\r
-                                                                this.vPackageList.elementAt(index));\r
+                                                                GlobalData.vPackageList.elementAt(index));\r
                 dmtnModulePackageLibrary = new IDefaultMutableTreeNode("Library",\r
                                                                        IDefaultMutableTreeNode.MODULE_PACKAGE_LIBRARY,\r
-                                                                       false, this.vPackageList.elementAt(index));\r
+                                                                       false, GlobalData.vPackageList.elementAt(index));\r
                 dmtnModulePackageModule = new IDefaultMutableTreeNode("Module",\r
                                                                       IDefaultMutableTreeNode.MODULE_PACKAGE_MODULE,\r
-                                                                      false, this.vPackageList.elementAt(index));\r
+                                                                      false, GlobalData.vPackageList.elementAt(index));\r
                 //\r
                 // And then add each module in its package\r
                 //\r
-                Vector<ModuleIdentification> vModule = wt.getAllModules(this.vPackageList.elementAt(index));\r
+                Vector<ModuleIdentification> vModule = wt.getAllModules(GlobalData.vPackageList.elementAt(index));\r
                 for (int indexJ = 0; indexJ < vModule.size(); indexJ++) {\r
                     if (vModule.get(indexJ).isLibrary()) {\r
                         dmtnModulePackageLibrary.add(new IDefaultMutableTreeNode(vModule.get(indexJ).getName(),\r
-                                                                                 IDefaultMutableTreeNode.MODULE,\r
-                                                                                 false, vModule.get(indexJ)));\r
+                                                                                 IDefaultMutableTreeNode.MODULE, false,\r
+                                                                                 vModule.get(indexJ)));\r
                     } else {\r
                         dmtnModulePackageModule.add(new IDefaultMutableTreeNode(vModule.get(indexJ).getName(),\r
-                                                                                IDefaultMutableTreeNode.MODULE,\r
-                                                                                false, vModule.get(indexJ)));\r
+                                                                                IDefaultMutableTreeNode.MODULE, false,\r
+                                                                                vModule.get(indexJ)));\r
                     }\r
                 }\r
                 if (dmtnModulePackageModule.getChildCount() > 0) {\r
@@ -1873,11 +1955,12 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         // Make Package Description\r
         //\r
         dmtnPackageDescription = new IDefaultMutableTreeNode("PackageDescription", IDefaultMutableTreeNode.PACKAGE, -1);\r
-        if (this.vPackageList.size() > 0) {\r
-            for (int index = 0; index < this.vPackageList.size(); index++) {\r
-                dmtnPackageDescription.add(new IDefaultMutableTreeNode(this.vPackageList.elementAt(index).getName(),\r
+        if (GlobalData.vPackageList.size() > 0) {\r
+            for (int index = 0; index < GlobalData.vPackageList.size(); index++) {\r
+                dmtnPackageDescription.add(new IDefaultMutableTreeNode(GlobalData.vPackageList.elementAt(index)\r
+                                                                                              .getName(),\r
                                                                        IDefaultMutableTreeNode.PACKAGE, false,\r
-                                                                       this.vPackageList.elementAt(index)));\r
+                                                                       GlobalData.vPackageList.elementAt(index)));\r
             }\r
         }\r
 \r
@@ -1886,11 +1969,12 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         dmtnPlatformDescription = new IDefaultMutableTreeNode("PlatformDescription", IDefaultMutableTreeNode.PLATFORM,\r
                                                               -1);\r
-        if (this.vPlatformList.size() > 0) {\r
-            for (int index = 0; index < this.vPlatformList.size(); index++) {\r
-                dmtnPlatformDescription.add(new IDefaultMutableTreeNode(this.vPlatformList.elementAt(index).getName(),\r
-                                                                        IDefaultMutableTreeNode.PLATFORM,\r
-                                                                        false, this.vPlatformList.elementAt(index)));\r
+        if (GlobalData.vPlatformList.size() > 0) {\r
+            for (int index = 0; index < GlobalData.vPlatformList.size(); index++) {\r
+                dmtnPlatformDescription.add(new IDefaultMutableTreeNode(GlobalData.vPlatformList.elementAt(index)\r
+                                                                                                .getName(),\r
+                                                                        IDefaultMutableTreeNode.PLATFORM, false,\r
+                                                                        GlobalData.vPlatformList.elementAt(index)));\r
             }\r
         }\r
 \r
@@ -2023,8 +2107,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         // Add new MsaHeader node to the tree\r
         //\r
-        IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(mid.getName(), IDefaultMutableTreeNode.MSA_HEADER,\r
-                                                                   true, mid);\r
+        IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(mid.getName(), IDefaultMutableTreeNode.MODULE, true,\r
+                                                                   mid);\r
         //\r
         // First find the module belongs to which package\r
         //\r
@@ -2083,90 +2167,6 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         }\r
     }\r
 \r
-    /**\r
-     Open Module\r
-\r
-     @param path input file path\r
-     \r
-     **/\r
-    private void openModule(String path, ModuleIdentification moduleId) {\r
-        ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = null;\r
-        try {\r
-            msa = OpenFile.openMsaFile(path);\r
-        } catch (IOException e) {\r
-            Log.wrn("Open Module Surface Area " + path, e.getMessage());\r
-            Log.err("Open Module Surface Area " + path, e.getMessage());\r
-            return;\r
-        } catch (XmlException e) {\r
-            Log.wrn("Open Module Surface Area " + path, e.getMessage());\r
-            Log.err("Open Module Surface Area " + path, e.getMessage());\r
-            return;\r
-        } catch (Exception e) {\r
-            Log.wrn("Open Module Surface Area " + path, "Invalid file type");\r
-            Log.err("Open Module Surface Area " + path, "Invalid file type");\r
-            return;\r
-        }\r
-        Identification id = new Identification(msa.getMsaHeader().getModuleName(), msa.getMsaHeader().getGuidValue(),\r
-                                               msa.getMsaHeader().getVersion(), path);\r
-        //\r
-        // Generate module id\r
-        //\r
-        PackageIdentification pid = wt.getPackageIdByModuleId(id);\r
-        if (pid != null) {\r
-            //\r
-            // To judge if the module existed in vModuleList\r
-            // If not, add it to vModuleList\r
-            //\r
-            boolean isFind = false;\r
-            for (int index = 0; index < vModuleList.size(); index++) {\r
-                if (vModuleList.elementAt(index).equals(id)) {\r
-                    isFind = true;\r
-                    break;\r
-                }\r
-            }\r
-            if (!isFind) {\r
-                ModuleIdentification mid = new ModuleIdentification(id, pid, moduleId.isLibrary());\r
-                vModuleList.addElement(mid);\r
-                addModuleToTree(mid);\r
-            }\r
-        } else {\r
-            //\r
-            // The module is not in existing packages\r
-            //\r
-            Log.err("The module hasn't been added to any package of current workspace!");\r
-            return;\r
-        }\r
-\r
-        //\r
-        // Make the node selected\r
-        //\r
-        iTree.setSelectionPath(iTree.getPathOfNode(iTree.getNodeById(this.dmtnModuleDescription, id,\r
-                                                                     IDefaultMutableTreeNode.MODULE)));\r
-        //\r
-        // Update opening Module list information\r
-        //\r
-        if (!openingModuleList.existsModule(id)) {\r
-            //\r
-            // Insert sub node of module\r
-            //\r
-            insertModuleTreeNode(id);\r
-            iTree.getSelectNode().setOpening(true);\r
-\r
-            //\r
-            // Update opening module list\r
-            //\r
-            openingModuleList.insertToOpeningModuleList(id, msa);\r
-            openingModuleList.setTreePathById(id, iTree.getSelectionPath());\r
-        }\r
-        //\r
-        // Select msa header node and show it in editor panel\r
-        //\r
-        iTree.setSelectionPath(iTree.getPathOfNode(iTree.getNodeById(this.dmtnModuleDescription, id,\r
-                                                                     IDefaultMutableTreeNode.MSA_HEADER)));\r
-        showModuleElement(IDefaultMutableTreeNode.MSA_HEADER, openingModuleList.getOpeningModuleById(id));\r
-        this.currentOpeningModuleIndex = openingModuleList.findIndexOfListById(id);\r
-    }\r
-\r
     /**\r
      Open Module\r
 \r
@@ -2174,46 +2174,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
      \r
      **/\r
     private void openModule(String path) {\r
-        ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = null;\r
-        try {\r
-            msa = OpenFile.openMsaFile(path);\r
-        } catch (IOException e) {\r
-            Log.wrn("Open Module Surface Area " + path, e.getMessage());\r
-            Log.err("Open Module Surface Area " + path, e.getMessage());\r
-            return;\r
-        } catch (XmlException e) {\r
-            Log.wrn("Open Module Surface Area " + path, e.getMessage());\r
-            Log.err("Open Module Surface Area " + path, e.getMessage());\r
-            return;\r
-        } catch (Exception e) {\r
-            Log.wrn("Open Module Surface Area " + path, "Invalid file type");\r
-            Log.err("Open Module Surface Area " + path, "Invalid file type");\r
-            return;\r
-        }\r
-        Identification id = new Identification(msa.getMsaHeader().getModuleName(), msa.getMsaHeader().getGuidValue(),\r
-                                               msa.getMsaHeader().getVersion(), path);\r
-        //\r
-        // Generate module id\r
-        //\r
-        PackageIdentification pid = wt.getPackageIdByModuleId(id);\r
-        if (pid != null) {\r
-            //\r
-            // To judge if the module existed in vModuleList\r
-            // If not, add it to vModuleList\r
-            //\r
-            boolean isFind = false;\r
-            for (int index = 0; index < vModuleList.size(); index++) {\r
-                if (vModuleList.elementAt(index).equals(id)) {\r
-                    isFind = true;\r
-                    break;\r
-                }\r
-            }\r
-            if (!isFind) {\r
-                ModuleIdentification mid = new ModuleIdentification(id, pid);\r
-                vModuleList.addElement(mid);\r
-                addModuleToTree(mid);\r
-            }\r
-        } else {\r
+        ModuleIdentification id = GlobalData.openingModuleList.getIdByPath(path);\r
+        if (id == null) {\r
             //\r
             // The module is not in existing packages\r
             //\r
@@ -2229,7 +2191,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         // Update opening Module list information\r
         //\r
-        if (!openingModuleList.existsModule(id)) {\r
+        if (!GlobalData.openingModuleList.getModuleOpen(id)) {\r
             //\r
             // Insert sub node of module\r
             //\r
@@ -2239,16 +2201,16 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             //\r
             // Update opening module list\r
             //\r
-            openingModuleList.insertToOpeningModuleList(id, msa);\r
-            openingModuleList.setTreePathById(id, iTree.getSelectionPath());\r
+            GlobalData.openingModuleList.setModuleOpen(id, true);\r
+            GlobalData.openingModuleList.setTreePathById(id, iTree.getSelectionPath());\r
         }\r
         //\r
         // Select msa header node and show it in editor panel\r
         //\r
         iTree.setSelectionPath(iTree.getPathOfNode(iTree.getNodeById(this.dmtnModuleDescription, id,\r
                                                                      IDefaultMutableTreeNode.MSA_HEADER)));\r
-        showModuleElement(IDefaultMutableTreeNode.MSA_HEADER, openingModuleList.getOpeningModuleById(id));\r
-        this.currentOpeningModuleIndex = openingModuleList.findIndexOfListById(id);\r
+        showModuleElement(IDefaultMutableTreeNode.MSA_HEADER, GlobalData.openingModuleList.getOpeningModuleById(id));\r
+        this.currentOpeningModuleIndex = GlobalData.openingModuleList.findIndexOfListById(id);\r
     }\r
 \r
     /**\r
@@ -2258,38 +2220,10 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
      \r
      **/\r
     private void openPackage(String path) {\r
-        PackageSurfaceAreaDocument.PackageSurfaceArea spd = null;\r
-        try {\r
-            spd = OpenFile.openSpdFile(path);\r
-        } catch (IOException e) {\r
-            Log.wrn("Open Package Surface Area " + path, e.getMessage());\r
-            Log.err("Open Package Surface Area " + path, e.getMessage());\r
-            return;\r
-        } catch (XmlException e) {\r
-            Log.wrn("Open Package Surface Area " + path, e.getMessage());\r
-            Log.err("Open Package Surface Area " + path, e.getMessage());\r
-            return;\r
-        } catch (Exception e) {\r
-            Log.wrn("Open Package Surface Area " + path, "Invalid file type");\r
-            Log.err("Open Package Surface Area " + path, "Invalid file type");\r
-            return;\r
-        }\r
-        Identification id = new Identification(spd.getSpdHeader().getPackageName(), spd.getSpdHeader().getGuidValue(),\r
-                                               spd.getSpdHeader().getVersion(), path);\r
-        //\r
-        // To judge if the package existed in vPackageList\r
-        // If not, add it to vPackageList\r
-        //\r
-        boolean isFind = false;\r
-        for (int index = 0; index < vPackageList.size(); index++) {\r
-            if (vPackageList.elementAt(index).equals(id)) {\r
-                isFind = true;\r
-                break;\r
-            }\r
-        }\r
-        if (!isFind) {\r
+        PackageIdentification id = GlobalData.openingPackageList.getIdByPath(path);\r
+        if (id == null) {\r
             //\r
-            // The module is not in existing packages\r
+            // The package is not in current workspace\r
             //\r
             Log.wrn("Open Package", "The package hasn't been added to current workspace!");\r
             return;\r
@@ -2303,7 +2237,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         // Update opening package list information\r
         //\r
-        if (!openingPackageList.existsPackage(id)) {\r
+        if (!GlobalData.openingPackageList.getPackageOpen(id)) {\r
             //\r
             // Insert sub node of module\r
             //\r
@@ -2313,16 +2247,16 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             //\r
             // Update opening module list\r
             //\r
-            openingPackageList.insertToOpeningPackageList(id, spd);\r
-            openingPackageList.setTreePathById(id, iTree.getSelectionPath());\r
+            GlobalData.openingPackageList.setPackageOpen(id, true);\r
+            GlobalData.openingPackageList.setTreePathById(id, iTree.getSelectionPath());\r
         }\r
         //\r
         // Show spd header in editor panel\r
         //\r
         iTree.setSelectionPath(iTree.getPathOfNode(iTree.getNodeById(this.dmtnPackageDescription, id,\r
                                                                      IDefaultMutableTreeNode.SPD_HEADER)));\r
-        showPackageElement(IDefaultMutableTreeNode.SPD_HEADER, openingPackageList.getOpeningPackageById(id));\r
-        this.currentOpeningPackageIndex = openingPackageList.findIndexOfListById(id);\r
+        showPackageElement(IDefaultMutableTreeNode.SPD_HEADER, GlobalData.openingPackageList.getOpeningPackageById(id));\r
+        this.currentOpeningPackageIndex = GlobalData.openingPackageList.findIndexOfListById(id);\r
     }\r
 \r
     /**\r
@@ -2332,39 +2266,10 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
      \r
      **/\r
     private void openPlatform(String path) {\r
-        PlatformSurfaceAreaDocument.PlatformSurfaceArea fpd = null;\r
-        try {\r
-            fpd = OpenFile.openFpdFile(path);\r
-        } catch (IOException e) {\r
-            Log.wrn("Open Platform Surface Area " + path, e.getMessage());\r
-            Log.err("Open Platform Surface Area " + path, e.getMessage());\r
-            return;\r
-        } catch (XmlException e) {\r
-            Log.wrn("Open Platform Surface Area " + path, e.getMessage());\r
-            Log.err("Open Platform Surface Area " + path, e.getMessage());\r
-            return;\r
-        } catch (Exception e) {\r
-            Log.wrn("Open Platform Surface Area " + path, "Invalid file type");\r
-            Log.err("Open Platform Surface Area " + path, "Invalid file type");\r
-            return;\r
-        }\r
-        Identification id = new Identification(fpd.getPlatformHeader().getPlatformName(), fpd.getPlatformHeader()\r
-                                                                                             .getGuidValue(),\r
-                                               fpd.getPlatformHeader().getVersion(), path);\r
-        //\r
-        // To judge if the platform existed in vPlatformList\r
-        // If not, add it to vPlatformList\r
-        //\r
-        boolean isFind = false;\r
-        for (int index = 0; index < vPlatformList.size(); index++) {\r
-            if (vPlatformList.elementAt(index).equals(id)) {\r
-                isFind = true;\r
-                break;\r
-            }\r
-        }\r
-        if (!isFind) {\r
+        PlatformIdentification id = GlobalData.openingPlatformList.getIdByPath(path);\r
+        if (id == null) {\r
             //\r
-            // The module is not in existing packages\r
+            // The platform is not in current workspace\r
             //\r
             Log.wrn("Open Platform", "The platform hasn't been added to current workspace!");\r
             return;\r
@@ -2378,7 +2283,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         // Update opening package list information\r
         //\r
-        if (!openingPlatformList.existsPlatform(id)) {\r
+        if (!GlobalData.openingPlatformList.getPlatformOpen(id)) {\r
             //\r
             // Insert sub node of module\r
             //\r
@@ -2388,16 +2293,17 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             //\r
             // Update opening module list\r
             //\r
-            openingPlatformList.insertToOpeningPlatformList(id, fpd);\r
-            openingPlatformList.setTreePathById(id, iTree.getSelectionPath());\r
+            GlobalData.openingPlatformList.setPlatformOpen(id, true);\r
+            GlobalData.openingPlatformList.setTreePathById(id, iTree.getSelectionPath());\r
         }\r
         //\r
         // Show fpd header in editor panel\r
         //\r
         iTree.setSelectionPath(iTree.getPathOfNode(iTree.getNodeById(this.dmtnPlatformDescription, id,\r
                                                                      IDefaultMutableTreeNode.FPD_PLATFORMHEADER)));\r
-        showPlatformElement(IDefaultMutableTreeNode.FPD_PLATFORMHEADER, openingPlatformList.getOpeningPlatformById(id));\r
-        this.currentOpeningPlatformIndex = openingPlatformList.findIndexOfListById(id);\r
+        showPlatformElement(IDefaultMutableTreeNode.FPD_PLATFORMHEADER,\r
+                            GlobalData.openingPlatformList.getOpeningPlatformById(id));\r
+        this.currentOpeningPlatformIndex = GlobalData.openingPlatformList.findIndexOfListById(id);\r
     }\r
 \r
     /**\r
@@ -2405,7 +2311,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
      \r
      **/\r
     private void saveModule(int index) {\r
-        OpeningModuleType omt = openingModuleList.getOpeningModuleByIndex(index);\r
+        OpeningModuleType omt = GlobalData.openingModuleList.getOpeningModuleByIndex(index);\r
         if (omt.isNew()) {\r
             if (getNewFilePath(DataType.MODULE_SURFACE_AREA_EXT) != JFileChooser.APPROVE_OPTION) {\r
                 return;\r
@@ -2413,8 +2319,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         }\r
         try {\r
             SaveFile.saveMsaFile(omt.getId().getPath(), omt.getXmlMsa());\r
-            openingModuleList.setNew(omt.getId(), false);\r
-            openingModuleList.setModuleSaved(omt.getId(), true);\r
+            GlobalData.openingModuleList.setNew(omt.getId(), false);\r
+            GlobalData.openingModuleList.setModuleSaved(omt.getId(), true);\r
         } catch (Exception e) {\r
             Log.wrn("Save Module", e.getMessage());\r
             Log.err("Save Module", e.getMessage());\r
@@ -2426,7 +2332,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
      \r
      **/\r
     private void savePackage(int index) {\r
-        OpeningPackageType opt = openingPackageList.getOpeningPackageByIndex(index);\r
+        OpeningPackageType opt = GlobalData.openingPackageList.getOpeningPackageByIndex(index);\r
         if (opt.isNew()) {\r
             if (getNewFilePath(DataType.PACKAGE_SURFACE_AREA_EXT) != JFileChooser.APPROVE_OPTION) {\r
                 return;\r
@@ -2434,8 +2340,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         }\r
         try {\r
             SaveFile.saveSpdFile(opt.getId().getPath(), opt.getXmlSpd());\r
-            openingPackageList.setNew(opt.getId(), false);\r
-            openingPackageList.setPackageSaved(opt.getId(), true);\r
+            GlobalData.openingPackageList.setNew(opt.getId(), false);\r
+            GlobalData.openingPackageList.setPackageSaved(opt.getId(), true);\r
         } catch (Exception e) {\r
             Log.wrn("Save Package", e.getMessage());\r
             Log.err("Save Package", e.getMessage());\r
@@ -2447,7 +2353,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
      \r
      **/\r
     private void savePlatform(int index) {\r
-        OpeningPlatformType opt = openingPlatformList.getOpeningPlatformByIndex(index);\r
+        OpeningPlatformType opt = GlobalData.openingPlatformList.getOpeningPlatformByIndex(index);\r
         if (opt.isNew()) {\r
             if (getNewFilePath(DataType.PACKAGE_SURFACE_AREA_EXT) != JFileChooser.APPROVE_OPTION) {\r
                 return;\r
@@ -2455,34 +2361,21 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         }\r
         try {\r
             SaveFile.saveFpdFile(opt.getId().getPath(), opt.getXmlFpd());\r
-            openingPlatformList.setNew(opt.getId(), false);\r
-            openingPlatformList.setPlatformSaved(opt.getId(), true);\r
+            GlobalData.openingPlatformList.setNew(opt.getId(), false);\r
+            GlobalData.openingPlatformList.setPlatformSaved(opt.getId(), true);\r
         } catch (Exception e) {\r
             Log.wrn("Save Package", e.getMessage());\r
             Log.err("Save Package", e.getMessage());\r
         }\r
     }\r
 \r
-    public void componentHidden(ComponentEvent arg0) {\r
-        // TODO Auto-generated method stub\r
-\r
-    }\r
-\r
-    public void componentMoved(ComponentEvent arg0) {\r
-        // TODO Auto-generated method stub\r
-\r
-    }\r
-\r
     public void componentResized(ComponentEvent arg0) {\r
-        this.jSplitPane.setSize(this.getWidth() - DataType.MAIN_FRAME_WIDTH_SPACING,\r
-                                this.getHeight() - DataType.MAIN_FRAME_HEIGHT_SPACING);\r
-        this.jSplitPane.validate();\r
-        resizeDesktopPanel();\r
-    }\r
-\r
-    public void componentShown(ComponentEvent arg0) {\r
-        // TODO Auto-generated method stub\r
-\r
+        if (this.jSplitPane != null) {\r
+            this.jSplitPane.setSize(this.getWidth() - DataType.MAIN_FRAME_WIDTH_SPACING,\r
+                                    this.getHeight() - DataType.MAIN_FRAME_HEIGHT_SPACING);\r
+            this.jSplitPane.validate();\r
+            resizeDesktopPanel();\r
+        }\r
     }\r
 \r
     /**\r
@@ -2506,19 +2399,11 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         }\r
     }\r
 \r
-    private void getCompontentsFromFrameworkDatabase() {\r
-        this.vModuleList = wt.getAllModules();\r
-        this.vPackageList = wt.getAllPackages();\r
-        this.vPlatformList = wt.getAllPlatforms();\r
-    }\r
-\r
     private void insertModuleTreeNode(Identification id) {\r
         iTree.addNode(new IDefaultMutableTreeNode("Module Header", IDefaultMutableTreeNode.MSA_HEADER, true, id));\r
-        iTree.addNode(new IDefaultMutableTreeNode("Module Definitions", IDefaultMutableTreeNode.MSA_MODULEDEFINITIONS,\r
-                                                  true, id));\r
+        iTree.addNode(new IDefaultMutableTreeNode("Source Files", IDefaultMutableTreeNode.MSA_SOURCEFILES, true, id));\r
         iTree.addNode(new IDefaultMutableTreeNode("Library Class Definitions",\r
                                                   IDefaultMutableTreeNode.MSA_LIBRARYCLASSDEFINITIONS, true, id));\r
-        iTree.addNode(new IDefaultMutableTreeNode("Source Files", IDefaultMutableTreeNode.MSA_SOURCEFILES, true, id));\r
         iTree.addNode(new IDefaultMutableTreeNode("Package Dependencies",\r
                                                   IDefaultMutableTreeNode.MSA_PACKAGEDEPENDENCIES, true, id));\r
         iTree.addNode(new IDefaultMutableTreeNode("Protocols", IDefaultMutableTreeNode.MSA_PROTOCOLS, true, id));\r
@@ -2537,8 +2422,6 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
 \r
     private void insertPackageTreeNode(Identification id) {\r
         iTree.addNode(new IDefaultMutableTreeNode("Package Header", IDefaultMutableTreeNode.SPD_HEADER, true, id));\r
-        iTree.addNode(new IDefaultMutableTreeNode("Package Definitions",\r
-                                                  IDefaultMutableTreeNode.SPD_PACKAGEDEFINITIONS, true, id));\r
         iTree.addNode(new IDefaultMutableTreeNode("Library Class Declarations",\r
                                                   IDefaultMutableTreeNode.SPD_LIBRARYCLASSDECLARATIONS, true, id));\r
         iTree.addNode(new IDefaultMutableTreeNode("Msa Files", IDefaultMutableTreeNode.SPD_MSAFILES, false, id));\r
@@ -2580,7 +2463,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             id = iTree.getSelectNode().getId();\r
             intCategory = iTree.getSelectCategory();\r
             isOpen = iTree.getSelectNode().isOpening();\r
-            \r
+\r
             if (!isOpen) {\r
                 //              \r
                 // If the node is not opened yet\r
@@ -2608,27 +2491,38 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
                     return;\r
                 }\r
             }\r
-            \r
+\r
             //\r
             // Show editor panel\r
             //\r
             if (intCategory >= IDefaultMutableTreeNode.MSA_HEADER && intCategory < IDefaultMutableTreeNode.SPD_HEADER) {\r
-                showModuleElement(intCategory, openingModuleList.getOpeningModuleById(id));\r
-                this.currentOpeningModuleIndex = openingModuleList.findIndexOfListById(id);\r
+                showModuleElement(intCategory,\r
+                                  GlobalData.openingModuleList.getOpeningModuleById(new ModuleIdentification(id)));\r
+                this.currentOpeningModuleIndex = GlobalData.openingModuleList\r
+                                                                             .findIndexOfListById(new ModuleIdentification(\r
+                                                                                                                           id));\r
             }\r
             if (intCategory >= IDefaultMutableTreeNode.SPD_HEADER\r
                 && intCategory < IDefaultMutableTreeNode.FPD_PLATFORMHEADER) {\r
-                showPackageElement(intCategory, openingPackageList.getOpeningPackageById(id));\r
-                this.currentOpeningPackageIndex = openingPackageList.findIndexOfListById(id);\r
+                showPackageElement(intCategory,\r
+                                   GlobalData.openingPackageList.getOpeningPackageById(new PackageIdentification(id)));\r
+                this.currentOpeningPackageIndex = GlobalData.openingPackageList\r
+                                                                               .findIndexOfListById(new PackageIdentification(\r
+                                                                                                                              id));\r
             }\r
             if (intCategory >= IDefaultMutableTreeNode.FPD_PLATFORMHEADER) {\r
-                showPlatformElement(intCategory, openingPlatformList.getOpeningPlatformById(id));\r
-                this.currentOpeningPlatformIndex = openingPlatformList.findIndexOfListById(id);\r
+                showPlatformElement(\r
+                                    intCategory,\r
+                                    GlobalData.openingPlatformList\r
+                                                                  .getOpeningPlatformById(new PlatformIdentification(id)));\r
+                this.currentOpeningPlatformIndex = GlobalData.openingPlatformList\r
+                                                                                 .findIndexOfListById(new PlatformIdentification(\r
+                                                                                                                                 id));\r
             }\r
         } catch (RuntimeException e) {\r
-            Log.log("double click category: " + intCategory);\r
-            Log.log("double click id path: " + id);\r
-            Log.log("double click exception: " + e.getMessage());\r
+            Log.err("double click category: " + intCategory);\r
+            Log.err("double click id path: " + id);\r
+            Log.err("double click exception: " + e.getMessage());\r
         }\r
     }\r
 \r
@@ -2734,10 +2628,6 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             MsaHeader frmMsaHeader = new MsaHeader(msa);\r
             getJDesktopPaneModule().add(frmMsaHeader, 1);\r
             break;\r
-        case IDefaultMutableTreeNode.MSA_MODULEDEFINITIONS:\r
-            ModuleDefinitions frmMd = new ModuleDefinitions(msa);\r
-            getJDesktopPaneModule().add(frmMd, 1);\r
-            break;\r
         case IDefaultMutableTreeNode.MSA_LIBRARYCLASSDEFINITIONS:\r
             ModuleLibraryClassDefinitions frmMlcd = new ModuleLibraryClassDefinitions(msa);\r
             getJDesktopPaneModule().add(frmMlcd, 1);\r
@@ -2833,26 +2723,47 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
                 smb.dispose();\r
                 return;\r
             } else if (result == DataType.RETURN_TYPE_OK) {\r
-                PackageSurfaceAreaDocument.PackageSurfaceArea psa = null;\r
-                if (this.openingPackageList.existsPackage(smb.getMid().getPackageId())) {\r
-                    psa = openingPackageList.getPackageSurfaceAreaFromId(smb.getMid().getPackageId());\r
-                }\r
-                try {\r
-                    wt.addModuleToPackage(smb.getMid(), psa);\r
-                } catch (IOException e) {\r
-                    Log.wrn("Upddate MsaFiles of Package", e.getMessage());\r
-                    Log.err("Upddate MsaFiles of Package", e.getMessage());\r
-                    return;\r
-                } catch (XmlException e) {\r
-                    Log.wrn("Upddate MsaFiles of Package", e.getMessage());\r
-                    Log.err("Upddate MsaFiles of Package", e.getMessage());\r
-                    return;\r
-                } catch (Exception e) {\r
-                    Log.wrn("Upddate MsaFiles of Package", e.getMessage());\r
-                    Log.err("Upddate MsaFiles of Package", e.getMessage());\r
-                    return;\r
+                ModuleIdentification mid = smb.getMid();\r
+                if (mid != null) {\r
+                    //\r
+                    // Update package of workspace first\r
+                    //\r
+                    PackageSurfaceAreaDocument.PackageSurfaceArea psa = null;\r
+                    if (GlobalData.openingPackageList.existsPackage(mid.getPackageId())) {\r
+                        psa = GlobalData.openingPackageList.getPackageSurfaceAreaFromId(mid.getPackageId());\r
+                    }\r
+                    try {\r
+                        wt.addModuleToPackage(mid, psa);\r
+                    } catch (IOException e) {\r
+                        Log.wrn("Upddate MsaFiles of Package", e.getMessage());\r
+                        Log.err("Upddate MsaFiles of Package", e.getMessage());\r
+                        return;\r
+                    } catch (XmlException e) {\r
+                        Log.wrn("Upddate MsaFiles of Package", e.getMessage());\r
+                        Log.err("Upddate MsaFiles of Package", e.getMessage());\r
+                        return;\r
+                    } catch (Exception e) {\r
+                        Log.wrn("Upddate MsaFiles of Package", e.getMessage());\r
+                        Log.err("Upddate MsaFiles of Package", e.getMessage());\r
+                        return;\r
+                    }\r
+\r
+                    //\r
+                    // Update Global Data\r
+                    //\r
+                    GlobalData.openingModuleList.insertToOpeningModuleList(mid, smb.getMsa());\r
+                    GlobalData.vModuleList.addElement(mid);\r
+\r
+                    //\r
+                    // Create new node on the tree\r
+                    //\r
+                    addModuleToTree(mid);\r
+\r
+                    //\r
+                    // Open the node\r
+                    //\r
+                    this.openModule(mid.getPath());\r
                 }\r
-                this.openModule(smb.getMid().getPath(), smb.getMid());\r
             }\r
         } else if (result == DataType.RETURN_TYPE_PACKAGE_SURFACE_AREA) {\r
             //\r
@@ -2866,30 +2777,37 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
                 smb.dispose();\r
                 return;\r
             } else if (result == DataType.RETURN_TYPE_OK) {\r
-                try {\r
-                    wt.addPackageToDatabase(smb.getPid());\r
-                } catch (Exception e) {\r
-                    Log.err("addPackageToDatabase", e.getMessage());\r
-                }\r
-                vPackageList.addElement(smb.getPid());\r
+                PackageIdentification pid = smb.getPid();\r
+                if (pid != null) {\r
+                    try {\r
+                        wt.addPackageToDatabase(smb.getPid());\r
+                    } catch (Exception e) {\r
+                        Log.err("addPackageToDatabase", e.getMessage());\r
+                    }\r
 \r
-                //\r
-                // Add to Module Description node\r
-                //\r
-                IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(vPackageList.lastElement().getName(),\r
-                                                                           IDefaultMutableTreeNode.MODULE_PACKAGE,\r
-                                                                           false, vPackageList.lastElement());\r
+                    //\r
+                    // Update Global Data\r
+                    //\r
+                    GlobalData.openingPackageList.insertToOpeningPackageList(pid, smb.getSpd());\r
+                    GlobalData.vPackageList.addElement(pid);\r
 \r
-                iTree.addNode(dmtnModuleDescription, node);\r
+                    //\r
+                    // Add to Module Description node\r
+                    //\r
+                    IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(pid.getName(),\r
+                                                                               IDefaultMutableTreeNode.MODULE_PACKAGE,\r
+                                                                               false, pid);\r
 \r
-                //\r
-                // Add new SpdHeader node to the tree\r
-                //\r
-                node = new IDefaultMutableTreeNode(vPackageList.lastElement().getName(),\r
-                                                   IDefaultMutableTreeNode.SPD_HEADER, true, vPackageList.lastElement());\r
-                iTree.addNode(dmtnPackageDescription, node);\r
+                    iTree.addNode(dmtnModuleDescription, node);\r
+\r
+                    //\r
+                    // Add new SpdHeader node to the tree\r
+                    //\r
+                    node = new IDefaultMutableTreeNode(pid.getName(), IDefaultMutableTreeNode.PACKAGE, true, pid);\r
+                    iTree.addNode(dmtnPackageDescription, node);\r
 \r
-                this.openPackage(smb.getPid().getPath());\r
+                    this.openPackage(pid.getPath());\r
+                }\r
             }\r
         } else if (result == DataType.RETURN_TYPE_PLATFORM_SURFACE_AREA) {\r
             //\r
@@ -2903,20 +2821,28 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
                 smb.dispose();\r
                 return;\r
             } else if (result == DataType.RETURN_TYPE_OK) {\r
-                try {\r
-                    wt.addPlatformToDatabase(smb.getFid());\r
-                } catch (Exception e) {\r
-                    Log.err("addPlatformToDatabase", e.getMessage());\r
+                PlatformIdentification fid = smb.getFid();\r
+                if (fid != null) {\r
+                    try {\r
+                        wt.addPlatformToDatabase(fid);\r
+                    } catch (Exception e) {\r
+                        Log.err("addPlatformToDatabase", e.getMessage());\r
+                    }\r
+\r
+                    //\r
+                    // Update global data\r
+                    //\r
+                    GlobalData.openingPlatformList.insertToOpeningPlatformList(fid, smb.getFpd());\r
+                    GlobalData.vPlatformList.addElement(fid);\r
+                    //\r
+                    // Add new SpdHeader node to the tree\r
+                    //\r
+                    IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(fid.getName(),\r
+                                                                               IDefaultMutableTreeNode.PLATFORM, true,\r
+                                                                               fid);\r
+                    iTree.addNode(dmtnPlatformDescription, node);\r
+                    this.openPlatform(fid.getPath());\r
                 }\r
-                vPlatformList.addElement(smb.getFid());\r
-                //\r
-                // Add new SpdHeader node to the tree\r
-                //\r
-                IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(vPlatformList.lastElement().getName(),\r
-                                                                           IDefaultMutableTreeNode.FPD_PLATFORMHEADER,\r
-                                                                           true, vPlatformList.lastElement());\r
-                iTree.addNode(dmtnPlatformDescription, node);\r
-                this.openPlatform(smb.getFid().getPath());\r
             }\r
         }\r
     }\r
@@ -2962,7 +2888,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         case 0:\r
             if (this.currentOpeningModuleIndex > -1) {\r
-                if (!openingModuleList.getModuleSaved(currentOpeningModuleIndex)) {\r
+                if (!GlobalData.openingModuleList.getModuleSaved(currentOpeningModuleIndex)) {\r
                     int result = showSaveDialog();\r
                     if (result == JOptionPane.YES_OPTION) {\r
                         this.saveAll();\r
@@ -2974,18 +2900,20 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
                         return;\r
                     }\r
                 }\r
-                iTree.removeNodeChildrenByPath(openingModuleList.getTreePathByIndex(currentOpeningModuleIndex));\r
-                this.openingModuleList.removeFromOpeningModuleListByIndex(this.currentOpeningModuleIndex);\r
+                iTree\r
+                     .removeNodeChildrenByPath(GlobalData.openingModuleList\r
+                                                                           .getTreePathByIndex(currentOpeningModuleIndex));\r
+                GlobalData.openingModuleList.setModuleOpen(this.currentOpeningModuleIndex, false);\r
                 this.cleanDesktopPaneModule();\r
                 this.currentOpeningModuleIndex = -1;\r
             }\r
             break;\r
         //\r
         // Current is package\r
-        //    \r
+        //\r
         case 1:\r
             if (this.currentOpeningPackageIndex > -1) {\r
-                if (!openingPackageList.getPackageSaved(currentOpeningPackageIndex)) {\r
+                if (!GlobalData.openingPackageList.getPackageSaved(currentOpeningPackageIndex)) {\r
                     int result = showSaveDialog();\r
                     if (result == JOptionPane.YES_OPTION) {\r
                         this.saveAll();\r
@@ -2997,8 +2925,10 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
                         return;\r
                     }\r
                 }\r
-                iTree.removeNodeChildrenByPath(openingPackageList.getTreePathByIndex(currentOpeningPackageIndex));\r
-                this.openingPackageList.removeFromOpeningPackageListByIndex(this.currentOpeningPackageIndex);\r
+                iTree\r
+                     .removeNodeChildrenByPath(GlobalData.openingPackageList\r
+                                                                            .getTreePathByIndex(currentOpeningPackageIndex));\r
+                GlobalData.openingPackageList.setPackageOpen(this.currentOpeningPackageIndex, false);\r
                 this.cleanDesktopPanePackage();\r
                 this.currentOpeningPackageIndex = -1;\r
             }\r
@@ -3008,7 +2938,7 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         case 2:\r
             if (this.currentOpeningPlatformIndex > -1) {\r
-                if (!openingPlatformList.getPlatformSaved(currentOpeningPlatformIndex)) {\r
+                if (!GlobalData.openingPlatformList.getPlatformSaved(currentOpeningPlatformIndex)) {\r
                     int result = showSaveDialog();\r
                     if (result == JOptionPane.YES_OPTION) {\r
                         this.saveAll();\r
@@ -3020,8 +2950,10 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
                         return;\r
                     }\r
                 }\r
-                iTree.removeNodeChildrenByPath(openingPlatformList.getTreePathByIndex(currentOpeningPlatformIndex));\r
-                this.openingPlatformList.removeFromOpeningPlatformListByIndex(this.currentOpeningPlatformIndex);\r
+                iTree\r
+                     .removeNodeChildrenByPath(GlobalData.openingPlatformList\r
+                                                                             .getTreePathByIndex(currentOpeningPlatformIndex));\r
+                GlobalData.openingPlatformList.setPlatformOpen(this.currentOpeningPlatformIndex, false);\r
                 this.cleanDesktopPanePlatform();\r
                 this.currentOpeningPlatformIndex = -1;\r
             }\r
@@ -3035,7 +2967,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
      **/\r
     private void closeAll() {\r
         int result = -1;\r
-        if (!openingModuleList.isSaved() || !openingPackageList.isSaved() || !openingPlatformList.isSaved()) {\r
+        if (!GlobalData.openingModuleList.isSaved() || !GlobalData.openingPackageList.isSaved()\r
+            || !GlobalData.openingPlatformList.isSaved()) {\r
             result = showSaveDialog();\r
         }\r
         if (result == JOptionPane.YES_OPTION) {\r
@@ -3050,10 +2983,9 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             return;\r
         }\r
         this.cleanDesktopPane();\r
-        this.getCompontentsFromFrameworkDatabase();\r
-        openingModuleList.removeAllFromOpeningModuleList();\r
-        openingPackageList.removeAllFromOpeningPackageList();\r
-        openingPlatformList.removeAllFromOpeningPlatformList();\r
+        GlobalData.openingModuleList.closeAll();\r
+        GlobalData.openingPackageList.closeAll();\r
+        GlobalData.openingPlatformList.closeAll();\r
         this.makeEmptyTree();\r
     }\r
 \r
@@ -3089,8 +3021,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         // Save all modules\r
         //\r
-        for (int index = 0; index < openingModuleList.size(); index++) {\r
-            if (!openingModuleList.getModuleSaved(index)) {\r
+        for (int index = 0; index < GlobalData.openingModuleList.size(); index++) {\r
+            if (!GlobalData.openingModuleList.getModuleSaved(index)) {\r
                 saveModule(index);\r
             }\r
         }\r
@@ -3098,8 +3030,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         // Save all packages\r
         //\r
-        for (int index = 0; index < openingPackageList.size(); index++) {\r
-            if (!openingPackageList.getPackageSaved(index)) {\r
+        for (int index = 0; index < GlobalData.openingPackageList.size(); index++) {\r
+            if (!GlobalData.openingPackageList.getPackageSaved(index)) {\r
                 savePackage(index);\r
             }\r
         }\r
@@ -3107,8 +3039,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         //\r
         // Save all platforms\r
         //\r
-        for (int index = 0; index < openingPlatformList.size(); index++) {\r
-            if (!openingPlatformList.getPlatformSaved(index)) {\r
+        for (int index = 0; index < GlobalData.openingPlatformList.size(); index++) {\r
+            if (!GlobalData.openingPlatformList.getPlatformSaved(index)) {\r
                 savePlatform(index);\r
             }\r
         }\r
@@ -3120,7 +3052,8 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
      **/\r
     private void exit() {\r
         int result = -1;\r
-        if (!openingModuleList.isSaved() || !openingPackageList.isSaved() || !openingPlatformList.isSaved()) {\r
+        if (!GlobalData.openingModuleList.isSaved() || !GlobalData.openingPackageList.isSaved()\r
+            || !GlobalData.openingPlatformList.isSaved()) {\r
             result = showSaveDialog();\r
         }\r
         if (result == JOptionPane.YES_OPTION) {\r
@@ -3136,6 +3069,15 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         System.exit(0);\r
     }\r
 \r
+    /**\r
+     To find all defined PPIs in workspace\r
+     \r
+     **/\r
+//    private void findPpi() {\r
+//        FindPPIsResult fpr = FindPPIsResult.getInstance();\r
+//        fpr.setVisible(true);\r
+//    }\r
+\r
     /**\r
      Switch current workspace to others\r
      \r
@@ -3152,6 +3094,10 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             closeAll();\r
             this.setTitle(DataType.PROJECT_NAME + " " + DataType.PROJECT_VERSION + " " + "- ["\r
                           + Workspace.getCurrentWorkspace() + "]");\r
+            //\r
+            // Reinit Global Data\r
+            //\r
+            GlobalData.init();\r
         }\r
         sw.dispose();\r
     }\r
@@ -3228,6 +3174,10 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         tcc.showDialog();\r
     }\r
 \r
+    private void configBuildPreferences() {\r
+       Preferences bt = Preferences.getInstance();\r
+       bt.showDialog();\r
+    }\r
     /**\r
      Clone selected item\r
      \r
@@ -3275,29 +3225,30 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
         }\r
         if (result == DataType.RETURN_TYPE_MODULE_SURFACE_AREA) {\r
             Tools.showInformationMessage("Module Surface Area Clone Finished");\r
-            vModuleList.addElement(c.getMid());\r
+            GlobalData.vModuleList.addElement(c.getMid());\r
             addModuleToTree(c.getMid());\r
         }\r
         if (result == DataType.RETURN_TYPE_PACKAGE_SURFACE_AREA) {\r
             Tools.showInformationMessage("Package Surface Area Clone Finished");\r
-            vPackageList.addElement(c.getPid());\r
+            GlobalData.vPackageList.addElement(c.getPid());\r
             //\r
             // Add new SpdHeader node to the tree\r
             //\r
-            IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(vPackageList.lastElement().getName(),\r
+            IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(GlobalData.vPackageList.lastElement().getName(),\r
                                                                        IDefaultMutableTreeNode.SPD_HEADER, true,\r
-                                                                       vPackageList.lastElement());\r
+                                                                       GlobalData.vPackageList.lastElement());\r
             iTree.addNode(dmtnPackageDescription, node);\r
         }\r
         if (result == DataType.RETURN_TYPE_PLATFORM_SURFACE_AREA) {\r
             Tools.showInformationMessage("Platform Surface Area Clone Finished");\r
-            vPlatformList.addElement(c.getFid());\r
+            GlobalData.vPlatformList.addElement(c.getFid());\r
             //\r
             // Add new SpdHeader node to the tree\r
             //\r
-            IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(vPlatformList.lastElement().getName(),\r
+            IDefaultMutableTreeNode node = new IDefaultMutableTreeNode(\r
+                                                                       GlobalData.vPlatformList.lastElement().getName(),\r
                                                                        IDefaultMutableTreeNode.FPD_PLATFORMHEADER,\r
-                                                                       true, vPlatformList.lastElement());\r
+                                                                       true, GlobalData.vPlatformList.lastElement());\r
             iTree.addNode(dmtnPlatformDescription, node);\r
             //this.openPlatform(c.getFid().getPath());\r
         }\r
@@ -3326,18 +3277,22 @@ public class FrameworkWizardUI extends IFrame implements MouseListener, TreeSele
             //\r
             // Enable close/close all if some files are opened\r
             //\r
-            jMenuItemFileClose.setEnabled(openingModuleList.isOpend() || openingPackageList.isOpend()\r
-                                          || openingPlatformList.isOpend());\r
-            jMenuItemFileCloseAll.setEnabled(openingModuleList.isOpend() || openingPackageList.isOpend()\r
-                                             || openingPlatformList.isOpend());\r
+            jMenuItemFileClose.setEnabled(GlobalData.openingModuleList.isOpen()\r
+                                          || GlobalData.openingPackageList.isOpen()\r
+                                          || GlobalData.openingPlatformList.isOpen());\r
+            jMenuItemFileCloseAll.setEnabled(GlobalData.openingModuleList.isOpen()\r
+                                             || GlobalData.openingPackageList.isOpen()\r
+                                             || GlobalData.openingPlatformList.isOpen());\r
 \r
             //\r
             // Enable save/save all if some files are changed\r
             //\r
-            jMenuItemFileSave.setEnabled(!openingModuleList.isSaved() || !openingPackageList.isSaved()\r
-                                         || !openingPlatformList.isSaved());\r
-            jMenuItemFileSaveAll.setEnabled(!openingModuleList.isSaved() || !openingPackageList.isSaved()\r
-                                            || !openingPlatformList.isSaved());\r
+            jMenuItemFileSave.setEnabled(!GlobalData.openingModuleList.isSaved()\r
+                                         || !GlobalData.openingPackageList.isSaved()\r
+                                         || !GlobalData.openingPlatformList.isSaved());\r
+            jMenuItemFileSaveAll.setEnabled(!GlobalData.openingModuleList.isSaved()\r
+                                            || !GlobalData.openingPackageList.isSaved()\r
+                                            || !GlobalData.openingPlatformList.isSaved());\r
         }\r
 \r
         if (arg0.getSource() == jMenuTools) {\r