]> git.proxmox.com Git - mirror_edk2.git/blame - BaseTools/Source/Python/Common/TargetTxtClassObject.py
BaseTools: Replace StandardError with Expression
[mirror_edk2.git] / BaseTools / Source / Python / Common / TargetTxtClassObject.py
CommitLineData
30fdf114
LG
1## @file\r
2# This file is used to define each component of Target.txt file\r
3#\r
1be2ed90 4# Copyright (c) 2007 - 2014, Intel Corporation. All rights reserved.<BR>\r
40d841f6 5# This program and the accompanying materials\r
30fdf114
LG
6# are licensed and made available under the terms and conditions of the BSD License\r
7# which accompanies this distribution. The full text of the license may be found at\r
8# http://opensource.org/licenses/bsd-license.php\r
9#\r
10# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12#\r
13\r
14##\r
15# Import Modules\r
16#\r
72443dd2 17from __future__ import print_function\r
1be2ed90 18import Common.LongFilePathOs as os\r
30fdf114
LG
19import EdkLogger\r
20import DataType\r
21from BuildToolError import *\r
22import GlobalData\r
1be2ed90 23from Common.LongFilePathSupport import OpenLongFilePath as open\r
30fdf114 24\r
97fa0ee9 25gDefaultTargetTxtFile = "target.txt"\r
30fdf114
LG
26\r
27## TargetTxtClassObject\r
28#\r
29# This class defined content used in file target.txt\r
30#\r
31# @param object: Inherited from object class\r
32# @param Filename: Input value for full path of target.txt\r
33#\r
34# @var TargetTxtDictionary: To store keys and values defined in target.txt\r
35#\r
36class TargetTxtClassObject(object):\r
37 def __init__(self, Filename = None):\r
38 self.TargetTxtDictionary = {\r
39 DataType.TAB_TAT_DEFINES_ACTIVE_PLATFORM : '',\r
40 DataType.TAB_TAT_DEFINES_ACTIVE_MODULE : '',\r
41 DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF : '',\r
30fdf114
LG
42 DataType.TAB_TAT_DEFINES_MAX_CONCURRENT_THREAD_NUMBER : '',\r
43 DataType.TAB_TAT_DEFINES_TARGET : [],\r
44 DataType.TAB_TAT_DEFINES_TOOL_CHAIN_TAG : [],\r
45 DataType.TAB_TAT_DEFINES_TARGET_ARCH : [],\r
46 DataType.TAB_TAT_DEFINES_BUILD_RULE_CONF : '',\r
47 }\r
97fa0ee9 48 self.ConfDirectoryPath = ""\r
4231a819 49 if Filename is not None:\r
30fdf114
LG
50 self.LoadTargetTxtFile(Filename)\r
51\r
52 ## LoadTargetTxtFile\r
53 #\r
54 # Load target.txt file and parse it, return a set structure to store keys and values\r
55 #\r
56 # @param Filename: Input value for full path of target.txt\r
57 #\r
58 # @retval set() A set structure to store keys and values\r
59 # @retval 1 Error happenes in parsing\r
60 #\r
61 def LoadTargetTxtFile(self, Filename):\r
62 if os.path.exists(Filename) and os.path.isfile(Filename):\r
63 return self.ConvertTextFileToDict(Filename, '#', '=')\r
64 else:\r
65 EdkLogger.error("Target.txt Parser", FILE_NOT_FOUND, ExtraData=Filename)\r
66 return 1\r
67\r
68 ## ConvertTextFileToDict\r
69 #\r
70 # Convert a text file to a dictionary of (name:value) pairs.\r
71 # The data is saved to self.TargetTxtDictionary\r
72 #\r
73 # @param FileName: Text filename\r
74 # @param CommentCharacter: Comment char, be used to ignore comment content\r
75 # @param KeySplitCharacter: Key split char, between key name and key value. Key1 = Value1, '=' is the key split char\r
76 #\r
77 # @retval 0 Convert successfully\r
78 # @retval 1 Open file failed\r
79 #\r
80 def ConvertTextFileToDict(self, FileName, CommentCharacter, KeySplitCharacter):\r
81 F = None\r
82 try:\r
97fa0ee9
YL
83 F = open(FileName, 'r')\r
84 self.ConfDirectoryPath = os.path.dirname(FileName)\r
30fdf114
LG
85 except:\r
86 EdkLogger.error("build", FILE_OPEN_FAILURE, ExtraData=FileName)\r
4231a819 87 if F is not None:\r
30fdf114
LG
88 F.close()\r
89\r
90 for Line in F:\r
91 Line = Line.strip()\r
92 if Line.startswith(CommentCharacter) or Line == '':\r
93 continue\r
94\r
95 LineList = Line.split(KeySplitCharacter, 1)\r
96 Key = LineList[0].strip()\r
97 if len(LineList) == 2:\r
98 Value = LineList[1].strip()\r
99 else:\r
100 Value = ""\r
101\r
102 if Key in [DataType.TAB_TAT_DEFINES_ACTIVE_PLATFORM, DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF, \\r
103 DataType.TAB_TAT_DEFINES_ACTIVE_MODULE, DataType.TAB_TAT_DEFINES_BUILD_RULE_CONF]:\r
104 self.TargetTxtDictionary[Key] = Value.replace('\\', '/')\r
97fa0ee9
YL
105 if Key == DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF and self.TargetTxtDictionary[Key]:\r
106 if self.TargetTxtDictionary[Key].startswith("Conf/"):\r
107 Tools_Def = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].strip())\r
108 if not os.path.exists(Tools_Def) or not os.path.isfile(Tools_Def):\r
109 # If Conf/Conf does not exist, try just the Conf/ directory\r
110 Tools_Def = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].replace("Conf/", "", 1).strip())\r
111 else:\r
112 # The File pointed to by TOOL_CHAIN_CONF is not in a Conf/ directory\r
113 Tools_Def = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].strip())\r
114 self.TargetTxtDictionary[Key] = Tools_Def\r
115 if Key == DataType.TAB_TAT_DEFINES_BUILD_RULE_CONF and self.TargetTxtDictionary[Key]:\r
116 if self.TargetTxtDictionary[Key].startswith("Conf/"):\r
117 Build_Rule = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].strip())\r
118 if not os.path.exists(Build_Rule) or not os.path.isfile(Build_Rule):\r
119 # If Conf/Conf does not exist, try just the Conf/ directory\r
120 Build_Rule = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].replace("Conf/", "", 1).strip())\r
121 else:\r
122 # The File pointed to by BUILD_RULE_CONF is not in a Conf/ directory\r
123 Build_Rule = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].strip())\r
124 self.TargetTxtDictionary[Key] = Build_Rule\r
30fdf114
LG
125 elif Key in [DataType.TAB_TAT_DEFINES_TARGET, DataType.TAB_TAT_DEFINES_TARGET_ARCH, \\r
126 DataType.TAB_TAT_DEFINES_TOOL_CHAIN_TAG]:\r
127 self.TargetTxtDictionary[Key] = Value.split()\r
30fdf114
LG
128 elif Key == DataType.TAB_TAT_DEFINES_MAX_CONCURRENT_THREAD_NUMBER:\r
129 try:\r
130 V = int(Value, 0)\r
131 except:\r
132 EdkLogger.error("build", FORMAT_INVALID, "Invalid number of [%s]: %s." % (Key, Value),\r
133 File=FileName)\r
134 self.TargetTxtDictionary[Key] = Value\r
135 #elif Key not in GlobalData.gGlobalDefines:\r
136 # GlobalData.gGlobalDefines[Key] = Value\r
137\r
138 F.close()\r
139 return 0\r
140\r
30fdf114
LG
141## TargetTxtDict\r
142#\r
97fa0ee9 143# Load target.txt in input Conf dir\r
30fdf114 144#\r
97fa0ee9 145# @param ConfDir: Conf dir\r
30fdf114
LG
146#\r
147# @retval Target An instance of TargetTxtClassObject() with loaded target.txt\r
148#\r
97fa0ee9 149def TargetTxtDict(ConfDir):\r
30fdf114 150 Target = TargetTxtClassObject()\r
97fa0ee9 151 Target.LoadTargetTxtFile(os.path.normpath(os.path.join(ConfDir, gDefaultTargetTxtFile)))\r
30fdf114
LG
152 return Target\r
153\r
154##\r
155#\r
156# This acts like the main() function for the script, unless it is 'import'ed into another\r
157# script.\r
158#\r
159if __name__ == '__main__':\r
160 pass\r
161 Target = TargetTxtDict(os.getenv("WORKSPACE"))\r
72443dd2
GL
162 print(Target.TargetTxtDictionary[DataType.TAB_TAT_DEFINES_MAX_CONCURRENT_THREAD_NUMBER])\r
163 print(Target.TargetTxtDictionary[DataType.TAB_TAT_DEFINES_TARGET])\r
164 print(Target.TargetTxtDictionary)\r