X-Git-Url: https://svn.cri.ensmp.fr/git/minwii.git/blobdiff_plain/e91cf222dbfdb5d5180b58aa906f7896972cb1ff..29dfa14e4419fb6ceb9350223f410e967e8cc4f6:/setup_win_exe.py?ds=sidebyside diff --git a/setup_win_exe.py b/setup_win_exe.py index 2a9b4e7..9fb24c4 100755 --- a/setup_win_exe.py +++ b/setup_win_exe.py @@ -1,4 +1,4 @@ -# -*- coding: utf-8 -*- +# -*- coding: iso-8859-1 -*- # This will create a dist directory containing the executable file, all the data # directories. All Libraries will be bundled in executable file. # @@ -26,48 +26,75 @@ def isSystemDLL(pathname): return origIsSystemDLL(pathname) py2exe.build_exe.isSystemDLL = isSystemDLL +def findMinwiiDir() : + import minwii + return os.path.dirname(minwii.__file__) -class pygame2exe(py2exe.build_exe.py2exe): #This hack make sure that pygame default font is copied: no need to modify code for specifying default font - def copy_extensions(self, extensions): - #Get pygame default font - pygamedir = os.path.split(pygame.base.__file__)[0] - pygame_default_font = os.path.join(pygamedir, pygame.font.get_default_font()) - - #Add font to list of extension to be copied - extensions.append(Module("pygame.font", pygame_default_font)) +class MinWii2exe(py2exe.build_exe.py2exe) : + def copy_extensions(self, extensions) : py2exe.build_exe.py2exe.copy_extensions(self, extensions) + minwiiDir = findMinwiiDir() + self.copyDataFiles(os.path.join(minwiiDir, 'fonts'), 'minwii/fonts') + self.copyDataFiles(os.path.join(minwiiDir, 'soundfonts'), 'minwii/soundfonts') + self.copyDataFiles(os.path.join(minwiiDir, 'widgets', 'data'), 'minwii/widgets/data') + + pygamedir = os.path.dirname(pygame.base.__file__) + pygame_default_font = os.path.join(pygamedir, pygame.font.get_default_font()) + dest = os.path.join(self.collect_dir, 'pygame', pygame.font.get_default_font()) + self.copy_file(pygame_default_font, dest) + self.compiled_files.append(os.path.join('pygame', pygame.font.get_default_font())) + + def copyDataFiles(self, src, dest) : + src = src.replace('/', os.path.sep) + reldest = dest.replace('/', os.path.sep) + dest = os.path.join(self.collect_dir, reldest) + + if not os.path.exists(dest) : + self.mkpath(dest) + + for path, dirs, files in os.walk(src) : + if '.svn' in path : continue + relpath = path[len(src)+1:] + if not os.path.exists(os.path.join(dest, relpath)) : + self.mkpath(os.path.join(dest, relpath)) + + for file in files : + s = os.path.join(path, file) + d = os.path.join(dest, relpath, file) + self.copy_file(s, d) + print os.path.join(reldest, relpath, file) + self.compiled_files.append(os.path.join(reldest, relpath, file)) + class BuildExe: def __init__(self): #Name of starting .py - self.script = "src/minwii/start_win.py" + #self.script = "src/minwii/runminwii.py" #Name of program - self.project_name = "MINWii" + self.project_name = "MINDs" #Project url - self.project_url = "about:none" + self.project_url = "http://minwii.org" #Version of program - self.project_version = "0.0" + self.project_version = "2.0.2" #License of the program - self.license = "MyApps License" + self.license = "GPL" #Auhor of program - self.author_name = "Me" - self.author_email = "example@example.com" - self.copyright = "Copyright (c) 2009 Me." + self.author_name = "Samuel Benveniste" + self.author_email = "samuel.benveniste@gmail.com" + self.copyright = "Copyright 2010-2011 MINES-ParisTech" #Description - self.project_description = "MyApps Description" + self.project_description = "Musique Interactive Numérique pour les Démences" #Icon file (None will use pygame default icon) - self.icon_file = None + self.icon_file = 'minwii.ico' - #Extra files/dirs copied to game - self.data_files = [('minwii/fonts', - glob.glob('src/minwii/fonts/*.ttf'))] + self.data_files = [] #Extra/excludes python modules self.extra_modules = [] @@ -77,7 +104,7 @@ class BuildExe: self.exclude_dll = [''] #Zip file name (None will bundle files in exe instead of zip file) - self.zipfile_name = None + self.zipfile_name = 'minwii_lib.zip' #Dist directory self.dist_dir ='dist' @@ -98,7 +125,7 @@ class BuildExe: setup( - cmdclass = {'py2exe': pygame2exe}, + cmdclass = {'py2exe': MinWii2exe}, version = self.project_version, description = self.project_description, name = self.project_name, @@ -108,18 +135,26 @@ class BuildExe: license = self.license, # targets to build - #windows = [{ - # 'script': self.script, - # 'icon_resources': [(0, self.icon_file)], - # 'copyright': self.copyright - #}], - console = [self.script], - options = {'py2exe': {#'optimize': 2, - 'bundle_files': 1, + windows = [{ + 'script': "src/minwii/runminwii.py", + 'icon_resources': [(0, self.icon_file)], + 'copyright': self.copyright + }, + { + 'script' : "src/minwii/logapp.py", + 'icon_resources': [(0, 'logapp.ico')], + 'copyright' : self.copyright + } + ], + #console = ["src/minwii/logapp.py"], + options = {'py2exe': {'optimize': 1, + 'bundle_files': 3, #'compressed': True, - 'excludes': self.exclude_modules, - 'packages': self.extra_modules, - 'dll_excludes': self.exclude_dll} + #'excludes': self.exclude_modules, + #'packages': self.extra_modules, + #'dll_excludes': self.exclude_dll, + 'skip_archive' : True + } }, zipfile = self.zipfile_name, data_files = self.data_files,