summaryrefslogtreecommitdiff
path: root/Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find
diff options
context:
space:
mode:
authorhche10x <hche10x@6f19259b-4bc3-4df7-8a09-765794883524>2006-10-31 03:04:31 +0000
committerhche10x <hche10x@6f19259b-4bc3-4df7-8a09-765794883524>2006-10-31 03:04:31 +0000
commit8b44bd1d51d17c20f2fcfc70409d406d414f62dd (patch)
treedcb97d29123c88942022a8e4affa3192b996db29 /Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find
parent71f30e5184872f6c5b43dfc8738ed7a0ed1e23bd (diff)
downloadedk2-platforms-8b44bd1d51d17c20f2fcfc70409d406d414f62dd.tar.xz
1. Fix EDKT447 Keep PPI/Protocol/GUID/PCD in find result even if they are only declared but not used
2. Fix EDKT448 Provide reload solution in Find Result git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@1870 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find')
-rw-r--r--Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/Find.java204
-rw-r--r--Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/FindResult.java49
2 files changed, 229 insertions, 24 deletions
diff --git a/Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/Find.java b/Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/Find.java
index c735b5e6b4..de67728dfc 100644
--- a/Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/Find.java
+++ b/Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/Find.java
@@ -16,11 +16,14 @@ package org.tianocore.frameworkwizard.common.find;
import java.util.Vector;
+import org.tianocore.GuidDeclarationsDocument.GuidDeclarations;
import org.tianocore.LibraryClassDeclarationsDocument.LibraryClassDeclarations.LibraryClass;
import org.tianocore.LibraryClassDefinitionsDocument.LibraryClassDefinitions;
import org.tianocore.ModuleSurfaceAreaDocument.ModuleSurfaceArea;
import org.tianocore.PackageSurfaceAreaDocument.PackageSurfaceArea;
import org.tianocore.PcdDeclarationsDocument.PcdDeclarations.PcdEntry;
+import org.tianocore.PpiDeclarationsDocument.PpiDeclarations;
+import org.tianocore.ProtocolDeclarationsDocument.ProtocolDeclarations;
import org.tianocore.frameworkwizard.common.DataType;
import org.tianocore.frameworkwizard.common.GlobalData;
import org.tianocore.frameworkwizard.common.Sort;
@@ -160,6 +163,39 @@ public class Find {
}
}
}
+ //
+ // Go through all defined ppi to find which is not added yet.
+ //
+ for (int indexOfPackage = 0; indexOfPackage < GlobalData.openingPackageList.size(); indexOfPackage++) {
+ PackageSurfaceArea spd = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage).getXmlSpd();
+ PackageIdentification packageId = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage)
+ .getId();
+ if (spd.getPpiDeclarations() != null) {
+ for (int indexOfPpis = 0; indexOfPpis < spd.getPpiDeclarations().getEntryList().size(); indexOfPpis++) {
+ boolean isFound = false;
+ PpiDeclarations.Entry e = spd.getPpiDeclarations().getEntryList().get(indexOfPpis);
+ for (int indexOfPv = 0; indexOfPv < pv.size(); indexOfPv++) {
+ if (e.getCName().equals(pv.getPpis(indexOfPv).getName())) {
+ isFound = true;
+ break;
+ }
+ }
+ if (!isFound) {
+ String arg0 = e.getCName();
+ String arg1 = "";
+ String arg2 = "";
+ String arg3 = "";
+ Vector<String> arg4 = Tools.convertListToVector(e.getSupArchList());
+ String arg5 = e.getHelpText();
+
+ pid = new PpisIdentification(arg0, arg1, arg2, arg3, arg4, arg5);
+ pid.setBelongModule(null);
+ pid.setDeclaredBy(packageId);
+ pv.addPpis(pid);
+ }
+ }
+ }
+ }
Sort.sortPpis(pv, DataType.SORT_TYPE_ASCENDING);
return pv;
}
@@ -197,7 +233,10 @@ public class Find {
//
// Get the sting "PackageName.ModuleName"
//
- String tmp = pvId.getBelongModule().getPackageId().getName() + SEPERATOR + pvId.getBelongModule().getName();
+ String tmp = "";
+ if (pvId.getBelongModule() != null) {
+ tmp = pvId.getBelongModule().getPackageId().getName() + SEPERATOR + pvId.getBelongModule().getName();
+ }
//
// Check if the item has been added in
@@ -353,6 +392,39 @@ public class Find {
}
}
}
+ //
+ // Go through all defined protocols to find which is not added yet.
+ //
+ for (int indexOfPackage = 0; indexOfPackage < GlobalData.openingPackageList.size(); indexOfPackage++) {
+ PackageSurfaceArea spd = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage).getXmlSpd();
+ PackageIdentification packageId = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage)
+ .getId();
+ if (spd.getProtocolDeclarations() != null) {
+ for (int indexOfProtocols = 0; indexOfProtocols < spd.getProtocolDeclarations().getEntryList().size(); indexOfProtocols++) {
+ boolean isFound = false;
+ ProtocolDeclarations.Entry e = spd.getProtocolDeclarations().getEntryList().get(indexOfProtocols);
+ for (int indexOfPv = 0; indexOfPv < pv.size(); indexOfPv++) {
+ if (e.getCName().equals(pv.getProtocols(indexOfPv).getName())) {
+ isFound = true;
+ break;
+ }
+ }
+ if (!isFound) {
+ String arg0 = e.getCName();
+ String arg1 = "";
+ String arg2 = "";
+ String arg3 = "";
+ Vector<String> arg4 = Tools.convertListToVector(e.getSupArchList());
+ String arg5 = e.getHelpText();
+
+ pid = new ProtocolsIdentification(arg0, arg1, arg2, arg3, arg4, arg5);
+ pid.setBelongModule(null);
+ pid.setDeclaredBy(packageId);
+ pv.addProtocols(pid);
+ }
+ }
+ }
+ }
Sort.sortProtocols(pv, DataType.SORT_TYPE_ASCENDING);
return pv;
}
@@ -390,7 +462,10 @@ public class Find {
//
// Get the sting "PackageName.ModuleName"
//
- String tmp = pvId.getBelongModule().getPackageId().getName() + SEPERATOR + pvId.getBelongModule().getName();
+ String tmp = "";
+ if (pvId.getBelongModule() != null) {
+ tmp = pvId.getBelongModule().getPackageId().getName() + SEPERATOR + pvId.getBelongModule().getName();
+ }
//
// Check if the item has been added in
@@ -500,6 +575,38 @@ public class Find {
}
}
}
+ //
+ // Go through all defined guids to find which is not added yet.
+ //
+ for (int indexOfPackage = 0; indexOfPackage < GlobalData.openingPackageList.size(); indexOfPackage++) {
+ PackageSurfaceArea spd = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage).getXmlSpd();
+ PackageIdentification packageId = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage)
+ .getId();
+ if (spd.getGuidDeclarations() != null) {
+ for (int indexOfGuids = 0; indexOfGuids < spd.getGuidDeclarations().getEntryList().size(); indexOfGuids++) {
+ boolean isFound = false;
+ GuidDeclarations.Entry e = spd.getGuidDeclarations().getEntryList().get(indexOfGuids);
+ for (int indexOfGv = 0; indexOfGv < gv.size(); indexOfGv++) {
+ if (e.getCName().equals(gv.getGuids(indexOfGv).getName())) {
+ isFound = true;
+ break;
+ }
+ }
+ if (!isFound) {
+ String arg0 = e.getCName();
+ String arg1 = "";
+ String arg2 = "";
+ Vector<String> arg3 = Tools.convertListToVector(e.getSupArchList());
+ String arg4 = e.getHelpText();
+
+ gid = new GuidsIdentification(arg0, arg1, arg2, arg3, arg4);
+ gid.setBelongModule(null);
+ gid.setDeclaredBy(packageId);
+ gv.addGuids(gid);
+ }
+ }
+ }
+ }
Sort.sortGuids(gv, DataType.SORT_TYPE_ASCENDING);
return gv;
}
@@ -537,7 +644,10 @@ public class Find {
//
// Get the sting "PackageName.ModuleName"
//
- String tmp = gvId.getBelongModule().getPackageId().getName() + SEPERATOR + gvId.getBelongModule().getName();
+ String tmp = "";
+ if (gvId.getBelongModule() != null) {
+ tmp = gvId.getBelongModule().getPackageId().getName() + SEPERATOR + gvId.getBelongModule().getName();
+ }
//
// Check if the item has been added in
@@ -656,32 +766,51 @@ public class Find {
}
}
}
+ //
+ // Go through all defined pcds to find which is not added yet.
+ //
+ for (int indexOfPackage = 0; indexOfPackage < GlobalData.openingPackageList.size(); indexOfPackage++) {
+ PackageSurfaceArea spd = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage).getXmlSpd();
+ PackageIdentification packageId = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage)
+ .getId();
+ if (spd.getPcdDeclarations() != null) {
+ for (int indexOfPcds = 0; indexOfPcds < spd.getPcdDeclarations().getPcdEntryList().size(); indexOfPcds++) {
+ boolean isFound = false;
+ PcdEntry e = spd.getPcdDeclarations().getPcdEntryList().get(indexOfPcds);
+ for (int indexOfPv = 0; indexOfPv < pv.size(); indexOfPv++) {
+ if (e.getCName().equals(pv.getPcdCoded(indexOfPv).getName())) {
+ isFound = true;
+ break;
+ }
+ }
+ if (!isFound) {
+ pid = new PcdCodedIdentification("", "", "", null, "", "", null, null);
+ pid.setName(e.getCName());
+ pid.setTokenSpaceGuidCName(e.getTokenSpaceGuidCName());
+ pid.setToken(e.getToken().toString());
+ pid.setDatumType(e.getDatumType().toString());
+ pid.setValue(e.getDefaultValue());
+ pid.setUsage(Tools.convertListToString(e.getValidUsage()));
+ pid.setHelp(e.getHelpText());
+ pid.setDeclaredBy(packageId);
+
+ pid.setBelongModule(null);
+ pv.addPcdCoded(pid);
+ }
+ }
+ }
+ }
Sort.sortPcdCodeds(pv, DataType.SORT_TYPE_ASCENDING);
return pv;
}
/**
- Re-org all guid entries for find table
+ @param pv
@return
**/
-/**
-
- @return
-
-**/
-/**
-
- @return
-
-**/
-/**
-
- @return
-
-**/
-public static Vector<PcdFindResultId> getAllPcdCodedForFind(PcdCodedVector pv) {
+ public static Vector<PcdFindResultId> getAllPcdCodedForFind(PcdCodedVector pv) {
Vector<PcdFindResultId> pcd = new Vector<PcdFindResultId>();
boolean isAdded = false;
boolean isProduced = false;
@@ -734,13 +863,14 @@ public static Vector<PcdFindResultId> getAllPcdCodedForFind(PcdCodedVector pv) {
pcdId.setDatumType(pvId.getDatumType());
pcdId.setValue(pvId.getValue());
pcdId.setUsage(pvId.getUsage());
-
+
pcd.addElement(pcdId);
}
}
return pcd;
}
+
/**
Get all library class entries from workspace
@@ -821,6 +951,38 @@ public static Vector<PcdFindResultId> getAllPcdCodedForFind(PcdCodedVector pv) {
}
}
}
+ //
+ // Go through all defined pcds to find which is not added yet.
+ //
+ for (int indexOfPackage = 0; indexOfPackage < GlobalData.openingPackageList.size(); indexOfPackage++) {
+ PackageSurfaceArea spd = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage).getXmlSpd();
+ PackageIdentification packageId = GlobalData.openingPackageList.getOpeningPackageByIndex(indexOfPackage)
+ .getId();
+ if (spd.getLibraryClassDeclarations() != null) {
+ for (int indexOfLibraryClass = 0; indexOfLibraryClass < spd.getLibraryClassDeclarations()
+ .getLibraryClassList().size(); indexOfLibraryClass++) {
+ boolean isFound = false;
+ LibraryClass lc = spd.getLibraryClassDeclarations().getLibraryClassList().get(indexOfLibraryClass);
+ for (int indexOfLcv = 0; indexOfLcv < lcv.size(); indexOfLcv++) {
+ if (lc.getName().equals(lcv.getLibraryClass(indexOfLcv).getLibraryClassName())) {
+ isFound = true;
+ break;
+ }
+ }
+ if (!isFound) {
+ lcid = new LibraryClassIdentification("", null, "", "", null, "", null, "");
+ lcid.setLibraryClassName(lc.getName());
+ lcid.setSupArchList(Tools.convertListToVector(lc.getSupArchList()));
+ lcid.setSupModuleList(Tools.convertListToVector(lc.getSupModuleList()));
+ lcid.setHelp(lc.getHelpText());
+ lcid.setDeclaredBy(packageId);
+
+ lcid.setBelongModule(null);
+ lcv.addLibraryClass(lcid);
+ }
+ }
+ }
+ }
Sort.sortLibraryClass(lcv, DataType.SORT_TYPE_ASCENDING);
return lcv;
}
diff --git a/Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/FindResult.java b/Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/FindResult.java
index c0991025ac..de6526b10c 100644
--- a/Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/FindResult.java
+++ b/Tools/Java/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/common/find/FindResult.java
@@ -91,6 +91,10 @@ public class FindResult extends IFrame implements TableModelListener, ListSelect
private Vector<PcdFindResultId> vPcdFindResult = null;
+ private JButton jButtonReload = null;
+
+ private JPanel jPanelOperation = null;
+
/**
* This is the default constructor
*/
@@ -130,7 +134,7 @@ public class FindResult extends IFrame implements TableModelListener, ListSelect
jContentPane = new JPanel();
jContentPane.setLayout(null);
jContentPane.add(getJScrollPaneTable(), null);
- jContentPane.add(getJButtonClose(), null);
+ jContentPane.add(getJPanelOperation(), null);
jContentPane.setPreferredSize(new java.awt.Dimension(585, 445));
}
return jContentPane;
@@ -213,8 +217,8 @@ public class FindResult extends IFrame implements TableModelListener, ListSelect
jButtonClose = new JButton();
jButtonClose.setText("Close");
jButtonClose.addActionListener(this);
- jButtonClose.setBounds(new java.awt.Rectangle(255, 415, 80, 20));
jButtonClose.setPreferredSize(new java.awt.Dimension(80, 20));
+ jButtonClose.setBounds(new java.awt.Rectangle(90, 0, 80, 20));
}
return jButtonClose;
}
@@ -281,6 +285,8 @@ public class FindResult extends IFrame implements TableModelListener, ListSelect
**/
private void showTable() {
clearAll();
+ this.jTable.repaint();
+ this.jTable.updateUI();
if (this.method.equals("PPI")) {
Vector<PpiId> vPpi = Find.getAllPpisForFind();
@@ -507,6 +513,10 @@ public class FindResult extends IFrame implements TableModelListener, ListSelect
if (arg0.getSource() == this.jButtonClose) {
this.dispose();
}
+
+ if (arg0.getSource() == this.jButtonReload) {
+ this.showTable();
+ }
}
/* (non-Javadoc)
@@ -522,7 +532,7 @@ public class FindResult extends IFrame implements TableModelListener, ListSelect
Tools.resizeComponent(this.jScrollPaneTable, intCurrentWidth, intCurrentHeight, intPreferredWidth,
intPreferredHeight);
- Tools.centerComponent(this.jButtonClose, intCurrentWidth, intCurrentHeight, intPreferredHeight,
+ Tools.centerComponent(this.jPanelOperation, intCurrentWidth, intCurrentHeight, intPreferredHeight,
DataType.SPACE_TO_BOTTOM_FOR_CLOSE_BUTTON);
Tools.resizeTableColumn(this.jTable, this.getSize().width - 28);
}
@@ -605,4 +615,37 @@ public class FindResult extends IFrame implements TableModelListener, ListSelect
// TODO Auto-generated method stub
}
+
+ /**
+ * This method initializes jButtonReload
+ *
+ * @return javax.swing.JButton
+ */
+ private JButton getJButtonReload() {
+ if (jButtonReload == null) {
+ jButtonReload = new JButton();
+ jButtonReload.setText("Reload");
+ jButtonReload.addActionListener(this);
+ jButtonReload.setBounds(new java.awt.Rectangle(0, 0, 80, 20));
+ jButtonReload.setPreferredSize(new java.awt.Dimension(80, 20));
+ }
+ return jButtonReload;
+ }
+
+ /**
+ * This method initializes jPanelOperation
+ *
+ * @return javax.swing.JPanel
+ */
+ private JPanel getJPanelOperation() {
+ if (jPanelOperation == null) {
+ jPanelOperation = new JPanel();
+ jPanelOperation.setLayout(null);
+ jPanelOperation.setBounds(new java.awt.Rectangle(300, 415, 170, 20));
+ jPanelOperation.setPreferredSize(new java.awt.Dimension(170, 20));
+ jPanelOperation.add(getJButtonClose(), null);
+ jPanelOperation.add(getJButtonReload(), null);
+ }
+ return jPanelOperation;
+ }
}