import uuid\r
\r
import Common.EdkLogger as EdkLogger\r
+from Common.BuildToolError import FORMAT_INVALID\r
\r
from MetaDataTable import Table, TableFile\r
from MetaDataTable import ConvertToSqlString\r
return self.Exec(SqlCommand)\r
\r
def GetValidExpression(self, TokenSpaceGuid, PcdCName):\r
- SqlCommand = "select Value1 from %s WHERE Value2='%s' and Value3='%s'" % (self.Table, TokenSpaceGuid, PcdCName)\r
+ SqlCommand = "select Value1,StartLine from %s WHERE Value2='%s' and Value3='%s'" % (self.Table, TokenSpaceGuid, PcdCName)\r
self.Cur.execute(SqlCommand)\r
validateranges = []\r
validlists = []\r
expressions = []\r
- for row in self.Cur:\r
- comment = row[0]\r
- comment = comment.strip("#")\r
- comment = comment.strip()\r
- if comment.startswith("@ValidRange"):\r
- comment = comment.replace("@ValidRange", "", 1)\r
- validateranges.append(comment.split("|")[1].strip())\r
- if comment.startswith("@ValidList"):\r
- comment = comment.replace("@ValidList", "", 1)\r
- validlists.append(comment.split("|")[1].strip())\r
- if comment.startswith("@Expression"):\r
- comment = comment.replace("@Expression", "", 1)\r
- expressions.append(comment.split("|")[1].strip())\r
+ try:\r
+ for row in self.Cur:\r
+ comment = row[0]\r
+ \r
+ LineNum = row[1]\r
+ comment = comment.strip("#")\r
+ comment = comment.strip()\r
+ oricomment = comment\r
+ if comment.startswith("@ValidRange"):\r
+ comment = comment.replace("@ValidRange", "", 1)\r
+ validateranges.append(comment.split("|")[1].strip())\r
+ if comment.startswith("@ValidList"):\r
+ comment = comment.replace("@ValidList", "", 1)\r
+ validlists.append(comment.split("|")[1].strip())\r
+ if comment.startswith("@Expression"):\r
+ comment = comment.replace("@Expression", "", 1)\r
+ expressions.append(comment.split("|")[1].strip())\r
+ except Exception, Exc:\r
+ ValidType = ""\r
+ if oricomment.startswith("@ValidRange"):\r
+ ValidType = "@ValidRange"\r
+ if oricomment.startswith("@ValidList"):\r
+ ValidType = "@ValidList"\r
+ if oricomment.startswith("@Expression"):\r
+ ValidType = "@Expression"\r
+ EdkLogger.error('Parser', FORMAT_INVALID, "The syntax for %s of PCD %s.%s is incorrect" % (ValidType,TokenSpaceGuid, PcdCName),\r
+ ExtraData=oricomment,File=self.MetaFile, Line=LineNum)\r
+ return set(), set(), set()\r
return set(validateranges), set(validlists), set(expressions)\r
## Python class representation of table storing platform data\r
class PlatformTable(MetaFileTable):\r