== FFMPEG ==
[blender.git] / SConstruct
index ce41589a03a4ee5f30c727f3c5c3f7832f04c1b1..2cacb91d10342114d1b9ef5d2baf5fbd853b863f 100644 (file)
@@ -71,6 +71,11 @@ if platform=='win32':
 
 if not use_color=='1':
     B.bc.disable()
+    
+ #on defaut white Os X terminal, some colors are totally unlegible
+if platform=='darwin':
+    B.bc.OKGREEN = '\033[34m'
+    B.bc.WARNING = '\033[36m'
 
 # arguments
 print B.bc.HEADER+'Command-line arguments'+B.bc.ENDC
@@ -110,6 +115,8 @@ if toolset:
         env.Tool('mstoolkit', ['tools'])
     else:
         env = BlenderEnvironment(tools=[toolset], ENV = os.environ)
+        if env:
+            btools.SetupSpawn(env)
 else:
     env = BlenderEnvironment(ENV = os.environ)
 
@@ -117,7 +124,7 @@ if not env:
     print "Could not create a build environment"
     Exit()
 
-env.SConscriptChdir(0)
+
 cc = B.arguments.get('CC', None)
 cxx = B.arguments.get('CXX', None)
 if cc:
@@ -130,53 +137,7 @@ if env['CC'] in ['cl', 'cl.exe'] and sys.platform=='win32':
 elif env['CC'] in ['gcc'] and sys.platform=='win32':
     platform = 'win32-mingw'
 
-# Fix me!
-#if platform == 'win32-mingw':
-if 0:
-    try:
-        import win32file
-        import win32event
-        import win32process
-        import win32security
-        import string
-
-        slash= re.compile(r"\\")
-
-        def myesc(b):
-            if b[0]!= "-":
-                b = slash.sub(r"\\\\", b[1:-1])
-                return "\"" + b + "\""
-            else:
-                return b
-
-        def my_spawn(sh, escape, cmd, args, spawnenv):
-            for var in spawnenv:
-                spawnenv[var] = spawnenv[var].encode('ascii', 'replace')
-
-            sAttrs = win32security.SECURITY_ATTRIBUTES()
-            StartupInfo = win32process.STARTUPINFO()
-            if cmd=='ar' and args[1]=='r':
-                args[1] = '-r'
-            newargs = string.join(map(myesc, args[1:]), ' ')
-            cmdline = cmd + " " + newargs
-
-            # check for any special operating system commands
-            if cmd == 'del':
-                for arg in args[1:]:
-                    win32file.DeleteFile(arg)
-                exit_code = 0
-            else:
-                # otherwise execute the command.
-                hProcess, hThread, dwPid, dwTid = win32process.CreateProcess(None, cmdline, None, None, 1, 0, spawnenv, None, StartupInfo)
-                win32event.WaitForSingleObject(hProcess, win32event.INFINITE)
-                exit_code = win32process.GetExitCodeProcess(hProcess)
-                win32file.CloseHandle(hProcess);
-                win32file.CloseHandle(hThread);
-            return exit_code
-
-        env['SPAWN'] = my_spawn
-    except:
-        print "install win32all from http://sourceforge.net/project/showfiles.php?group_id=78018"
+env.SConscriptChdir(0)
 
 crossbuild = B.arguments.get('BF_CROSS', None)
 if crossbuild and platform!='win32':
@@ -273,162 +234,6 @@ env['BUILDDIR'] = B.root_build_dir
 if not B.root_build_dir[-1]==os.sep:
     B.root_build_dir += os.sep
     
-def NSIS_Installer():
-
-       if env['OURPLATFORM'] != 'win32-vc' and env['OURPLATFORM'] != 'win32-mingw':
-               print "NSIS installer is only available on Windows."
-               Exit()
-               
-       install_base_dir = os.getcwd() + "\\"
-       
-       os.chdir("release")
-       v = open("VERSION")
-       version = v.read()[:-1]
-       shortver = version.split('.')[0] + version.split('.')[1]
-       v.close()
-       
-       #### change to suit install dir ####
-       inst_dir = install_base_dir + env['BF_INSTALLDIR']
-
-       os.chdir("windows/installer")
-       
-       ns = open("00.sconsblender.nsi","r")
-       
-       ns_cnt = str(ns.read())
-       ns.close()
-       
-       # do root
-       rootlist = []
-       rootdir = os.listdir(inst_dir+"\\")
-       for rootitem in rootdir:
-               if os.path.isdir(inst_dir+"\\"+ rootitem) == 0:
-                       rootlist.append("File " + inst_dir + "\\" + rootitem)
-       rootstring = string.join(rootlist, "\n  ")
-       rootstring += "\n\n"
-       ns_cnt = string.replace(ns_cnt, "[ROOTDIRCONTS]", rootstring)
-       
-       # do delete items
-       delrootlist = []
-       for rootitem in rootdir:
-               if os.path.isdir(inst_dir + rootitem) == 0:
-                       delrootlist.append("Delete $INSTDIR\\" + rootitem)
-       delrootstring = string.join(delrootlist, "\n ")
-       delrootstring += "\n"
-       ns_cnt = string.replace(ns_cnt, "[DELROOTDIRCONTS]", delrootstring)
-       
-       # do scripts
-       scriptlist = []
-       scriptpath = "%s%s" % (inst_dir, "\\.blender\\scripts")
-       scriptdir = os.listdir(scriptpath)
-       for scriptitem in scriptdir:
-               scriptfile = "%s\\%s" % (scriptpath, scriptitem)
-               if os.path.isdir(scriptfile) == 0:
-                       scriptlist.append("File %s" % scriptfile)
-       scriptstring = string.join(scriptlist, "\n  ")
-       scriptstring += "\n\n"
-       ns_cnt = string.replace(ns_cnt, "[SCRIPTCONTS]", scriptstring)
-       
-       # do scripts\bpymodules
-       bpymodlist = []
-       bpymodpath = "%s%s" % (inst_dir, "\\.blender\\scripts\\bpymodules")
-       bpymoddir = os.listdir(bpymodpath)
-       
-       for bpymoditem in bpymoddir:
-               bpymodfile = "%s\\%s" % (bpymodpath, bpymoditem)
-               if os.path.isdir(bpymodfile) == 0:
-                       bpymodlist.append("File %s" % bpymodfile)
-       bpymodstring = string.join(bpymodlist, "\n  ")
-       bpymodstring += "\n\n"
-       ns_cnt = string.replace(ns_cnt, "[SCRIPTMODCONTS]", bpymodstring)
-       
-       # do scripts\bpymodules\colladaimex
-       colladalist = []
-       bpymodpath = "%s%s" % (inst_dir, "\\.blender\\scripts\\bpymodules\\ColladaImEx")
-       bpymoddir = os.listdir(bpymodpath)
-       
-       for bpymoditem in bpymoddir:
-               bpymodfile = "%s\\%s" % (bpymodpath, bpymoditem)
-               if os.path.isdir(bpymodfile) == 0:
-                       colladalist.append("File %s" % bpymodfile)
-       bpymodstring = string.join(colladalist, "\n  ")
-       bpymodstring += "\n\n"
-       ns_cnt = string.replace(ns_cnt, "[SCRIPTMODCOLLADACONT]", bpymodstring)
-       
-       # do scripts\bpydata
-       bpydatalist = []
-       bpydatapath = "%s%s" % (inst_dir, "\\.blender\\scripts\\bpydata")
-       bpydatadir = os.listdir(bpydatapath)
-       for bpydataitem in bpydatadir:
-               bpydatafile = "%s\\%s" % (bpydatapath, bpydataitem)
-               if os.path.isdir(bpydatafile) == 0:
-                       bpydatalist.append("File %s" % bpydatafile)
-       bpydatastring = string.join(bpydatalist, "\n  ")
-       bpydatastring += "\n\n"
-       ns_cnt = string.replace(ns_cnt, "[SCRIPTDATACONTS]", bpydatastring)
-       
-       # do plugins\include
-       plugincludelist = []
-       plugincludepath = "%s%s" % (inst_dir, "\\plugins\\include")
-       plugincludedir = os.listdir(plugincludepath)
-       for plugincludeitem in plugincludedir:
-               plugincludefile = "%s\\%s" % (plugincludepath, plugincludeitem)
-               if os.path.isdir(plugincludefile) == 0:
-                       if plugincludefile.find('.h') or plugincludefile.find('.DEF'):
-                               plugincludelist.append("File %s" % plugincludefile)
-       plugincludestring = string.join(plugincludelist, "\n  ")
-       plugincludestring += "\n\n"
-       ns_cnt = string.replace(ns_cnt, "[PLUGINCONTS]", plugincludestring)
-       
-       # do scripts\bpydata\config
-       cfglist = []
-       cfgpath = "%s%s" % (inst_dir, "\\.blender\\scripts\\bpydata\\config")
-       cfgdir = os.listdir(cfgpath)
-       for cfgitem in cfgdir:
-               cfgfile = "%s\\%s" % (cfgpath, cfgitem)
-               if os.path.isdir(cfgfile) == 0:
-                       cfglist.append("File %s" % cfgfile)
-       cfgstring = string.join(cfglist, "\n  ")
-       cfgstring += "\n\n"
-       ns_cnt = string.replace(ns_cnt, "[SCRIPTDATACFGCONTS]", cfgstring)
-       
-       # do dotblender
-       dotblendlist = []
-       dotblenddir = os.listdir(inst_dir+"\\.blender")
-       for dotblenditem in dotblenddir:
-               if os.path.isdir(inst_dir + "\\.blender\\" + dotblenditem) == 0:
-                       dotblendlist.append("File " + inst_dir + "\\.blender\\" + dotblenditem)
-       dotblendstring = string.join(dotblendlist, "\n  ")
-       dotblendstring += "\n\n"
-       ns_cnt = string.replace(ns_cnt, "[DOTBLENDERCONTS]", dotblendstring)
-       
-       # do language files
-       langlist = []
-       langfiles = []
-       langdir = os.listdir(inst_dir + "\\.blender\\locale")
-       for langitem in langdir:
-               if os.path.isdir(inst_dir + "\\.blender\\locale\\" + langitem) == 1:
-                       langfiles.append("SetOutPath $BLENDERHOME\\.blender\\locale\\" + langitem + "\\LC_MESSAGES")
-                       langfiles.append("File " + inst_dir + "\\.blender\\locale\\" + langitem + "\\LC_MESSAGES\\blender.mo")
-       langstring = string.join(langfiles, "\n  ")
-       langstring += "\n\n"
-       ns_cnt = string.replace(ns_cnt, "[LANGUAGECONTS]", langstring)
-       
-       # var replacements
-       ns_cnt = string.replace(ns_cnt, "DISTDIR", inst_dir+"\\")
-       ns_cnt = string.replace(ns_cnt, "SHORTVER", shortver)
-       ns_cnt = string.replace(ns_cnt, "VERSION", version)
-       
-       new_nsis = open("00.blender_tmp.nsi", 'w')
-       new_nsis.write(ns_cnt)
-       new_nsis.close()
-       
-       sys.stdout = os.popen("makensis 00.blender_tmp.nsi", 'w')
-    
-nsis_build = None
-if 'nsis' in B.targets:
-    NSIS_Installer()
-    Exit()
-
 # We do a shortcut for clean when no quicklist is given: just delete
 # builddir without reading in SConscripts
 do_clean = None
@@ -436,13 +241,16 @@ if 'clean' in B.targets:
     do_clean = True
 
 if not quickie and do_clean:
-    print B.bc.HEADER+'Cleaning...'+B.bc.ENDC
-    dirs = os.listdir(B.root_build_dir)
-    for dir in dirs:
-        if os.path.isdir(B.root_build_dir + dir) == 1:
-            print "clean dir %s"%(B.root_build_dir+dir)
-            shutil.rmtree(B.root_build_dir+dir)
-    print B.bc.OKGREEN+'...done'+B.bc.ENDC
+    if os.path.exists(B.root_build_dir):
+        print B.bc.HEADER+'Cleaning...'+B.bc.ENDC
+        dirs = os.listdir(B.root_build_dir)
+        for dir in dirs:
+            if os.path.isdir(B.root_build_dir + dir) == 1:
+                print "clean dir %s"%(B.root_build_dir+dir)
+                shutil.rmtree(B.root_build_dir+dir)
+        print B.bc.OKGREEN+'...done'+B.bc.ENDC
+    else:
+        print B.bc.HEADER+'Already Clean, nothing to do.'+B.bc.ENDC
     Exit()
 
 if not os.path.isdir ( B.root_build_dir):
@@ -471,8 +279,6 @@ B.init_lib_dict()
 ##### END SETUP ##########
 
 Export('env')
-#Export('root_build_dir') # this one is still needed for makesdna
-##TODO: improve makesdna usage
 
 BuildDir(B.root_build_dir+'/intern', 'intern', duplicate=0)
 SConscript(B.root_build_dir+'/intern/SConscript')
@@ -506,7 +312,22 @@ if env['WITH_BF_PLAYER']:
 
 #------------ INSTALL
 
-blenderinstall = env.Install(dir=env['BF_INSTALLDIR'], source=B.program_list)
+#-- binaries
+blenderinstall = []
+if  env['OURPLATFORM']=='darwin':
+    for prg in B.program_list:
+        bundle = '%s.app' % prg[0]
+        bundledir = os.path.dirname(bundle)
+        for dp, dn, df in os.walk(bundle):
+            if 'CVS' in dn:
+                dn.remove('CVS')
+            if '.svn' in dn:
+                dn.remove('.svn')
+            dir=env['BF_INSTALLDIR']+dp[len(bundledir):]
+            source=[dp+os.sep+f for f in df]
+            blenderinstall.append(env.Install(dir=dir,source=source))
+else:
+    blenderinstall = env.Install(dir=env['BF_INSTALLDIR'], source=B.program_list)
 
 #-- .blender
 dotblendlist = []
@@ -514,6 +335,8 @@ dottargetlist = []
 for dp, dn, df in os.walk('bin/.blender'):
     if 'CVS' in dn:
         dn.remove('CVS')
+    if '.svn' in dn:
+        dn.remove('.svn')
     for f in df:
         dotblendlist.append(dp+os.sep+f)
         dottargetlist.append(env['BF_INSTALLDIR']+dp[3:]+os.sep+f)
@@ -529,6 +352,8 @@ scriptpath='release/scripts'
 for dp, dn, df in os.walk(scriptpath):
     if 'CVS' in dn:
         dn.remove('CVS')
+    if '.svn' in dn:
+        dn.remove('.svn')
     dir=env['BF_INSTALLDIR']+'/.blender/scripts'+dp[len(scriptpath):]
     source=[dp+os.sep+f for f in df]
     scriptinstall.append(env.Install(dir=dir,source=source))
@@ -539,6 +364,8 @@ plugtargetlist = []
 for tp, tn, tf in os.walk('release/plugins'):
     if 'CVS' in tn:
         tn.remove('CVS')
+    if '.svn' in tn:
+        tn.remove('.svn')
     for f in tf:
         pluglist.append(tp+os.sep+f)
         plugtargetlist.append(env['BF_INSTALLDIR']+tp[7:]+os.sep+f)
@@ -553,6 +380,8 @@ texttargetlist = []
 for tp, tn, tf in os.walk('release/text'):
     if 'CVS' in tn:
         tn.remove('CVS')
+    if '.svn' in tn:
+        tn.remove('.svn')
     for f in tf:
         textlist.append(tp+os.sep+f)
 
@@ -563,15 +392,15 @@ allinstall = [blenderinstall, dotblenderinstall, scriptinstall, plugininstall, t
 if env['OURPLATFORM'] in ('win32-vc', 'win32-mingw'):
     dllsources = ['${LCGDIR}/gettext/lib/gnu_gettext.dll',
                         '${LCGDIR}/png/lib/libpng.dll',
-#                        '#release/windows/extra/python24.zip',
-#                        '#release/windows/extra/zlib.pyd',
+                        '#release/windows/extra/python25.zip',
+                        '#release/windows/extra/zlib.pyd',
                         '${LCGDIR}/sdl/lib/SDL.dll',
                         '${LCGDIR}/zlib/lib/zlib.dll',
                         '${LCGDIR}/tiff/lib/libtiff.dll']
     if env['BF_DEBUG']:
-        dllsources.append('${LCGDIR}/python/lib/python25_d.dll')
+        dllsources.append('${LCGDIR}/python/lib/${BF_PYTHON_LIB}.dll')
     else:
-        dllsources.append('${LCGDIR}/python/lib/python25.dll')
+        dllsources.append('${LCGDIR}/python/lib/${BF_PYTHON_LIB}.dll')
     if env['OURPLATFORM'] == 'win32-mingw':
         dllsources += ['${LCGDIR}/pthreads/lib/pthreadGC2.dll']
     else:
@@ -581,24 +410,17 @@ if env['OURPLATFORM'] in ('win32-vc', 'win32-mingw'):
     if env['WITH_BF_FFMPEG']:
         dllsources += ['${LCGDIR}/ffmpeg/lib/avcodec-51.dll',
                         '${LCGDIR}/ffmpeg/lib/avformat-51.dll',
-                        '${LCGDIR}/ffmpeg/lib/avutil-49.dll',
-                        '${LCGDIR}/ffmpeg/lib/libdts.dll',
-                        '${LCGDIR}/ffmpeg/lib/libfaac.dll',
-                        '${LCGDIR}/ffmpeg/lib/libfaad.dll',
-                        '${LCGDIR}/ffmpeg/lib/libgsm.dll',
-                        '${LCGDIR}/ffmpeg/lib/libmp3lame-0.dll',
-                        '${LCGDIR}/ffmpeg/lib/libogg-0.dll',
-                        '${LCGDIR}/ffmpeg/lib/libvorbis-0.dll',
-                        '${LCGDIR}/ffmpeg/lib/libvorbisenc-2.dll',
-                        '${LCGDIR}/ffmpeg/lib/libx264-54.dll',
-                        '${LCGDIR}/ffmpeg/lib/postproc-51.dll',
-                        '${LCGDIR}/ffmpeg/lib/xvidcore.dll']
+                        '${LCGDIR}/ffmpeg/lib/avutil-49.dll']
     windlls = env.Install(dir=env['BF_INSTALLDIR'], source = dllsources)
     allinstall += windlls
 
 installtarget = env.Alias('install', allinstall)
 bininstalltarget = env.Alias('install-bin', blenderinstall)
 
+nsisaction = env.Action(btools.NSIS_Installer, btools.NSIS_print)
+nsiscmd = env.Command('nsisinstaller', None, nsisaction)
+nsisalias = env.Alias('nsis', nsiscmd)
+
 if env['WITH_BF_PLAYER']:
     blenderplayer = env.Alias('blenderplayer', B.program_list)
     Depends(blenderplayer,installtarget)
@@ -607,8 +429,12 @@ if not env['WITH_BF_GAMEENGINE']:
     blendernogame = env.Alias('blendernogame', B.program_list)
     Depends(blendernogame,installtarget)
 
+Depends(nsiscmd, allinstall)
+
 Default(B.program_list)
-Default(installtarget)
+
+if not env['WITHOUT_BF_INSTALL']:
+       Default(installtarget)
 
 #------------ RELEASE
 # TODO: zipup the installation