summaryrefslogtreecommitdiff
path: root/Tools
diff options
context:
space:
mode:
authorjlin16 <jlin16@6f19259b-4bc3-4df7-8a09-765794883524>2006-09-05 10:31:51 +0000
committerjlin16 <jlin16@6f19259b-4bc3-4df7-8a09-765794883524>2006-09-05 10:31:51 +0000
commit701d95b339340ec89c71ae980a2b72e1e4d9680e (patch)
tree283df466ebec167e6c0d1e8e6db619a4baa39a01 /Tools
parenteff5170cce433b0cb6a77691237af414b6ce3818 (diff)
downloadedk2-platforms-701d95b339340ec89c71ae980a2b72e1e4d9680e.tar.xz
a. Sync FV info with FDF file contents when editing FV information.
b. display module GUID in FrameworkModules if that module no longer exists in workspace. c. modify SourceFiles to reflect changes in Wizard Package/Platform part. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@1466 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'Tools')
-rw-r--r--Tools/Source/FrameworkWizard/FrameworkWizard.msa11
-rw-r--r--Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFileContents.java12
-rw-r--r--Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFlash.java116
-rw-r--r--Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFrameworkModules.java7
4 files changed, 115 insertions, 31 deletions
diff --git a/Tools/Source/FrameworkWizard/FrameworkWizard.msa b/Tools/Source/FrameworkWizard/FrameworkWizard.msa
index 262e30aa38..b8166c5f36 100644
--- a/Tools/Source/FrameworkWizard/FrameworkWizard.msa
+++ b/Tools/Source/FrameworkWizard/FrameworkWizard.msa
@@ -205,15 +205,12 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
<Filename>src/org/tianocore/frameworkwizard/platform/ui/FpdModuleSA.java</Filename>
<Filename>src/org/tianocore/frameworkwizard/platform/ui/FpdPlatformDefs.java</Filename>
<Filename>src/org/tianocore/frameworkwizard/platform/ui/GenListDialog.java</Filename>
+ <Filename>src/org/tianocore/frameworkwizard/platform/ui/GenLongTextDialog.java</Filename>
<Filename>src/org/tianocore/frameworkwizard/platform/ui/ListEditor.java</Filename>
- <Filename>src/org/tianocore/frameworkwizard/platform/ui/global/GlobalData.java</Filename>
- <Filename>src/org/tianocore/frameworkwizard/platform/ui/global/Spd.java</Filename>
+ <Filename>src/org/tianocore/frameworkwizard/platform/ui/LongTextEditor.java</Filename>
+ <Filename>src/org/tianocore/frameworkwizard/platform/ui/TableSorter.java</Filename>
<Filename>src/org/tianocore/frameworkwizard/platform/ui/global/SurfaceAreaQuery.java</Filename>
- <Filename>src/org/tianocore/frameworkwizard/platform/ui/id/FpdModuleIdentification.java</Filename>
- <Filename>src/org/tianocore/frameworkwizard/platform/ui/id/Identification.java</Filename>
- <Filename>src/org/tianocore/frameworkwizard/platform/ui/id/ModuleIdentification.java</Filename>
- <Filename>src/org/tianocore/frameworkwizard/platform/ui/id/PackageIdentification.java</Filename>
- <Filename>src/org/tianocore/frameworkwizard/platform/ui/id/PlatformIdentification.java</Filename>
+ <Filename>src/org/tianocore/frameworkwizard/platform/ui/global/WorkspaceProfile.java</Filename>
<Filename>src/org/tianocore/frameworkwizard/workspace/Workspace.java</Filename>
<Filename>src/org/tianocore/frameworkwizard/workspace/WorkspaceTools.java</Filename>
<Filename>src/org/tianocore/frameworkwizard/workspace/ui/SwitchWorkspace.java</Filename>
diff --git a/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFileContents.java b/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFileContents.java
index 9e2f955599..20b5c10568 100644
--- a/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFileContents.java
+++ b/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFileContents.java
@@ -2698,6 +2698,9 @@ public class FpdFileContents {
while (li.hasNext()) {
FvImagesDocument.FvImages.FvImage fi = li.next();
updateFvImageNamesInFvImage (fi, oldFvName, newFvName);
+ if (fi.getFvImageNamesList().size() == 0) {
+ li.remove();
+ }
}
}
@@ -2712,18 +2715,13 @@ public class FpdFileContents {
if (cursor.toChild(qFvImageNames)) {
do {
- if (cursor.getTextValue().equals(oldFvName)){
+ String xmlValue = cursor.getTextValue();
+ if (xmlValue.equals(oldFvName)){
if (newFvName != null) {
cursor.setTextValue(newFvName);
}
else {
- if (fi.getFvImageNamesList().size() == 1) {
- removeElement(fi);
- break;
- }
- else {
cursor.removeXml();
- }
}
}
}while (cursor.toNextSibling(qFvImageNames));
diff --git a/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFlash.java b/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFlash.java
index e40caf9445..74999ef5ec 100644
--- a/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFlash.java
+++ b/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFlash.java
@@ -16,7 +16,6 @@ import java.awt.BorderLayout;
import javax.swing.JPanel;
import javax.swing.AbstractAction;
-import javax.swing.DefaultCellEditor;
import javax.swing.JFileChooser;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
@@ -64,7 +63,6 @@ import javax.swing.event.ListSelectionListener;
import javax.swing.event.TableModelEvent;
import javax.swing.event.TableModelListener;
import javax.swing.table.DefaultTableModel;
-import javax.swing.table.TableColumn;
import javax.swing.table.TableModel;
import javax.swing.JComboBox;
import java.awt.Dimension;
@@ -161,7 +159,8 @@ public class FpdFlash extends IInternalFrame {
private int selectedRowInFvAdditionalTable = -1;
private String oldFvName = null;
private Vector<String> vBlockSize = new Vector<String>();
- private String erasePolarity = null;
+ private String determinedFvBlockSize = null;
+ private String erasePolarity = "";
boolean memModified = false;
@@ -183,6 +182,11 @@ public class FpdFlash extends IInternalFrame {
public FpdFlash(OpeningPlatformType opt) {
this(opt.getXmlFpd());
docConsole = opt;
+ if (memModified) {
+ docConsole.setSaved(false);
+ JOptionPane.showMessageDialog(frame, "Platform Synced with FDF file.");
+ memModified = false;
+ }
}
/**
@@ -1178,23 +1182,45 @@ public class FpdFlash extends IInternalFrame {
private void initFvInFdfTable(String fdfPath){
Vector<FvInfoFromFdf> vFvInfo = new Vector<FvInfoFromFdf>();
getFvInfoFromFdf(fdfPath, vFvInfo);
- getFlashInfoFromFdf (fdfPath, vBlockSize, erasePolarity);
- ffc.setTypedFvImageNameValue("Attributes", "ErasePolarity", erasePolarity);
+ getFlashInfoFromFdf (fdfPath);
+ if (!erasePolarity.equals("1") && !erasePolarity.equals("0")) {
+ JOptionPane.showMessageDialog(frame, "FDF file does NOT contain valid Erase Polarity.");
+ }
+ else {
+ ffc.setTypedFvImageNameValue("Attributes", "ErasePolarity", erasePolarity);
+ }
+
// BugBug: assume all blocks have same size;
- String blkSize = vBlockSize.get(0);
+
+ String blkSize = "0x10000";
+ if (vBlockSize.size() > 0) {
+ blkSize = vBlockSize.get(0);
+ if (!DataValidation.isInt(blkSize) && !DataValidation.isHexDoubleWordDataType(blkSize)) {
+ JOptionPane.showMessageDialog(frame, "FDF file does NOT contain valid FV block size. Default size 0x10000 will be used.");
+ blkSize = "0x10000";
+ }
+ }
+ determinedFvBlockSize = blkSize;
getFvInFdfTableModel().setRowCount(0);
for (int j = 0; j < vFvInfo.size(); ++j) {
FvInfoFromFdf fvInfo = vFvInfo.get(j);
String[] row = {fvInfo.getFvName(), fvInfo.getSize(), fvInfo.getEfiFileName()};
+ // if FV addtional table contains the same FV from fdf file, remove that row.
+ for (int k = 0; k < jTableFvAdditional.getRowCount(); ++k) {
+ if (fvAdditionalTableModel.getValueAt(k, 0).equals(row[0])) {
+ fvAdditionalTableModel.removeRow(k);
+ }
+ }
getFvInFdfTableModel().addRow(row);
try {
int blockSize = Integer.decode(blkSize);
int fvSize = Integer.decode(row[1]);
int numBlocks = fvSize/blockSize;
+ HashMap<String, String> mOptions = new HashMap<String, String>();
// if no options for this FV before, generate a new options entry for this FV.
if (ffc.getFvImagesFvImageWithName(row[0], "Options") == null) {
- HashMap<String, String> mOptions = new HashMap<String, String>();
+
mOptions.put("EFI_BLOCK_SIZE", blkSize);
mOptions.put("EFI_NUM_BLOCKS", numBlocks+"");
mOptions.put("EFI_FILE_NAME", row[2]);
@@ -1202,9 +1228,20 @@ public class FpdFlash extends IInternalFrame {
memModified = true;
}
else {
- ffc.setTypedNamedFvImageNameValue(row[0], "Options", "EFI_BLOCK_SIZE", blkSize);
- ffc.setTypedNamedFvImageNameValue(row[0], "Options", "EFI_NUM_BLOCKS", numBlocks + "");
- ffc.setTypedNamedFvImageNameValue(row[0], "Options", "EFI_FILE_NAME", row[2]);
+ ffc.getFvImagesFvImageOptions(row[0], mOptions);
+ if (mOptions.get("EFI_BLOCK_SIZE") == null || !mOptions.get("EFI_BLOCK_SIZE").equalsIgnoreCase(blkSize)) {
+ ffc.setTypedNamedFvImageNameValue(row[0], "Options", "EFI_BLOCK_SIZE", blkSize);
+ memModified = true;
+ }
+ if (mOptions.get("EFI_NUM_BLOCKS") == null || Integer.decode(mOptions.get("EFI_NUM_BLOCKS")) != numBlocks) {
+ ffc.setTypedNamedFvImageNameValue(row[0], "Options", "EFI_NUM_BLOCKS", numBlocks + "");
+ memModified = true;
+ }
+ if (mOptions.get("EFI_FILE_NAME") == null || !mOptions.get("EFI_FILE_NAME").equals(row[2])) {
+ ffc.setTypedNamedFvImageNameValue(row[0], "Options", "EFI_FILE_NAME", row[2]);
+ memModified = true;
+ }
+
}
}
catch (NumberFormatException e){
@@ -1683,6 +1720,7 @@ public class FpdFlash extends IInternalFrame {
int row = arg0.getFirstRow();
int col = arg0.getColumn();
TableModel m = (TableModel) arg0.getSource();
+
if (arg0.getType() == TableModelEvent.UPDATE) {
if (col == 0) {
String newFvName = m.getValueAt(row, 0) + "";
@@ -1712,10 +1750,54 @@ public class FpdFlash extends IInternalFrame {
String[] fvNames = {newFvName};
ffc.AddFvImageFvImageNames(fvNames);
}
-
+ docConsole.setSaved(false);
oldFvName = newFvName;
}
- docConsole.setSaved(false);
+
+ if (col == 1) {
+ String fvSize = m.getValueAt(row, col) + "";
+ if (!DataValidation.isInt(fvSize) && !DataValidation.isHexDoubleWordDataType(fvSize)) {
+ JOptionPane.showMessageDialog(frame, "FV size should be Integer or Hex format.");
+ return;
+ }
+ HashMap<String, String> mFvOpts = new HashMap<String, String>();
+ ffc.getFvImagesFvImageOptions(oldFvName, mFvOpts);
+ String blkSize = mFvOpts.get("EFI_BLOCK_SIZE");
+ if (blkSize == null) {
+ ffc.setTypedNamedFvImageNameValue(oldFvName, "Options", "EFI_BLOCK_SIZE", determinedFvBlockSize);
+ int fs = Integer.decode(fvSize);
+ int bs = Integer.decode(determinedFvBlockSize);
+ ffc.setTypedNamedFvImageNameValue(oldFvName, "Options", "EFI_NUM_BLOCKS", (fs/bs)+"");
+ docConsole.setSaved(false);
+ }
+ else {
+ if (!DataValidation.isInt(blkSize) && !DataValidation.isHexDoubleWordDataType(blkSize)) {
+ int retVal = JOptionPane.showConfirmDialog(frame, "Confirm", "FPD file contains error block size format. Would you like to replace it with a default value?", JOptionPane.YES_NO_OPTION);
+ if (retVal == JOptionPane.YES_OPTION) {
+ ffc.setTypedNamedFvImageNameValue(oldFvName, "Options", "EFI_BLOCK_SIZE", determinedFvBlockSize);
+ int fs = Integer.decode(fvSize);
+ int bs = Integer.decode(determinedFvBlockSize);
+ ffc.setTypedNamedFvImageNameValue(oldFvName, "Options", "EFI_NUM_BLOCKS", (fs/bs)+"");
+ docConsole.setSaved(false);
+ return;
+ }
+ else {
+ return;
+ }
+
+ }
+ int fs = Integer.decode(fvSize);
+ int bs = Integer.decode(blkSize);
+ ffc.setTypedNamedFvImageNameValue(oldFvName, "Options", "EFI_NUM_BLOCKS", (fs/bs)+"");
+ docConsole.setSaved(false);
+ }
+ }
+
+ if (col == 2) {
+ ffc.setTypedNamedFvImageNameValue(oldFvName, "Options", "EFI_FILE_NAME", m.getValueAt(row, col)+"");
+ docConsole.setSaved(false);
+ }
+
}
}
});
@@ -1879,12 +1961,12 @@ public class FpdFlash extends IInternalFrame {
jTextFieldFdf.setText("");
String fdfFile = ffc.getFlashDefinitionFile();
- if (fdfFile != null) {
+ if (fdfFile != null && fdfFile.length() > 0) {
jTextFieldFdf.setText(fdfFile);
+ String fdfPath = System.getenv("WORKSPACE") + File.separator + fdfFile;
+ initFvInFdfTable(fdfPath);
}
- String fdfPath = System.getenv("WORKSPACE") + File.separator + fdfFile;
- initFvInFdfTable(fdfPath);
initFvAdditionalTable();
}
@@ -1911,7 +1993,7 @@ public class FpdFlash extends IInternalFrame {
return jContentPane;
}
- private void getFlashInfoFromFdf (String fdfPath, Vector<String> vBlockSize, String erasePolarity) {
+ private void getFlashInfoFromFdf (String fdfPath) {
File fdf = new File(fdfPath);
if (!fdf.exists()) {
return;
@@ -1936,7 +2018,7 @@ public class FpdFlash extends IInternalFrame {
// ErasePolarity
//
if (str.startsWith("ErasePolarity")) {
- erasePolarity = str.substring(str.indexOf("=") + 1, str.lastIndexOf(","));
+ erasePolarity = str.substring(str.indexOf("=") + 1, str.lastIndexOf(",")).trim();
}
//
// dig into Block section.
diff --git a/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFrameworkModules.java b/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFrameworkModules.java
index bab107737d..b831703235 100644
--- a/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFrameworkModules.java
+++ b/Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFrameworkModules.java
@@ -717,6 +717,13 @@ public class FpdFrameworkModules extends IInternalFrame {
}
al.add(saa[i][ffcModArch]);
}
+ else {
+ row[modNameColForFpdModTable] = saa[i][ffcModGuid];
+ row[modVerColForFpdModTable] = saa[i][ffcModVer];
+ row[pkgNameColForFpdModTable] = saa[i][ffcPkgGuid];
+ row[pkgVerColForFpdModTable] = saa[i][ffcPkgVer];
+ row[archColForFpdModTable] = saa[i][ffcModArch];
+ }
row[forceDbgColForFpdModTable] = ffc.getModuleSAForceDebug(i);
modelFpdModules.addRow(row);