summaryrefslogtreecommitdiff
path: root/Tools
diff options
context:
space:
mode:
authorqwang12 <qwang12@6f19259b-4bc3-4df7-8a09-765794883524>2006-05-26 11:00:44 +0000
committerqwang12 <qwang12@6f19259b-4bc3-4df7-8a09-765794883524>2006-05-26 11:00:44 +0000
commit4acf8ce7da7a8125ec83c6ce6d4dd675314e3d59 (patch)
tree831dc418060cf566be2154ce987b890dbb680c70 /Tools
parent24dba7f3c138af82b9cc7de2e77dddef46d75741 (diff)
downloadedk2-4acf8ce7da7a8125ec83c6ce6d4dd675314e3d59.zip
edk2-4acf8ce7da7a8125ec83c6ce6d4dd675314e3d59.tar.gz
edk2-4acf8ce7da7a8125ec83c6ce6d4dd675314e3d59.tar.bz2
Add version check in both PCD database generation and service driver.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@292 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'Tools')
-rw-r--r--Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java27
1 files changed, 14 insertions, 13 deletions
diff --git a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java
index 6cc73ff..9df1800 100644
--- a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java
+++ b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java
@@ -217,7 +217,7 @@ class SizeTable {
return index;
}
-
+
private int getDatumSize(Token token) {
/*
switch (token.datumType) {
@@ -674,6 +674,15 @@ class PcdDatabase {
private ArrayList<Token> alTokens;
private String phase;
private int assignedTokenNumber;
+
+ //
+ // After Major changes done to the PCD
+ // database generation class PcdDatabase
+ // Please increment the version and please
+ // also update the version number in PCD
+ // service PEIM and DXE driver accordingly.
+ //
+ private final int version = 1;
private String hString;
private String cString;
@@ -754,10 +763,8 @@ class PcdDatabase {
public void genCode () {
final String newLine = "\r\n";
- final String instNewLine = "\\\r\n";
final String declNewLine = ";\r\n";
final String tab = "\t";
- final String commaInstNewLine = "\t,\\\r\n";
final String commaNewLine = ", \r\n";
int i;
@@ -790,7 +797,8 @@ class PcdDatabase {
// Generate Structure Declaration for PcdTokens without Default Value
// PEI_PCD_DATABASE_UNINIT
//
- java.util.Collections.sort(uninitTokens, comparator);
+ list = uninitTokens;
+ java.util.Collections.sort(list, comparator);
uninitCode = processTokens(uninitTokens);
//
@@ -851,12 +859,6 @@ class PcdDatabase {
initInstStr += tab + genInstantiationStr(exMapTable.getInstantiation()) + commaNewLine;
initInstStr += tab + genInstantiationStr(guidTable.getInstantiation()) + commaNewLine;
initInstStr += tab + genInstantiationStr(localTokenNumberTable.getInstantiation()) + commaNewLine;
- /*
- inst = stringTable.getInstantiation();
- for (i = 0; i < inst.size(); i++ ) {
- initInstStr += tab + inst.get(i) + commaNewLine;
- }
- */
initInstStr += tab + genInstantiationStr(stringTable.getInstantiation()) + commaNewLine;
initInstStr += tab + genInstantiationStr(sizeTable.getInstantiation()) + commaNewLine;
initInstStr += tab + genInstantiationStr(skuIdTable.getInstantiation()) + commaNewLine;
@@ -907,6 +909,8 @@ class PcdDatabase {
+ initDeclStr + newLine
+ uninitDeclStr + newLine
+ newLine;
+
+ hString += String.format("#define PCD_%s_SERVICE_DRIVER_VERSION %d", phase, version);
}
@@ -924,7 +928,6 @@ class PcdDatabase {
private HashMap<String, ArrayList<String>> processTokens (List<Token> alToken) {
- ArrayList[] output = new ArrayList[4];
HashMap <String, ArrayList<String>> map = new HashMap<String, ArrayList<String>>();
ArrayList<String> decl = new ArrayList<String>();
@@ -1039,8 +1042,6 @@ class PcdDatabase {
private String getDataTypeInstantiation (Token token) {
- String typeStr = "";
-
if (token.datumType == Token.DATUM_TYPE.POINTER) {
return String.format("%s /* %s */", token.datum.toString(), token.getPrimaryKeyString());
} else {