forked from cztomczak/cefpython
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmake-setup.py
More file actions
172 lines (144 loc) · 6.08 KB
/
make-setup.py
File metadata and controls
172 lines (144 loc) · 6.08 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
# Copyright (c) 2012-2014 The CEF Python authors. All rights reserved.
# License: New BSD License.
# Website: http://code.google.com/p/cefpython/
# Create a setup package.
import sys
import os
import platform
import argparse
import re
import shutil
import glob
import sysconfig
import subprocess
import struct
BITS = "%sbit" % (8 * struct.calcsize("P"))
PACKAGE_NAME = "cefpython3"
INIT_TEMPLATE = os.getcwd()+r"/__init__.py.template"
SETUP_TEMPLATE = os.getcwd()+r"/setup.py.template"
PY_VERSION_DIGITS_ONLY = (str(sys.version_info.major) + ""
+ str(sys.version_info.minor)) # "27" or "34"
def str_format(string, dictionary):
orig_string = string
for key, value in dictionary.iteritems():
string = string.replace("%("+key+")s", value)
if string == orig_string:
raise Exception("Nothing to format")
if re.search(r"%\([a-zA-Z0-9_]+\)s", string):
raise Exception("Not all strings formatted")
return string
def get_binaries_dir(b32, b64, bfat):
pyver = PY_VERSION_DIGITS_ONLY
if (os.path.exists(b32 + "/cefpython_py{}.so".format(pyver))
and os.path.exists(b64 + "/cefpython_py{}.so".format(pyver))):
create_fat_binaries(b32, b64, bfat)
return bfat
return os.path.abspath(installer_dir+"/../binaries_"+BITS+"/")
def create_fat_binaries(b32, b64, bfat):
print("Creating fat binaries")
if os.path.exists(bfat):
shutil.rmtree(bfat)
os.mkdir(bfat)
res = os.system("cp -rf {}/* {}/".format(b64, bfat))
assert res == 0
files = os.listdir(b32)
for fbase in files:
if not (fbase.endswith(".dylib") or fbase.endswith(".so")
or fbase.endswith("subprocess")):
continue
fname32 = os.path.join(b32, fbase)
fname64 = os.path.join(b64, fbase)
fnamefat = os.path.join(bfat, fbase)
print("Creating fat binary: {}".format(fbase))
res = os.system("lipo {} {} -create -output {}"
.format(fname32, fname64, fnamefat))
assert res == 0
def main():
parser = argparse.ArgumentParser(usage="%(prog)s [options]")
parser.add_argument("-v", "--version", help="cefpython version",
required=True)
args = parser.parse_args()
assert re.search(r"^\d+\.\d+$", args.version), (
"Invalid version string")
vars = {}
vars["APP_VERSION"] = args.version
# vars["PLATFORM"] = sysconfig.get_platform()
vars["PLATFORM"] = "macosx"
vars["PY_VERSION_DIGITS_ONLY"] = PY_VERSION_DIGITS_ONLY
print("Reading template: %s" % INIT_TEMPLATE)
f = open(INIT_TEMPLATE)
INIT_CONTENT = str_format(f.read(), vars)
f.close()
print("Reading template: %s" % SETUP_TEMPLATE)
f = open(SETUP_TEMPLATE)
SETUP_CONTENT = str_format(f.read(), vars)
f.close()
installer_dir = os.path.dirname(os.path.abspath(__file__))
setup_dir = installer_dir+"/"+PACKAGE_NAME+"-"+vars["APP_VERSION"]+"-"+vars["PLATFORM"]+"-setup"
print("Creating setup dir: "+setup_dir)
os.mkdir(setup_dir)
package_dir = setup_dir+"/"+PACKAGE_NAME
print("Creating package dir")
os.mkdir(package_dir)
print("Creating setup.py from template")
with open(setup_dir+"/setup.py", "w") as f:
f.write(SETUP_CONTENT)
# Create fat binaries if both 32bit and 64bit are available
b32 = os.path.abspath(installer_dir+"/../binaries_32bit/")
b64 = os.path.abspath(installer_dir+"/../binaries_64bit/")
bfat = os.path.abspath(installer_dir+"/binaries_fat/")
binaries_dir = get_binaries_dir(b32, b64, bfat)
print("Copying binaries to package dir")
ret = os.system("cp -rf "+binaries_dir+"/* "+package_dir)
assert ret == 0
os.chdir(package_dir)
print("Removing .log files from the package dir")
ret = os.system("rm *.log")
# assert ret == 0 - if there are no .log files this assert would fail.
os.chdir(installer_dir)
print("Creating __init__.py from template")
with open(package_dir+"/__init__.py", "w") as f:
f.write(INIT_CONTENT)
print("Creating examples dir in package dir")
os.mkdir(package_dir+"/examples/")
print("Creating wx dir in package dir")
os.mkdir(package_dir+"/wx/")
print("Moving example scripts from package dir to examples dir")
examples = glob.glob(package_dir+"/*.py")
for example in examples:
# Ignore: cefpython_py27.py - dummy API script
if os.path.basename(example).startswith("cefpython_"):
continue
# Ignore: __init__.py
if os.path.basename(example).startswith("__"):
continue
os.rename(example, package_dir+"/examples/"+os.path.basename(example))
ret = os.system("mv "+package_dir+"/*.html "+package_dir+"/examples/")
ret = os.system("mv "+package_dir+"/*.js "+package_dir+"/examples/")
ret = os.system("mv "+package_dir+"/*.css "+package_dir+"/examples/")
assert ret == 0
print("Copying wx/ to package dir")
wx_subpackage_dir = os.path.abspath(installer_dir+"/../../wx/")
ret = os.system("cp -rf "+wx_subpackage_dir+"/* "+package_dir+"/wx/")
assert ret == 0
print("Moving wx examples from wx/examples to examples/wx")
shutil.move(package_dir+"/wx/examples", package_dir+"/wx/wx/")
shutil.move(package_dir+"/wx/wx/", package_dir+"/examples/")
print("Copying package dir examples to setup dir")
ret = os.system("cp -rf "+package_dir+"/examples/ "+setup_dir+"/examples/")
assert ret == 0
# Create empty debug.log files so that package uninstalls cleanly
# in case examples were launched. Issue 149.
debug_log_dirs = [package_dir,
package_dir+"/examples/",
package_dir+"/examples/wx/"]
for dir in debug_log_dirs:
print("Creating empty debug.log in %s" % dir)
with open(dir+"/debug.log", "w") as f:
f.write("")
# Set write permissions so that Wheel package files have it
# right. So that examples may be run from package directory.
subprocess.call("chmod 666 %s/debug.log" % dir, shell=True)
print("Setup Package created successfully.")
if __name__ == "__main__":
main()