From: "Feng, Bob C" <bob.c.feng@intel.com>
To: edk2-devel@lists.01.org
Cc: Bob Feng <bob.c.feng@intel.com>, Liming Gao <liming.gao@intel.com>
Subject: [Patch 1/3] BaseTools: Implement splitquoted function in Build tool
Date: Sun, 3 Feb 2019 13:55:13 +0800 [thread overview]
Message-ID: <20190203055515.18336-2-bob.c.feng@intel.com> (raw)
In-Reply-To: <20190203055515.18336-1-bob.c.feng@intel.com>
https://bugzilla.tianocore.org/show_bug.cgi?id=1509
On some Linux environment, there may be no distutils.util
library for python3 that will cause build tool crash.
This patch implement distutils.util.split_quoted
in BaseTools so that the build tool will be independent with
distutils.util library.
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
---
BaseTools/Source/Python/AutoGen/UniClassObject.py | 50 ++++++++++++++++++++++++++++++++++++++++++++++----
1 file changed, 46 insertions(+), 4 deletions(-)
diff --git a/BaseTools/Source/Python/AutoGen/UniClassObject.py b/BaseTools/Source/Python/AutoGen/UniClassObject.py
index d162387cc5..c4b39d25d4 100644
--- a/BaseTools/Source/Python/AutoGen/UniClassObject.py
+++ b/BaseTools/Source/Python/AutoGen/UniClassObject.py
@@ -16,11 +16,10 @@
##
# Import Modules
#
from __future__ import print_function
import Common.LongFilePathOs as os, codecs, re
-import distutils.util
import Common.EdkLogger as EdkLogger
from io import BytesIO
from Common.BuildToolError import *
from Common.StringUtils import GetLineNo
from Common.Misc import PathClass
@@ -41,11 +40,11 @@ NON_BREAKING_CHAR = u'\uFFF2'
CR = u'\u000D'
LF = u'\u000A'
NULL = u'\u0000'
TAB = u'\t'
BACK_SLASH_PLACEHOLDER = u'\u0006'
-
+WHITESPACE = ' \t\n\r\v\f'
gIncludePattern = re.compile("^#include +[\"<]+([^\"< >]+)[>\"]+$", re.MULTILINE | re.UNICODE)
## Convert a unicode string to a Hex list
#
# Convert a unicode string to a Hex list
@@ -216,10 +215,54 @@ def StripComments(Line):
CommentPos = Line.find (Comment, CommentPos + 1)
else:
return Line[:CommentPos].strip()
return Line.strip()
+#
+# This function implement distutils.util.split_quoted in another way.
+#
+def splitquoted(s):
+ words = []
+ word = []
+ InQuoted = False
+ escaped = False
+ CurrentQ = ""
+ s = s.strip()
+ for ch in s:
+ if escaped:
+ # preserve whatever is escaped;
+ # This char will become part of the current word
+ word.append(ch)
+ escaped = False
+ continue
+
+ if ch in WHITESPACE and not InQuoted:
+ # unescaped, unquoted whitespace: now
+ # we definitely have a word delimiter
+ if "".join(word):
+ words.append("".join(word))
+ word = []
+ continue
+ elif ch == "\\":
+ escaped = True
+ if not InQuoted:
+ continue
+ else:
+ # handle singly-quoted string or doubly-quoted string
+ if ch =='"' or ch == "'":
+ if not InQuoted:
+ InQuoted = True
+ CurrentQ = ch
+ continue
+ elif ch == CurrentQ:
+ InQuoted = False
+ continue
+ word.append(ch)
+ if word:
+ words.append("".join(word))
+ return words
+
## UniFileClassObject
#
# A structure for .uni file definition
#
class UniFileClassObject(object):
@@ -232,16 +275,15 @@ class UniFileClassObject(object):
self.OrderedStringListByToken = {} #{ u'LanguageIdentifier' : {Token: StringDefClassObject} }
self.IsCompatibleMode = IsCompatibleMode
self.IncludePathList = IncludePathList
if len(self.FileList) > 0:
self.LoadUniFiles(FileList)
-
#
# Get Language definition
#
def GetLangDef(self, File, Line):
- Lang = distutils.util.split_quoted((Line.split(u"//")[0]))
+ Lang = splitquoted((Line.split(u"//")[0]))
if len(Lang) != 3:
try:
FileIn = UniFileClassObject.OpenUniFile(LongFilePath(File.Path))
except UnicodeError as X:
EdkLogger.error("build", FILE_READ_FAILURE, "File read failure: %s" % str(X), ExtraData=File);
--
2.20.1.windows.1
next prev parent reply other threads:[~2019-02-03 5:55 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-02-03 5:55 [Patch 0/3] BaseTools: Implement splitquoted function Feng, Bob C
2019-02-03 5:55 ` Feng, Bob C [this message]
2019-02-04 15:38 ` [Patch 1/3] BaseTools: Implement splitquoted function in Build tool Carsey, Jaben
2019-02-03 5:55 ` [Patch 2/3] BaseTools: Implement splitquoted function in UPT Feng, Bob C
2019-02-03 5:55 ` [Patch 3/3] BaseTools: unit test for splitquoted function Feng, Bob C
2019-02-04 19:12 ` [Patch 0/3] BaseTools: Implement " Laszlo Ersek
2019-02-12 12:23 ` Laszlo Ersek
2019-02-12 13:33 ` Gao, Liming
2019-02-12 14:02 ` Laszlo Ersek
2019-02-12 17:16 ` Philippe Mathieu-Daudé
2019-02-12 17:24 ` Laszlo Ersek
2019-02-14 2:51 ` Feng, Bob C
2019-02-14 3:23 ` Gao, Liming
2019-02-14 15:35 ` Laszlo Ersek
2019-02-15 14:35 ` Gao, Liming
2019-02-15 21:54 ` Laszlo Ersek
2019-02-14 15:32 ` Laszlo Ersek
2019-02-15 3:19 ` Feng, Bob C
2019-02-12 10:44 ` Gao, Liming
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-list from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20190203055515.18336-2-bob.c.feng@intel.com \
--to=devel@edk2.groups.io \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox