summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEdwin Mons <edwin.mons@isode.com>2014-10-17 10:06:17 (GMT)
committerEdwin Mons <edwin.mons@isode.com>2014-10-17 10:39:46 (GMT)
commit0e7940bf2ede0147ee1eafced53bc9ad08a4015e (patch)
tree6295f5e8054f7f7212fc66ab83001c8d82821995
parentc02aedbe59a3abc2a7b84b7e1a8bf3a7f11ee20f (diff)
downloadswift-contrib-0e7940bf2ede0147ee1eafced53bc9ad08a4015e.zip
swift-contrib-0e7940bf2ede0147ee1eafced53bc9ad08a4015e.tar.bz2
Make core.c generation compatible with Python 2.4
generate_embedded_lua in Sluift/SConscript used a bytearray, which wasn't available until Python 2.6. Modified the code to use the string data instead of a bytearray. Test-information: Builds on OS X 10.9 and CentOS 5.9 sluift binary works on both platforms Change-Id: Iae29f76e32c8b7a827bc438caf09457b259446ca
-rw-r--r--Sluift/SConscript5
1 files changed, 2 insertions, 3 deletions
diff --git a/Sluift/SConscript b/Sluift/SConscript
index 5e0a030..a2b6748 100644
--- a/Sluift/SConscript
+++ b/Sluift/SConscript
@@ -40,50 +40,49 @@ elif env["SCONS_STAGE"] == "build" :
"core.c",
"client.cpp",
"component.cpp",
"sluift.cpp"
]
sluift_sources += env.SConscript("ElementConvertors/SConscript")
sluift_env = env.Clone()
sluift_env.UseFlags(env.get("LUA_FLAGS", {}))
sluift_env.UseFlags(env["SWIFTEN_FLAGS"])
sluift_env.UseFlags(env["SWIFTEN_DEP_FLAGS"])
# Support compilation on both Lua 5.1 and Lua 5.2
sluift_env.Append(CPPDEFINES = ["LUA_COMPAT_ALL"])
if sluift_env["PLATFORM"] == "win32" :
sluift_env.Append(CPPDEFINES = ["SLUIFT_BUILD_DLL"])
if sluift_env["PLATFORM"] == "darwin" and os.path.isdir("/Applications/iTunes.app") :
sluift_env.Append(FRAMEWORKS = ["ScriptingBridge"])
sluift_env.Command("iTunes.h", "/Applications/iTunes.app",
"sdef ${SOURCE} | sdp -fh --basename iTunes -o ${TARGET.dir}")
sluift_env.Append(CPPDEFINES = ["HAVE_ITUNES"])
sluift_sources += ["ITunesInterface.mm"]
# Generate Version.h
version_header = "#pragma once\n\n"
version_header += "#define SLUIFT_VERSION_STRING \"" + Version.getBuildVersion(env.Dir("#").abspath, "sluift") + "\"\n"
sluift_env.WriteVal("Version.h", sluift_env.Value(version_header))
# Generate core.c
def generate_embedded_lua(env, target, source) :
f = open(source[0].abspath, "r")
data = f.read()
f.close()
- data_bytes = bytearray(data)
f = open(target[0].abspath, "w")
f.write('#include <stddef.h>\n')
- f.write('const size_t ' + source[0].name.replace(".", "_") + "_size = " + str(len(data_bytes)) + ";\n")
- f.write('const char ' + source[0].name.replace(".", "_") + "[] = {" + ", ".join([str(b) for b in data_bytes]) + "};\n")
+ f.write('const size_t ' + source[0].name.replace(".", "_") + "_size = " + str(len(data)) + ";\n")
+ f.write('const char ' + source[0].name.replace(".", "_") + "[] = {" + ", ".join([str(ord(c)) for c in data]) + "};\n")
f.close()
sluift_env.Command("core.c", ["core.lua"], env.Action(generate_embedded_lua, cmdstr="$GENCOMSTR"))
sluift_env.WriteVal("dll.c", sluift_env.Value(""))
sluift_sources = [env.File(x) for x in sluift_sources]
for sluift_variant in ['dll', 'exe'] :
SConscript(["SConscript.variant"], variant_dir = sluift_variant,
duplicate = 0,
exports = ['sluift_sources', 'sluift_variant', 'sluift_env'])