RNA: ID properties were not being shown as RNA properties anymore, fixed.
[blender.git] / source / blender / makesrna / intern / SConscript
index f8d623dfa2bcc709ca7f7bec8142b2d46ea06529..83f14b9ef14cadd2ccd26c76830b33b882df3dc8 100644 (file)
@@ -2,51 +2,98 @@
 import sys
 import os
 
+def normpath(path):
+       return os.path.abspath(os.path.normpath(path))
+
 Import ('env')
-cflags = ''
+cflags = '-Wall'
 defines = []
-root_build_dir=env['BF_BUILDDIR']
+root_build_dir=normpath(env['BF_BUILDDIR'])
 
 source_files = env.Glob('*.c')
-
-# making rna_access.c part of both makesrna and blender seems to
-# give conflict, how to solve?
 source_files.remove('rna_access.c')
-source_files.remove('rna_dependency.c')
+
+generated_files = source_files[:]
+generated_files.remove('rna_define.c')
+generated_files.remove('makesrna.c')
+generated_files = [filename[:-2] + '_gen.c' for filename in generated_files]
+
+source_files.extend(env.Glob('../../editors/*/*_api.c'))
 
 makesrna_tool = env.Clone()
 rna = env.Clone()
 makesrna_tool.Append(CCFLAGS = '-DBASE_HEADER="\\"source/blender/makesrna/\\"" ')
 
 makesrna_tool.Append (CPPPATH = ['#/intern/guardedalloc',
-                                 '../../blenlib',
-                                 '../../blenkernel',
-                                 '../../makesdna',
-                                 '../../makesrna'])
+                                                                '../../blenlib',
+                                                                '../../blenkernel',
+                                                                '../../makesdna',
+                                                                '../../makesrna',
+                                                                '../../windowmanager',
+                                                                '../../editors/include'])
 
 if env['OURPLATFORM'] == 'linuxcross':
-    makesrna_tool.Replace(CC='gcc')
-    makesrna_tool.Replace(AR='ar')
-    makesrna_tool.Replace(LINK='gcc')
+       USE_WINE = True # when cross compiling on linux 64bit this is useful
+else:
+       USE_WINE = False
+
+if not USE_WINE:
+       if env['OURPLATFORM'] == 'linuxcross':
+               makesdna_tool.Replace(CC='gcc')
+               makesdna_tool.Replace(AR='ar')
+               makesdna_tool.Replace(LINK='gcc')
 
 if sys.platform != 'cygwin':
-    makesrna_tool.Append (CCFLAGS = cflags)
+       makesrna_tool.Append (CCFLAGS = cflags)
 makesrna_tool.Append (CPPDEFINES = defines)
-makesrna_tool.Append (LIBPATH = '#'+root_build_dir+'/lib')
+
+libdir = root_build_dir+'/lib'
+if not (root_build_dir[0]==os.sep or root_build_dir[1]==':'):
+       libdir = '#' + libdir
+
+makesrna_tool.Append (LIBPATH = libdir)
+
 if env['BF_PROFILE']:
        makesrna_tool.Append (LINKFLAGS = env['BF_PROFILE_FLAGS'])
 
+if env['BF_DEBUG']:
+       makesrna_tool.Append(CFLAGS = env['BF_DEBUG_CFLAGS'])
+       makesrna_tool.Append(CCFLAGS = env['BF_DEBUG_CCFLAGS'])
+       if env['OURPLATFORM'] == 'win32-vc':
+               makesrna_tool.Append(LINKFLAGS = ['/DEBUG','/PDB:makesrna.pdb'])
+
+targetpath = root_build_dir+'/makesrna'
+if not (root_build_dir[0]==os.sep or root_build_dir[1]==':'):
+       targetpath = '#' + targetpath
+
 if env['OURPLATFORM'] == 'linux2' and root_build_dir[0]==os.sep:
-    makesrna = makesrna_tool.Program (target = root_build_dir+'/makesrna', source = source_files, LIBS=['bf_guardedalloc', 'bf_dna'])
+       makesrna = makesrna_tool.Program (target = targetpath, source = source_files, LIBS=['bf_guardedalloc', 'bf_dna'])
 else:
-    makesrna = makesrna_tool.Program (target = '#'+root_build_dir+'/makesrna', source = source_files, LIBS=['bf_guardedalloc', 'bf_dna'])
+       makesrna = makesrna_tool.Program (target = targetpath, source = source_files, LIBS=['bf_guardedalloc', 'bf_dna'])
 
 rna_dict = rna.Dictionary()
-rna.Depends ('rna.c', makesrna)
+rna.Depends (generated_files, makesrna)
+
+# this seems bad, how to retrieve it from scons?
+build_dir = root_build_dir + os.sep +'source' + os.sep + 'blender' + os.sep + 'makesrna' + os.sep + 'intern' + os.sep
+
 if env['OURPLATFORM'] != 'linuxcross':
-    rna.Command ('rna.c', '', root_build_dir+os.sep+"makesrna $TARGET")
+       if env['OURPLATFORM'] in ('win32-vc', 'win64-vc', 'win32-mingw'):
+               rna.Command (generated_files, '', "\"" + root_build_dir+os.sep+"makesrna.exe\" \""  + build_dir )
+       else:
+               rna.Command (generated_files, '', root_build_dir+os.sep+"makesrna "  + build_dir)
 else:
-    rna.Command ('rna.c', '', root_build_dir+os.sep+"makesrna.exe $TARGET")
-obj = ['intern/rna.c', 'intern/rna_access.c', 'intern/rna_dependency.c']
+       rna.Command (generated_files, '', root_build_dir+os.sep+"makesrna.exe "  + build_dir)
+       
+       if USE_WINE:
+               rna.Command (generated_files, '', 'wine ' + root_build_dir+os.sep+"makesrna.exe "  + build_dir)
+       else:
+               rna.Command (generated_files, '', root_build_dir+os.sep+"makesrna.exe "  + build_dir)
+
+
+obj = ['intern/rna_access.c']
+for generated_file in generated_files:
+       obj += ['intern/' + generated_file]
+
 Return ('obj')