package_rpm.bbclass : escape "%" in files and directories name
The rpm process replace all the "%name" in the spec file by the name of the package. So, if the package is composed of some files or directories named "%name...", the rpm package process failed. Replace all "%" present in files or directories names by "%%%%%%%%" to correctly escape "%" due to the number of times that % is treated as an escape character. Jeff Johnson says this is the Right Thing To Do. [ YOCTO #5397 ] (From OE-Core rev: 5ed1c7f556df3fafd45d493010cc0bbe74d05ebd) Signed-off-by: Sébastien Mennetrier <smennetrier@voxtok.com> Signed-off-by: Michaël Burtin <mburtin@voxtok.com> Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
e062f01d5f
commit
311c428636
|
@ -196,6 +196,7 @@ python write_specfile () {
|
|||
path = rootpath.replace(walkpath, "")
|
||||
if path.endswith("DEBIAN") or path.endswith("CONTROL"):
|
||||
continue
|
||||
path = path.replace("%", "%%%%%%%%")
|
||||
|
||||
# Treat all symlinks to directories as normal files.
|
||||
# os.walk() lists them as directories.
|
||||
|
@ -214,6 +215,7 @@ python write_specfile () {
|
|||
for dir in dirs:
|
||||
if dir == "CONTROL" or dir == "DEBIAN":
|
||||
continue
|
||||
dir = dir.replace("%", "%%%%%%%%")
|
||||
# All packages own the directories their files are in...
|
||||
target.append('%dir "' + path + '/' + dir + '"')
|
||||
else:
|
||||
|
@ -227,6 +229,7 @@ python write_specfile () {
|
|||
for file in files:
|
||||
if file == "CONTROL" or file == "DEBIAN":
|
||||
continue
|
||||
file = file.replace("%", "%%%%%%%%")
|
||||
if conffiles.count(path + '/' + file):
|
||||
target.append('%config "' + path + '/' + file + '"')
|
||||
else:
|
||||
|
|
Loading…
Reference in New Issue