Implémentation plus propre avec une sous-classe de Sprite.
[minwii.git] / setup_win_exe.py
index 2a9b4e7..9fb24c4 100755 (executable)
@@ -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,