[Python-ogre-commit] SF.net SVN: python-ogre: [375] trunk/python-ogre
Brought to you by:
andy_miller,
roman_yakovenko
|
From: <and...@us...> - 2007-09-12 13:40:20
|
Revision: 375
http://python-ogre.svn.sourceforge.net/python-ogre/?rev=375&view=rev
Author: andy_miller
Date: 2007-09-12 06:40:08 -0700 (Wed, 12 Sep 2007)
Log Message:
-----------
General updates for 1.1 release
Support for latest Quickgui and NXogre (from their SVN's)
Initial wrapping for navi GUI -- not yet complete however works 'ok'
Modified Paths:
--------------
trunk/python-ogre/PythonOgreConfig_nt.py
trunk/python-ogre/code_generators/nxogre/generate_code.py
trunk/python-ogre/code_generators/nxogre/python_nxogre_aliases.h
trunk/python-ogre/code_generators/quickgui/generate_code.py
trunk/python-ogre/environment.py
trunk/python-ogre/scripts/MakeRelease.bat
trunk/python-ogre/setup.py
Added Paths:
-----------
trunk/python-ogre/code_generators/navi/
trunk/python-ogre/code_generators/navi/NxOgre.log.html
trunk/python-ogre/code_generators/navi/customization_data.py
trunk/python-ogre/code_generators/navi/generate_code.py
trunk/python-ogre/code_generators/navi/hand_made_wrappers.py
trunk/python-ogre/code_generators/navi/python_navi.h
trunk/python-ogre/code_generators/navi/python_navi_aliases.h
trunk/python-ogre/code_generators/navi/python_navi_sizeof.h
trunk/python-ogre/code_generators/navi/register_exceptions.py
trunk/python-ogre/scripts/MakeSnapShot.bat
trunk/python-ogre/scripts/PythonOgreInstallCreator.iss.1.0
trunk/python-ogre/scripts/PythonOgreInstallCreator.iss.org
trunk/python-ogre/scripts/UpdateDLLs.bat
Removed Paths:
-------------
trunk/python-ogre/scripts/PythonOgreInstallCreator.iss
Modified: trunk/python-ogre/PythonOgreConfig_nt.py
===================================================================
--- trunk/python-ogre/PythonOgreConfig_nt.py 2007-09-06 10:19:05 UTC (rev 374)
+++ trunk/python-ogre/PythonOgreConfig_nt.py 2007-09-12 13:40:08 UTC (rev 375)
@@ -47,7 +47,9 @@
PATH_ffmpeg= os.path.join(BASE_DIR, 'ffmpeg')
PATH_ogredshow = os.path.join(root_dir, 'ThirdParty','dshow')
PATH_plib = os.path.join(BASE_DIR, 'plib')
+PATH_navi = os.path.join(BASE_DIR, 'navi','Navi')
+
#
# it's time for the SDK version
if SDK:
@@ -96,6 +98,7 @@
PATH_LIB_ffmpeg= os.path.join(PATH_ffmpeg, 'lib')
PATH_LIB_ogredshow = PATH_ogredshow
PATH_LIB_plib = PATH_plib
+PATH_LIB_navi= os.path.join(PATH_navi, 'lib')
if SDK:
PATH_LIB_Ogre_CEGUIRenderer = os.path.join( PATH_Ogre, 'lib')
@@ -138,6 +141,7 @@
PATH_INCLUDE_ffmpeg = os.path.join (PATH_ffmpeg,'include')
PATH_INCLUDE_ogredshow = PATH_ogredshow
PATH_INCLUDE_plib = PATH_plib
+PATH_INCLUDE_navi = os.path.join (PATH_navi,'include')
PATH_INCLUDE_OggVorbisTheora = [ os.path.join(BASE_DIR,'ogg','include')
,os.path.join(BASE_DIR, 'vorbis', 'include')
Added: trunk/python-ogre/code_generators/navi/NxOgre.log.html
===================================================================
--- trunk/python-ogre/code_generators/navi/NxOgre.log.html (rev 0)
+++ trunk/python-ogre/code_generators/navi/NxOgre.log.html 2007-09-12 13:40:08 UTC (rev 375)
@@ -0,0 +1,29 @@
+<html>
+ <head>
+ <title>NxOgre Log - NxOgre 0.9-28</title>
+ <style>
+ body {background:#121212;color:white;font-family:Helvetica,sans-serif;font-size:80%;padding-top:1em;}
+ h2 {font-size:145%;margin:0;padding:0;color:#999;}
+ h2 small {padding-left:1em;}
+ div.log {width:75%;margin:0 auto 2em auto;padding:1em 2em 2em 1em;border-left:2px solid #333;background-color:#181818;}
+ div.conflict {border-left:2px solid hotpink;}
+ div.error {border-left:2px solid red;}
+ div.error h2{color:orangered}
+ div.leak {border-left:2px solid orangered;}
+ div.debug {border-left:2px solid #333;}
+ div.debug h2 {font-size:125%;color:#444;}
+ div.warning {border-left:2px solid SaddleBrown;}
+ span.item{font-size:85%;background:red;}
+ small {font-size:95%;color:#333;}
+ div.et0{border-left:2px solid red;}
+ div.et99{}
+ pre {font-size:1.1em;padding:0.5em 0 0 0;margin:0;overflow:auto;}
+ h1 {background: url("") top center no-repeat;padding-top:85px;text-align:center;font-size:1.2em;}
+ a#jump {position:absolute;top:0.5em;right:0.5em;color:white;text-decoration:none;}
+ a#jump:hover {text-decoration:underline;}
+ h5 {width:80%;margin:0 auto 2em auto;padding:1.25em 0 0.25em 0;border-bottom:2px solid red;text-align:center;}
+ div#e {width:90%;margin:0 auto 2em auto;padding:1.25em 0 0 0;font-size:0.9em;text-align:center;}
+ div#key {margin:0 auto 2em auto;display:table;font-size:0.75em;} div#key span{display:table-cell;margin-left:24px;width:12px;height:1em;font-size:1px;border-left:32px solid #121212;border-right:8px solid #121212;} </style>
+ </head>
+<body>
+<h1>Log<br /><small>NxOgre 0.9-28</small></h1><a href="#bottom" id="jump">Jump to bottom</a><div id="key"><span style="background-color:#333;"> </span> Debug <span style="background-color:Indigo;"> </span> Warning<span style="background-color:hotpink;"> </span> Conflict<span style="background-color: red;"> </span> Error <span style="background-color: orangered;"> </span> Leaks</div>
Added: trunk/python-ogre/code_generators/navi/customization_data.py
===================================================================
--- trunk/python-ogre/code_generators/navi/customization_data.py (rev 0)
+++ trunk/python-ogre/code_generators/navi/customization_data.py 2007-09-12 13:40:08 UTC (rev 375)
@@ -0,0 +1,9 @@
+
+def header_files( version ):
+ return [ 'navi.h'
+
+ ]
+
+def huge_classes( version ):
+ return []
+
\ No newline at end of file
Added: trunk/python-ogre/code_generators/navi/generate_code.py
===================================================================
--- trunk/python-ogre/code_generators/navi/generate_code.py (rev 0)
+++ trunk/python-ogre/code_generators/navi/generate_code.py 2007-09-12 13:40:08 UTC (rev 375)
@@ -0,0 +1,517 @@
+#!/usr/bin/env python
+# -----------------------------------------------------------------------------
+# This source file is part of Python-Ogre and is covered by the LGPL
+# For the latest info, see http://python-ogre.org/
+#
+# -----------------------------------------------------------------------------
+
+
+import os, sys, time, shutil
+
+#add environment to the path
+sys.path.append( os.path.join( '..', '..' ) )
+#add common utils to the pass
+sys.path.append( '..' )
+sys.path.append( '.' )
+
+import environment
+import common_utils
+import customization_data
+import hand_made_wrappers
+import register_exceptions
+
+from pygccxml import parser
+from pygccxml import declarations
+from pyplusplus import messages
+from pyplusplus import module_builder
+from pyplusplus import decl_wrappers
+
+from pyplusplus import function_transformers as ft
+from pyplusplus.module_builder import call_policies
+from pyplusplus.module_creator import sort_algorithms
+
+import common_utils.extract_documentation as exdoc
+import common_utils.var_checker as varchecker
+import common_utils.ogre_properties as ogre_properties
+
+MAIN_NAMESPACE = 'NaviLibrary'
+
+## small helper function
+def docit ( general, i, o ):
+ docs = "Python-Ogre Modified Function Call\\n" + general +"\\n"
+ docs = docs + "Input: " + i + "\\n"
+ docs = docs + "Output: " + o + "\\n\\\n"
+ return docs
+
+############################################################
+##
+## Here is where we manually exclude stuff
+##
+############################################################
+
+def ManualExclude ( mb ):
+ global_ns = mb.global_ns
+ main_ns = global_ns.namespace( MAIN_NAMESPACE )
+
+ # things not yet implemented in the C source..
+ excludes=[]
+ for c in main_ns.classes():
+ for m in c.member_functions(allow_empty=True):
+ for e in excludes:
+ if e in m.decl_string:
+ m.exclude()
+
+ ### Member Functions
+ excludes=[ '::NaviLibrary::NaviDataValue::isEmpty'
+ ,'::NaviLibrary::NaviDataValue::isNumber' ## inline functions
+ ]
+ for e in excludes:
+ print "excluding ", e
+ main_ns.member_functions(e).exclude()
+
+ ### Free Functions
+ excludes = []
+ for e in excludes:
+ main_ns.free_functions(e).exclude()
+
+ ## Classes
+ excludes = []
+ for e in excludes:
+ main_ns.class_(e).exclude()
+
+
+ ## I have a challenge that Py++ doesn't recognise these classes by full name (perhaps because they are structs?)
+ ## so I have to look through and match on a class by class basis
+ excludeName = []
+ for c in main_ns.classes():
+ if c.name in excludeName:
+ c.exclude()
+
+ ### Variables
+ excludes = []
+ for e in excludes:
+ main_ns.variable(e).exclude()
+
+ ### Typedefs
+ excludes = []
+ for e in excludes:
+ main_ns.typedefs(e).exclude()
+
+ ### Operators
+ excludes=[]
+ for e in excludes:
+ main_ns.operators(e).exclude()
+
+ main_ns.class_('::NaviLibrary::NaviDataValue').constructor(arg_types=['bool']).exclude()
+# ### Constructors
+# for c in main_ns.class_('NaviDataValue').constructor(arg_types=['bool']): ## these hide the working constructors
+# for a in c.arguments:
+# if 'NxVec3' in a.type.decl_string or 'NxQuat' in a.type.decl_string:
+# c.exclude()
+# break
+
+
+############################################################
+##
+## And there are things that manually need to be INCLUDED
+##
+############################################################
+
+def ManualInclude ( mb ):
+ global_ns = mb.global_ns
+ main_ns = global_ns.namespace( MAIN_NAMESPACE )
+
+ includes=[]
+ ### Free Functions
+ for e in includes:
+ main_ns.free_functions(e).include()
+
+############################################################
+##
+## And things that need manual fixes, but not necessarly hand wrapped
+##
+############################################################
+def ManualFixes ( mb ):
+
+ global_ns = mb.global_ns
+
+
+############################################################
+##
+## And things that need to have their argument and call values fixed.
+## ie functions that pass pointers in the argument list and of course we need
+## to read the updated values - so instead we pass them back
+## as new values in a tuple (ETC ETC)
+##
+############################################################
+
+def ManualTransformations ( mb ):
+ def _ReturnUnsignedInt( type_ ):
+ """helper to return an UnsignedInt call for tranformation functions
+ """
+ return declarations.cpptypes.unsigned_int_t()
+
+ global_ns = mb.global_ns
+ main_ns = global_ns.namespace( MAIN_NAMESPACE )
+
+ def create_output( size ):
+ return [ ft.output( i ) for i in range( size ) ]
+
+
+###############################################################################
+##
+## Now for the AUTOMATIC stuff that should just work
+##
+###############################################################################
+
+
+def AutoExclude( mb ):
+ """ Automaticaly exclude a range of things that don't convert well from C++ to Python
+ """
+ global_ns = mb.global_ns
+ main_ns = global_ns.namespace( MAIN_NAMESPACE )
+
+ # vars that are static consts but have their values set in the header file are bad
+ Remove_Static_Consts ( main_ns )
+
+ ## Exclude protected and private that are not pure virtual
+ query = ~declarations.access_type_matcher_t( 'public' ) \
+ & ~declarations.virtuality_type_matcher_t( declarations.VIRTUALITY_TYPES.PURE_VIRTUAL )
+ non_public_non_pure_virtual = main_ns.calldefs( query )
+ non_public_non_pure_virtual.exclude()
+
+ #Virtual functions that return reference could not be overriden from Python
+ query = declarations.virtuality_type_matcher_t( declarations.VIRTUALITY_TYPES.VIRTUAL ) \
+ & declarations.custom_matcher_t( lambda decl: declarations.is_reference( decl.return_type ) )
+ try:
+ main_ns.calldefs( query ).virtuality = declarations.VIRTUALITY_TYPES.NOT_VIRTUAL
+ except:
+ pass
+
+def AutoInclude( mb ):
+ global_ns = mb.global_ns
+ main_ns = global_ns.namespace( MAIN_NAMESPACE )
+
+
+def AutoFixes ( mb ):
+ """ now we fix a range of things automatically - typically by going through
+ the entire name space trying to guess stuff and fix it:)
+ """
+ global_ns = mb.global_ns
+ main_ns = global_ns.namespace( MAIN_NAMESPACE )
+
+ # arguments passed as refs but not const are not liked by boost
+ #Fix_Ref_Not_Const ( main_ns )
+
+ # Functions that have void pointers in their argument list need to change to unsigned int's
+ Fix_Void_Ptr_Args ( main_ns )
+
+ # and change functions that return a variety of pointers to instead return unsigned int's
+ Fix_Pointer_Returns ( main_ns )
+
+ # functions that need to have implicit conversions turned off
+ Fix_Implicit_Conversions ( main_ns)
+
+ if os.name =='nt':
+ Fix_NT( mb )
+ elif os.name =='posix':
+ Fix_Posix( mb )
+
+
+###############################################################################
+##
+## here are the helper functions that do much of the work
+##
+###############################################################################
+def Fix_Posix ( mb ):
+ """ fixup for posix specific stuff -- note only expect to be called on a posix machine
+ """
+ ## we could do more here if need be...
+ if sys.platform == 'darwin':
+ pass
+ elif sys.platform.startswith ('linux'):
+ pass
+
+
+def Fix_NT ( mb ):
+ """ fixup for NT systems
+ """
+
+
+def Fix_Implicit_Conversions ( mb ):
+ """By default we disable explicit conversion, however sometimes it makes sense
+ """
+ pass
+
+def Add_Auto_Conversions( mb ):
+ pass
+
+
+def Set_Call_Policies( mb ):
+ """ set the return call policies on classes that this hasn't already been done for.
+ Set the default policy to deal with pointer/reference return types to reference_existing object
+ """
+ mem_funs = mb.calldefs ()
+ mem_funs.create_with_signature = True #Generated code will not compile on
+ #MSVC 7.1 if function has throw modifier.
+ for mem_fun in mem_funs:
+ if mem_fun.call_policies:
+ continue
+ if not mem_fun.call_policies and \
+ (declarations.is_reference (mem_fun.return_type) or declarations.is_pointer (mem_fun.return_type) ):
+ mem_fun.call_policies = call_policies.return_value_policy(
+ call_policies.reference_existing_object )
+
+
+def Set_Exception(mb):
+ pass
+ #~ """We don't exclude Exception, because it contains functionality, that could
+ #~ be useful to user. But, we will provide automatic exception translator
+ #~ """
+ #~ Exception = mb.namespace( 'Ogre' ).class_( 'Exception' )
+ #~ Exception.include()
+ #~ Exception.mem_fun('what').exclude() # declared with empty throw
+ #~ Exception.mem_fun('getNumber').exclude() # declared with empty throw
+ #~ Exception.translate_exception_to_string( 'PyExc_RuntimeError', 'exc.getFullDescription().c_str()' )
+
+
+def _ReturnUnsignedInt( type_ ):
+ """helper to return an UnsignedInt call for tranformation functions
+ """
+ return declarations.cpptypes.unsigned_int_t()
+
+def Fix_Void_Ptr_Args ( mb ):
+ """ we modify functions that take void *'s in their argument list to instead take
+ unsigned ints, which allows us to use CTypes buffers
+ """
+ for fun in mb.member_functions():
+ arg_position = 0
+ for arg in fun.arguments:
+ if declarations.type_traits.is_void_pointer(arg.type) or arg.type.decl_string == "void const *":
+ fun.add_transformation( ft.modify_type(arg_position,_ReturnUnsignedInt ), alias=fun.name )
+ fun.documentation = docit ("Modified Input Argument to work with CTypes",
+ "Argument "+arg.name+ "(pos:" + str(arg_position)\
+ +") takes a CTypes.adddressof(xx)", "...")
+ print "Fixed Void Ptr", fun, arg_position
+ break
+ arg_position +=1
+
+ ## lets go and look for stuff that might be a problem
+ pointee_types=['unsigned int',' int ', ' float ', ' Real ', 'uchar', 'uint8',
+ 'unsigned char']
+
+ function_names=[]
+ for fun in mb.member_functions():
+ if fun.documentation or fun.ignore: continue ## means it's been tweaked somewhere else
+ for n in function_names:
+ if n in fun.name:
+ print "CHECK :", fun
+ break
+ arg_position = 0
+ for arg in fun.arguments:
+ if declarations.is_pointer(arg.type): ## and "const" not in arg.type.decl_string:
+ for i in pointee_types:
+ if i in arg.type.decl_string:
+ print '"',arg.type.decl_string, '"'
+ print "CHECK ", fun, str(arg_position)
+ fun.documentation=docit("SUSPECT - MAYBE BROKEN", "....", "...")
+ break
+ arg_position +=1
+
+## NEED To do the same for constructors
+ for fun in mb.constructors():
+ arg_position = 0
+ for arg in fun.arguments:
+ if declarations.is_pointer(arg.type): ## and "const" not in arg.type.decl_string:
+ for i in pointee_types:
+ if i in arg.type.decl_string:
+ print '"',arg.type.decl_string, '"'
+ print "Excluding: ", fun
+ fun.exclude()
+ break
+ arg_position +=1
+
+def Fix_Pointer_Returns ( mb ):
+ """ Change out functions that return a variety of pointer to base types and instead
+ have them return the address the pointer is pointing to (the pointer value)
+ This allow us to use CTypes to handle in memory buffers from Python
+
+ Also - if documentation has been set then ignore the class/function as it means it's been tweaked else where
+ """
+ pointee_types=['unsigned int','int', 'float', 'unsigned char']
+ known_names=[] # these are function names we know it's cool to exclude
+ for fun in mb.member_functions():
+ if declarations.is_pointer (fun.return_type) and not fun.documentation:
+ for i in pointee_types:
+ if fun.return_type.decl_string.startswith ( i ) and not fun.documentation:
+ if not fun.name in known_names:
+ print "Excluding (function):", fun, "as it returns (pointer)", i
+ fun.exclude()
+ for fun in mb.member_operators(allow_empty=True):
+ if declarations.is_pointer (fun.return_type) and not fun.documentation:
+ for i in pointee_types:
+ if fun.return_type.decl_string.startswith ( i ) and not fun.documentation:
+ print "Excluding (operator):", fun
+ fun.exclude()
+
+
+
+def query_containers_with_ptrs(decl):
+ if not isinstance( decl, declarations.class_types ):
+ return False
+ if not decl.indexing_suite:
+ return False
+ return declarations.is_pointer( decl.indexing_suite.element_type )
+
+
+def Remove_Static_Consts ( mb ):
+ """ linux users have compile problems with vars that are static consts AND have values set in the .h files
+ we can simply leave these out """
+ checker = varchecker.var_checker()
+ for var in mb.vars():
+ if type(var.type) == declarations.cpptypes.const_t:
+ if checker( var ):
+ print "Excluding static const ", var
+ var.exclude()
+
+#
+# the 'main'function
+#
+def generate_code():
+# messages.disable(
+# # Warnings 1020 - 1031 are all about why Py++ generates wrapper for class X
+# messages.W1020
+# , messages.W1021
+# , messages.W1022
+# , messages.W1023
+# , messages.W1024
+# , messages.W1025
+# , messages.W1026
+# , messages.W1027
+# , messages.W1028
+# , messages.W1029
+# , messages.W1030
+# , messages.W1031
+# , messages.W1035
+# , messages.W1040
+# , messages.W1038
+# , messages.W1039
+# , messages.W1041
+# , messages.W1036 # pointer to Python immutable member
+# , messages.W1033 # unnamed variables
+# , messages.W1018 # expose unnamed classes
+# , messages.W1049 # returns reference to local variable
+# , messages.W1014 # unsupported '=' operator
+# )
+ #
+ # Use GCCXML to create the controlling XML file.
+ # If the cache file (../cache/*.xml) doesn't exist it gets created, otherwise it just gets loaded
+ # NOTE: If you update the source library code you need to manually delete the cache .XML file
+ #
+ xml_cached_fc = parser.create_cached_source_fc(
+ os.path.join( environment.navi.root_dir, "python_navi.h" )
+ , environment.navi.cache_file )
+
+ defined_symbols = [ 'OGRE_NONCLIENT_BUILD', 'OGRE_GCC_VISIBILITY']
+ if environment._USE_THREADS:
+ defined_symbols.append('BOOST_HAS_THREADS')
+ defined_symbols.append('BOOST_HAS_WINTHREADS')
+ defined_symbols.append( 'VERSION_' + environment.navi.version )
+
+ undefined_symbols = []
+ #
+ # build the core Py++ system from the GCCXML created source
+ #
+ mb = module_builder.module_builder_t( [ xml_cached_fc ]
+ , gccxml_path=environment.gccxml_bin
+ , working_directory=environment.root_dir
+ , include_paths=environment.navi.include_dirs
+ , define_symbols=defined_symbols
+ , indexing_suite_version=2
+ , cflags=environment.navi.cflags
+ )
+ # NOTE THE CHANGE HERE
+ mb.constructors().allow_implicit_conversion = False
+ mb.register_module_dependency ( environment.ogre.generated_dir )
+
+ mb.BOOST_PYTHON_MAX_ARITY = 25
+ mb.classes().always_expose_using_scope = True
+
+ #
+ # We filter (both include and exclude) specific classes and functions that we want to wrap
+ #
+ global_ns = mb.global_ns
+ global_ns.exclude()
+ main_ns = global_ns.namespace( MAIN_NAMESPACE )
+ main_ns.include()
+
+
+ AutoExclude ( mb )
+ ManualExclude ( mb )
+ AutoInclude ( mb )
+ ManualInclude ( mb )
+ # here we fixup functions that expect to modifiy their 'passed' variables
+ ManualTransformations ( mb )
+
+ AutoFixes ( mb )
+ ManualFixes ( mb )
+
+
+ #
+ # We need to tell boost how to handle calling (and returning from) certain functions
+ #
+ Set_Call_Policies ( mb.global_ns )
+
+ #
+ # the manual stuff all done here !!!
+ #
+ hand_made_wrappers.apply( mb )
+
+ NoPropClasses = [""]
+ for cls in main_ns.classes():
+ if cls.name not in NoPropClasses:
+ cls.add_properties( recognizer=ogre_properties.ogre_property_recognizer_t() )
+
+ common_utils.add_constants( mb, { 'PROJECT_version' : '"%s"' % environment.navi.version.replace("\n", "\\\n")
+ , 'python_version' : '"%s"' % sys.version.replace("\n", "\\\n" ) } )
+
+ ## need to create a welcome doc string for this...
+ common_utils.add_constants( mb, { '__doc__' : '"Navi PROJECT DESCRIPTION"' } )
+
+
+ ##########################################################################################
+ #
+ # Creating the code. After this step you should not modify/customize declarations.
+ #
+ ##########################################################################################
+ extractor = exdoc.doc_extractor("") # I'm excluding the UTFstring docs as lots about nothing
+ mb.build_code_creator (module_name='_navi_' , doc_extractor= extractor )
+
+ for inc in environment.navi.include_dirs:
+ mb.code_creator.user_defined_directories.append(inc )
+ mb.code_creator.user_defined_directories.append( environment.navi.generated_dir )
+ mb.code_creator.replace_included_headers( customization_data.header_files( environment.navi.version ) )
+
+ huge_classes = map( mb.class_, customization_data.huge_classes( environment.navi.version ) )
+
+ mb.split_module(environment.navi.generated_dir, huge_classes,use_files_sum_repository=False)
+
+ ## now we need to ensure a series of headers and additional source files are
+ ## copied to the generaated directory..
+ additional_files = []
+ paths = []
+
+ for p in paths:
+ additional_files = os.listdir(p)
+ for f in additional_files:
+ if f.endswith('cpp') or f.endswith('.h'):
+ sourcefile = os.path.join(p, f)
+ destfile = os.path.join(environment.navi.generated_dir, f )
+
+ if not common_utils.samefile( sourcefile ,destfile ):
+ shutil.copy( sourcefile, environment.navi.generated_dir )
+ print "Updated ", f, "as it was missing or out of date"
+if __name__ == '__main__':
+ start_time = time.clock()
+ generate_code()
+ print 'Source code was updated( %f minutes ).' % ( ( time.clock() - start_time )/60 )
Added: trunk/python-ogre/code_generators/navi/hand_made_wrappers.py
===================================================================
--- trunk/python-ogre/code_generators/navi/hand_made_wrappers.py (rev 0)
+++ trunk/python-ogre/code_generators/navi/hand_made_wrappers.py 2007-09-12 13:40:08 UTC (rev 375)
@@ -0,0 +1,72 @@
+import os
+import environment
+
+
+WRAPPER_DEFINITION_NaviManager = \
+"""
+class EventCallback
+{
+public:
+ EventCallback(PyObject* subscriber, std::string const & method)
+ {
+ mSubscriber = subscriber;
+ mMethod = method;
+ }
+
+ void call(const NaviLibrary::NaviData &naviData)
+ {
+ if (mMethod.length() > 0 ) {
+ boost::python::call_method<void>(mSubscriber, mMethod.c_str(),
+ static_cast<const NaviLibrary::NaviData&>(naviData) );
+ }
+ else
+ boost::python::call<void>(mSubscriber,
+ static_cast<const NaviLibrary::NaviData&>(naviData) );
+ }
+ PyObject* mSubscriber;
+ std::string mMethod;
+};
+
+
+
+void NaviManager_bind(NaviLibrary::NaviManager &me, const std::string &naviName,
+ const std::string &naviDataName,
+ PyObject* subscriber, std::string const & method="",
+ boost::python::list listin= boost::python::list())
+{
+ int index;
+
+ // create a new call back function that knows how to call a python function or class method
+ EventCallback * cb = new EventCallback( subscriber, method);
+
+ // create the necessary Delegate wrapper around this new functions
+ NaviLibrary::NaviDelegate callback = NaviLibrary::NaviDelegate ( cb, &EventCallback::call );
+
+ // we allow a list of strings to be passed in and we convert these to a string vector
+ std::vector<std::string> myVector;
+ for (index=0;index<len(listin);index++ )
+ myVector.push_back ( boost::python::extract<std::string> (listin[index]) );
+
+ // and finally call the bind function to make it all work
+ me.bind(naviName, naviDataName, callback, myVector ) ;
+}
+
+"""
+WRAPPER_REGISTRATION_NaviManager = [
+ """def( "bind", &::NaviManager_bind );"""
+
+]
+
+
+#################################################################################################
+#################################################################################################
+
+def apply_reg ( class_, code ):
+ for c in code:
+ class_.add_registration_code ( c )
+
+def apply( mb ):
+ rt = mb.class_( 'NaviManager' )
+ rt.add_declaration_code( WRAPPER_DEFINITION_NaviManager )
+ apply_reg (rt, WRAPPER_REGISTRATION_NaviManager )
+
\ No newline at end of file
Added: trunk/python-ogre/code_generators/navi/python_navi.h
===================================================================
--- trunk/python-ogre/code_generators/navi/python_navi.h (rev 0)
+++ trunk/python-ogre/code_generators/navi/python_navi.h 2007-09-12 13:40:08 UTC (rev 375)
@@ -0,0 +1,19 @@
+#include "navi.h"
+
+// First we create a magic namespace to hold all our aliases
+namespace pyplusplus { namespace aliases {
+
+ #include "python_navi_aliases.h"
+} }
+
+// then we exposed everything needed (and more) to ensure GCCXML makes them visible to Py++
+//
+namespace python_plib{ namespace details{
+inline void instantiate(){
+ using namespace NaviLibrary;
+
+ #include "python_navi_sizeof.h"
+
+} } }
+
+
Added: trunk/python-ogre/code_generators/navi/python_navi_aliases.h
===================================================================
--- trunk/python-ogre/code_generators/navi/python_navi_aliases.h (rev 0)
+++ trunk/python-ogre/code_generators/navi/python_navi_aliases.h 2007-09-12 13:40:08 UTC (rev 375)
@@ -0,0 +1,5 @@
+typedef NaviLibrary::NaviUtilities::InlineVector<std::basic_string<char, std::char_traits<char>, std::allocator<char> > >\
+ InlineVectorString;
+typedef std::map<std::string, std::string, std::less<std::string>, std::allocator<std::pair<std::string const, std::string> > >\
+ MapStringString;
+typedef std::vector<std::string, std::allocator<std::string> > VectorString;
Added: trunk/python-ogre/code_generators/navi/python_navi_sizeof.h
===================================================================
--- trunk/python-ogre/code_generators/navi/python_navi_sizeof.h (rev 0)
+++ trunk/python-ogre/code_generators/navi/python_navi_sizeof.h 2007-09-12 13:40:08 UTC (rev 375)
@@ -0,0 +1,3 @@
+
+
+
Added: trunk/python-ogre/code_generators/navi/register_exceptions.py
===================================================================
--- trunk/python-ogre/code_generators/navi/register_exceptions.py (rev 0)
+++ trunk/python-ogre/code_generators/navi/register_exceptions.py 2007-09-12 13:40:08 UTC (rev 375)
@@ -0,0 +1,137 @@
+import os
+import environment
+from string import Template
+
+base_exception = \
+"""
+class OgreException(Exception):
+ def __init__( self, app_error ):
+ Exception.__init__( self )
+ self._pimpl = app_error
+
+ def __str__( self ):
+ return self._pimpl.getFullDescription()
+
+ def __getattribute__(self, attr):
+ my_pimpl = super(OgreException, self).__getattribute__("_pimpl")
+ try:
+ return getattr(my_pimpl, attr)
+ except AttributeError:
+ return super(OgreException,self).__getattribute__(attr)
+
+_ogre_.OgreException = OgreException
+#this one for backward compatability
+_ogre_.Exception = OgreException
+_ogre_._Exception_.py_err_class = OgreException
+""".strip()
+
+derived_py_exception = \
+"""
+class Ogre${err_class}(OgreException):
+ def __init__( self, app_error ):
+ OgreException.__init__( self, app_error )
+
+ def __getattribute__(self, attr):
+ return super(Ogre${err_class},self).__getattribute__(attr)
+
+_ogre_._${err_class}_.py_err_class = Ogre${err_class}
+_ogre_.Ogre${err_class} = Ogre${err_class}
+""".strip()
+
+register_translator = """${err_class}_exception_translator();"""
+
+exception_translator = \
+"""
+
+struct ${err_class}_exception_translator{
+
+ typedef Ogre::${err_class} exception_type;
+ typedef ${err_class}_exception_translator translator_type;
+
+ ${err_class}_exception_translator(){
+ bp::converter::registry::push_back( &translator_type::convertible
+ , &translator_type::construct
+ , bp::type_id<exception_type>() );
+
+ bp::register_exception_translator<exception_type>(&translator_type::translate);
+ }
+
+ static void
+ translate( const exception_type& err ){
+ bp::object pimpl_err( err );
+ bp::object pyerr_class = pimpl_err.attr( "py_err_class" );
+ bp::object pyerr = pyerr_class( pimpl_err );
+ PyErr_SetObject( pyerr_class.ptr(), bp::incref( pyerr.ptr() ) );
+ }
+
+ //Sometimes, exceptions should be passed back to the library.
+ static void*
+ convertible(PyObject* py_obj){
+ if( 1 != PyObject_IsInstance( py_obj, PyExc_Exception ) ){
+ return 0;
+ }
+
+ if( !PyObject_HasAttrString( py_obj, "_pimpl" ) ){
+ return 0;
+ }
+
+ bp::object pyerr( bp::handle<>( bp::borrowed( py_obj ) ) );
+ bp::object pimpl = bp::getattr( pyerr, "_pimpl" );
+ bp::extract<exception_type> type_checker( pimpl );
+ if( !type_checker.check() ){
+ return 0;
+ }
+ return py_obj;
+ }
+
+ static void
+ construct( PyObject* py_obj, bp::converter::rvalue_from_python_stage1_data* data){
+ typedef bp::converter::rvalue_from_python_storage<exception_type> storage_t;
+
+ bp::object pyerr( bp::handle<>( bp::borrowed( py_obj ) ) );
+ bp::object pimpl = bp::getattr( pyerr, "_pimpl" );
+
+ storage_t* the_storage = reinterpret_cast<storage_t*>( data );
+ void* memory_chunk = the_storage->storage.bytes;
+ exception_type* cpp_err
+ = new (memory_chunk) exception_type( bp::extract<exception_type>(pimpl) );
+
+ data->convertible = memory_chunk;
+ }
+
+};
+""".strip()
+
+def substitute( text, **keywd ):
+ return Template( text ).substitute( **keywd )
+
+def register( mb ):
+ ogre_ns = mb.namespace( 'Ogre' )
+ python_part_code = ['import _ogre_']
+
+ exception = ogre_ns.class_( 'Exception' )
+ exception.include()
+ exception.alias = '_%s_' % exception.name
+ exception.add_declaration_code( substitute( exception_translator, err_class=exception.name ) )
+ exception.add_registration_code( substitute( register_translator, err_class=exception.name ), False )
+ python_part_code.append( base_exception )
+
+ for derived_info in exception.derived:
+ derived = derived_info.related_class
+ derived.include()
+ derived.alias = '_%s_' % derived.name
+ derived.add_declaration_code( substitute( exception_translator, err_class=derived.name ) )
+ derived.add_registration_code( substitute( register_translator, err_class=derived.name ), False )
+ python_part_code.append( substitute( derived_py_exception, err_class=derived.name ) )
+
+ directory_path = environment.ogre.generated_dir
+ ogre_exceptions = os.path.join( directory_path, '_ogre_exceptions_.py' )
+
+ if os.path.exists( directory_path ) and not os.path.isdir(directory_path):
+ raise RuntimeError( 'directory_path should be a path not a file.' )
+ if not os.path.exists( directory_path ):
+ os.makedirs( directory_path )
+
+ f = file( ogre_exceptions, 'w+' )
+ f.write( os.linesep.join( python_part_code ) )
+ f.close()
Modified: trunk/python-ogre/code_generators/nxogre/generate_code.py
===================================================================
--- trunk/python-ogre/code_generators/nxogre/generate_code.py 2007-09-06 10:19:05 UTC (rev 374)
+++ trunk/python-ogre/code_generators/nxogre/generate_code.py 2007-09-12 13:40:08 UTC (rev 375)
@@ -93,6 +93,11 @@
,'::NxOgre::Container<std::string, NxOgre::FluidDrain*>::get'
,'::NxOgre::Container<std::string, NxOgre::FluidDrain*>::getFirst'
,'::NxOgre::Container<std::string, NxOgre::FluidDrain*>::next'
+ ,'::NxOgre::Container<std::string, NxOgre::FluidDrain*>::_begin'
+ ,'::NxOgre::Container<std::string, NxOgre::FluidDrain*>::_next'
+ ,'::NxOgre::Container<std::string, NxOgre::FluidEmitter*>::_begin'
+ ,'::NxOgre::Container<std::string, NxOgre::FluidEmitter*>::_next'
+
,'::NxOgre::Container<std::string, NxOgre::FluidEmitter*>::getFirst'
,'::NxOgre::List<NxOgre::RemoteDebuggerConnection::Camera>::destroyAndEraseAll'
,'::NxOgre::List<NxOgre::RemoteDebuggerConnection::Camera>::dumpToConsole'
@@ -109,20 +114,24 @@
,'::NxOgre::Joint::getBreakableMaxTorque'
,'::NxOgre::Joint::getGlobalAxis'
,'::NxOgre::Joint::setGlobalAxis'
- ,'::NxOgre::Joint::getType'
- ,'::NxOgre::Joint::hasMoreLimitPlanes'
- ,'::NxOgre::Joint::purgeLimitPlanes'
- ,'::NxOgre::Joint::resetLimitPlaneIterator'
- ,'::NxOgre::Joint::addLimitPlane'
- ,'::NxOgre::Joint::setBreakable'
- ,'::NxOgre::Joint::getGlobalAnchor'
- ,'::NxOgre::Joint::setGlobalAnchor'
- ,'::NxOgre::Joint::getState'
- ,'::NxOgre::Joint::getNextLimitPlane'
- ,'::NxOgre::Joint::setLimitPoint'
- ,'::NxOgre::Joint::getLimitPoint'
- ,'::NxOgre::Joint::getActorA'
- ,'::NxOgre::Joint::getActorB'
+# # # ,'::NxOgre::Joint::getType'
+# ,'::NxOgre::Joint::hasMoreLimitPlanes'
+# ,'::NxOgre::Joint::purgeLimitPlanes'
+# ,'::NxOgre::Joint::resetLimitPlaneIterator'
+# ,'::NxOgre::Joint::addLimitPlane'
+# ,'::NxOgre::Joint::setBreakable'
+# ,'::NxOgre::Joint::getGlobalAnchor'
+# ,'::NxOgre::Joint::setGlobalAnchor'
+# ,'::NxOgre::Joint::getState'
+# ,'::NxOgre::Joint::getNextLimitPlane'
+# ,'::NxOgre::Joint::setLimitPoint'
+# ,'::NxOgre::Joint::getLimitPoint'
+# ,'::NxOgre::Joint::getActorA'
+# ,'::NxOgre::Joint::getActorB'
+ ,'::NxOgre::JointParams::setSpring'
+ ,'::NxOgre::JointParams::setMotor'
+ ,'::NxOgre::JointParams::setLimits'
+ ,'::NxOgre::JointParams::setJointProjection'
,'::NxOgre::Scene::addMaterialPairsFromFile'
,'::NxOgre::Scene::addMaterialPair'
,'::NxOgre::Fluid::setName'
@@ -134,6 +143,8 @@
,'::NxOgre::Scene::createPrismaticJoint'
,'::NxOgre::Scene::createFixedJoint'
,'::NxOgre::Scene::save'
+ ,'::NxOgre::Scene::batchDestroyActors'
+ ,'::NxOgre::SimpleIntersection::getResult'
,'::NxOgre::SoftBody::simulate'
,'::NxOgre::SoftBody::render'
,'::NxOgre::PhysXDriver::stop'
@@ -169,6 +180,7 @@
## I have a challenge that Py++ doesn't recognise these classes by full name (perhaps because they are structs?)
## so I have to look through and match on a class by class basis
excludeName = ['Container<NxOgre::Scene::Renderables, float>'
+ ,'Container<std::string,NxOgre::Actor*>'
,'List<NxOgre::CharacterHitReport*>'
,'List<NxOgre::RemoteDebuggerConnection::Camera>'
,'List<NxOgre::Blueprints::ActorBlueprint*>'
Modified: trunk/python-ogre/code_generators/nxogre/python_nxogre_aliases.h
===================================================================
--- trunk/python-ogre/code_generators/nxogre/python_nxogre_aliases.h 2007-09-06 10:19:05 UTC (rev 374)
+++ trunk/python-ogre/code_generators/nxogre/python_nxogre_aliases.h 2007-09-12 13:40:08 UTC (rev 375)
@@ -1,3 +1,6 @@
+typedef std::vector<NxOgre::Joint::LimitPlane,std::allocator<NxOgre::Joint::LimitPlane> > VectorJointLimitPlane;
+typedef std::vector<NxOgre::SimplePlane*,std::allocator<NxOgre::SimplePlane*> > VectorSimplePlane;
+
typedef std::vector<float, std::allocator<float> > VectorFloat;
typedef std::vector<std::string, std::allocator<std::string> > VectorString;
typedef std::list<std::string> stdString;
Modified: trunk/python-ogre/code_generators/quickgui/generate_code.py
===================================================================
--- trunk/python-ogre/code_generators/quickgui/generate_code.py 2007-09-06 10:19:05 UTC (rev 374)
+++ trunk/python-ogre/code_generators/quickgui/generate_code.py 2007-09-12 13:40:08 UTC (rev 375)
@@ -369,8 +369,8 @@
os.path.join( environment.quickgui.root_dir, "python_quickgui.h" )
, environment.quickgui.cache_file )
- defined_symbols = [ 'OGRE_NONCLIENT_BUILD', 'FT2_BUILD_LIBRARY', 'QUICKGUI_EXPORTS',
- 'WIN32', 'NDEBUG', 'WINDOWS' ]
+ defined_symbols = [ 'OGRE_NONCLIENT_BUILD',
+ 'WIN32', 'NDEBUG', 'WINDOWS' ] ## , 'QUICKGUI_EXPORTS'
if environment._USE_THREADS:
defined_symbols.append('BOOST_HAS_THREADS')
defined_symbols.append('BOOST_HAS_WINTHREADS')
@@ -461,17 +461,17 @@
## now we need to ensure a series of headers and additional source files are
## copied to the generated directory..
- additional_files= os.listdir(environment.Config.PATH_INCLUDE_quickgui)
- additional_files=[]
- for f in additional_files:
- if f.endswith('cpp') or f.endswith('.h'):
- sourcefile = os.path.join(environment.Config.PATH_INCLUDE_quickgui, f)
- destfile = os.path.join(environment.quickgui.generated_dir, f )
+ additional_dirs=[environment.Config.PATH_INCLUDE_quickgui,
+ os.path.join(environment.Config.PATH_quickgui,'QuickGUI','src')]
+ for d in additional_dirs:
+ for f in os.listdir(d):
+ if f.endswith('cpp') or f.endswith('.h'):
+ sourcefile = os.path.join(d, f)
+ destfile = os.path.join(environment.quickgui.generated_dir, f )
+ if not common_utils.samefile( sourcefile ,destfile ):
+ shutil.copy( sourcefile, environment.quickgui.generated_dir )
+ print "Updated ", f, "as it was missing or out of date"
- if not common_utils.samefile( sourcefile ,destfile ):
- shutil.copy( sourcefile, environment.quickgui.generated_dir )
- print "Updated ", f, "as it was missing or out of date"
-
if __name__ == '__main__':
start_time = time.clock()
generate_code()
Modified: trunk/python-ogre/environment.py
===================================================================
--- trunk/python-ogre/environment.py 2007-09-06 10:19:05 UTC (rev 374)
+++ trunk/python-ogre/environment.py 2007-09-12 13:40:08 UTC (rev 375)
@@ -103,15 +103,64 @@
######################
## Hopefully we can make the rest of this 'automagic' ##
+class Default:
+ version = ""
+ pythonModule = False
+ moduleName = ""
+ myHome = ""
+ myLibraryPaths = [ ]
+ myLibraries = [ ]
+ parent = None
+ children = []
+ codeGenerationFlags=[]
+ dependsOn = []
+ compileFlags = []
+ linkFlags= []
+ includePaths = []
+ myIncludes = []
+ libaries = myLibraries # a list of the libraries I need plus
+ mySource = [] # where to get the source - tuples, {'svn|cvs|ftp|http','utl'}
+ myBuildCmds = [] # commands to build the library with
######################
-
+class boost:
+ version = "3.4"
+ pythonModule = False
+ moduleName = ""
+ myHome = 'boost'
+ myLibraryPaths = [ 'boost/bin.v2/libs/python2.5/build/msvc-8.0/release/threading-multi' ]
+ myLibraries = [ 'boost_python-vc80-mt-1_35']
+
+ parent = None
+ children = []
+ codeGenerationFlags=[]
+ dependsOn = []
+ compileFlags = []
+ linkFlags= []
+ includePaths = []
+ myIncludes = []
+ libaries = myLibraries # a list of the libraries I need plus
+ mySource = ['http://prdownloads.sourceforge.net/boost/boost-jam-3.1.13-1-linuxx86.tgz',
+ 'http://downloads.sourceforge.net/boost/boost_1_34_0.tar.bz2'] # where to get the source - tuples, {'svn|cvs|ftp|http','utl'}
+ myBuildCmds = [] # commands to build the library with
+
class ogre:
active = True
- version = "1.4" # "1.2"
+ pythonModule = True
+ version = "1.4"
+ myName='ogre'
+ moduleName='OGRE'
cflags = ""
- parent = "ogre/renderer"
- ModuleName = 'OGRE'
+ moduleParentLocation = "renderer"
+ dependsOn = ['boost']
+ myLibraryPaths = []
+ myLibraries = ['OgreMain']
+ libraries = myLibraries
+
+# for mod in dependsOn:
+# libraries += mod.libraries
+#
+
if os.name =='nt':
libs=[Config.LIB_Boost, 'OgreMain' ] #, 'OgreGUIRenderer', 'CEGUIBase']
lib_dirs = [ Config.PATH_LIB_Boost
@@ -335,7 +384,7 @@
class quickgui:
version="0.9.6"
parent="ogre/gui"
- CCFLAGS = ' /D "WIN32" /D "NDEBUG", /D "WINDOWS" /D "OGRE_PLATFORM_WIN32"' # /D "FT2_BUILD_LIBRARY"
+ CCFLAGS = ' /D "WIN32" /D "NDEBUG", /D "WINDOWS"' ###/D "OGRE_PLATFORM_WIN32"' # /D "FT2_BUILD_LIBRARY"
cflags=""
include_dirs = [ Config.PATH_Boost,
Config.PATH_INCLUDE_Ogre,
@@ -343,14 +392,35 @@
#,Config.PATH_INCLUDE_freetype
]
lib_dirs = [Config.PATH_LIB_Boost,
- Config.PATH_LIB_Ogre_OgreMain,
- Config.PATH_LIB_quickgui
+ Config.PATH_LIB_Ogre_OgreMain
+ ##,Config.PATH_LIB_quickgui
]
CheckIncludes=[]
- libs=[ Config.LIB_Boost, 'OgreMain', 'QuickGUI' ]
+ libs=[ Config.LIB_Boost, 'OgreMain' ]
ModuleName="quickgui"
active=True
+class navi:
+ version="0.9"
+ parent="ogre/gui"
+ CCFLAGS = '/D "WIN32" /D "NDEBUG", /D "WINDOWS"'
+ cflags=""
+ include_dirs = [ Config.PATH_Boost
+ ,Config.PATH_INCLUDE_Ogre
+ ,Config.PATH_INCLUDE_navi
+ ,os.path.join(Config.PATH_navi,'..','Dependencies','win32','llmozlib','include')
+ ]
+ lib_dirs = [Config.PATH_LIB_Boost,
+ Config.PATH_LIB_Ogre_OgreMain
+ ,Config.PATH_LIB_navi
+ ,os.path.join(Config.PATH_navi,'..','Dependencies','win32','llmozlib','lib')
+ ]
+ CheckIncludes=[]
+ libs=[ Config.LIB_Boost, 'Navi', 'OgreMain','llmozlib', 'user32',
+ 'kernel32.lib', 'gdi32.lib', 'winspool.lib', 'comdlg32.lib', 'advapi32.lib',
+ 'shell32.lib','ole32.lib','oleaut32.lib','uuid.lib' ]
+ ModuleName="navi"
+ active=True
class betagui:
version="0.16"
@@ -558,6 +628,7 @@
, 'ogrevideoffmpeg' : ogrevideoffmpeg
, 'ogredshow' : ogredshow
, 'plib' : plib
+ , 'navi': navi
#, 'raknet' : raknet
}
Modified: trunk/python-ogre/scripts/MakeRelease.bat
===================================================================
--- trunk/python-ogre/scripts/MakeRelease.bat 2007-09-06 10:19:05 UTC (rev 374)
+++ trunk/python-ogre/scripts/MakeRelease.bat 2007-09-12 13:40:08 UTC (rev 375)
@@ -26,6 +26,7 @@
del ..\..\PythonOgreRelease\1 /s
del ..\..\PythonOgreRelease\2 /s
del ..\..\PythonOgreRelease\ogre.cfg /s
+for /r ..\..\PythonOgreRelease\ %1 in (*) do touch %1
rem rmdir /s /q ..\..\PythonOgreRelease\demos\gui\tofix
rem rmdir /s /q ..\..\PythonOgreRelease\demos\ogre\tofix
Added: trunk/python-ogre/scripts/MakeSnapShot.bat
===================================================================
--- trunk/python-ogre/scripts/MakeSnapShot.bat (rev 0)
+++ trunk/python-ogre/scripts/MakeSnapShot.bat 2007-09-12 13:40:08 UTC (rev 375)
@@ -0,0 +1,31 @@
+rem echo off
+echo
+echo ====== Python-Ogre Snap Shot ======
+echo =
+rmdir /s /q ..\..\PythonOgreSnapShot
+mkdir ..\..\PythonOgreSnapShot\packages_2.5
+mkdir ..\..\PythonOgreSnapShot\plugins
+mkdir ..\..\PythonOgreSnapShot\demos
+mkdir ..\..\PythonOgreSnapShot\ThirdParty
+mkdir ..\..\PythonOgreSnapShot\Tools
+mkdir ..\..\PythonOgreSnapShot\docs
+xcopy ..\packages_2.5 ..\..\PythonOgreSnapShot\packages_2.5 /s
+xcopy ..\plugins ..\..\PythonOgreSnapShot\plugins
+copy ..\*.rtf ..\..\PythonOgreSnapShot
+copy ..\COPYING ..\..\PythonOgreSnapShot
+copy ..\*.gpl ..\..\PythonOgreSnapShot
+copy ..\setup.py ..\..\PythonOgreSnapShot
+
+copy ..\changelog.txt ..\..\PythonOgreSnapShot
+del ..\..\PythonOgreSnapShot\*.pyc /s
+del ..\..\PythonOgreSnapShot\*.log /s
+del ..\..\PythonOgreSnapShot\1 /s
+del ..\..\PythonOgreSnapShot\2 /s
+del ..\..\PythonOgreSnapShot\ogre.cfg /s
+for /r ..\..\PythonOgreSnapShot\ %1 in (*) do touch %1
+rem rmdir /s /q ..\..\PythonOgreSnapShot\demos\gui\tofix
+rem rmdir /s /q ..\..\PythonOgreSnapShot\demos\ogre\tofix
+
+
+
+
Deleted: trunk/python-ogre/scripts/PythonOgreInstallCreator.iss
===================================================================
--- trunk/python-ogre/scripts/PythonOgreInstallCreator.iss 2007-09-06 10:19:05 UTC (rev 374)
+++ trunk/python-ogre/scripts/PythonOgreInstallCreator.iss 2007-09-12 13:40:08 UTC (rev 375)
@@ -1,446 +0,0 @@
-;
-; Python-Ogre setup script
-;
-[Setup]
-AppName=Python-Ogre
-AppVerName=Python-Ogre 1.0RC2c
-DefaultDirName=C:\PythonOgre
-DefaultGroupName=Python-Ogre
-OutputBaseFilename=PythonOgreInstaller
-OutputDir=C:\temp
-SourceDir=C:\Development\PythonOgreRelease
-VersionInfoDescription=First Installer Release of Python-Ogre
-AllowNoIcons=true
-AppPublisher=OpenSource
-AppPublisherURL=http://www.python-ogre.org
-AppSupportURL=http://www.python-ogre.org
-AppUpdatesURL=http://www.python-ogre.org
-AppVersion=1.0.2.3
-LicenseFile=LICENSE.GPL
-Compression=lzma
-InfoBeforeFile=InstallWarning.rtf
-InfoAfterFile=postinstall.rtf
-SolidCompression=true
-AppCopyright=LPGL
-VersionInfoCompany=OpenSource
-VersionInfoTextVersion=1.0RC2c
-VersionInfoCopyright=PythonOgre Development Team
-RestartIfNeededByRun=false
-UninstallDisplayName=PythonOgre
-WizardImageFile=compiler:WizModernImage-IS.bmp
-WizardSmallImageFile=compiler:WizModernSmallImage-IS.bmp
-VersionInfoVersion=1.0.2.3
-[Files]
-; base files, demos and tools
-Source: *; DestDir: {app}
-Source: plugins\*; DestDir: {app}\plugins
-Source: tools\*; DestDir: {app}\tools
-Source: demos\*; DestDir: {app}\demos; Flags: recursesubdirs
-Source: docs\*; DestDir: {app}\docs; Flags: recursesubdirs
-; the python modules - in the event we find python
-Source: packages_2.5\*; DestDir: {code:GetPythonSiteDir}; Flags: recursesubdirs; Check: SelectedPython('2.5')
-Source: packages_2.4\*; DestDir: {code:GetPythonSiteDir}; Flags: recursesubdirs; Check: SelectedPython('2.4')
-; the python modules again - if we don't find python we install both versions in the app directory
-Source: packages_2.5\*; DestDir: {app}\packages_2.5; Flags: recursesubdirs; Check: NoPythonFound
-Source: packages_2.4\*; DestDir: {app}\packages_2.4; Flags: recursesubdirs; Check: NoPythonFound
-;
-; we need to remove the .pyc files when we uninstall
-;
-Source: ThirdParty\dxwebsetup.exe; DestDir: {app}\ThirdParty
-Source: ThirdParty\vcredist_x86.exe; DestDir: {app}\ThirdParty
-
-[UninstallDelete]
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\renderer\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\renderer\OGRE\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\io\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\io\OIS\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\gui\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\gui\CEGUI\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\gui\QuickGUI\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\sound\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\sound\OgreAL\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\physics\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\physics\OgreRefApp\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\physics\ODE\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\physics\OgreOde\*.pyc
-Type: filesandordirs; Name: {code:GetPythonSiteDir}\ogre\physics\OgreNewt\*.pyc
-
-Type: files; Name: {app}\demos\CEGUI\*.pyc
-Type: files; Name: {app}\demos\CEGUI\*.log
-Type: files; Name: {app}\demos\GUI\*.pyc
-Type: files; Name: {app}\demos\GUI\*.log
-Type: files; Name: {app}\demos\ogre\*.pyc
-Type: files; Name: {app}\demos\ogre\*.log
-Type: files; Name: {app}\demos\ogreode\*.pyc
-Type: files; Name: {app}\demos\ogreode\*.log
-Type: files; Name: {app}\demos\ogrenewt\*.pyc
-Type: files; Name: {app}\demos\ogrenewt\*.log
-Type: files; Name: {app}\demos\ogreal\*.pyc
-Type: files; Name: {app}\demos\ogreal\*.log
-Type: files; Name: {app}\demos\ode\*.pyc
-Type: files; Name: {app}\demos\ode\*.log
-Type: files; Name: {app}\demos\CEGUI\*.cfg
-Type: files; Name: {app}\demos\GUI\*.cfg
-Type: files; Name: {app}\demos\ogre\*.cfg
-Type: files; Name: {app}\demos\ogreode\*.cfg
-Type: files; Name: {app}\demos\ogrenewt\*.cfg
-Type: files; Name: {app}\demos\ogreal\*.cfg
-Type: files; Name: {app}\demos\ode\*.cfg
-Type: dirifempty; Name: {app}\demos\CEGUI
-Type: dirifempty; Name: {app}\demos\GUI
-Type: dirifempty; Name: {app}\demos\ogre
-Type: dirifempty; Name: {app}\demos\ogreode
-Type: dirifempty; Name: {app}\demos\ogrenewt
-Type: dirifempty; Name: {app}\demos\ogreal
-Type: dirifempty; Name: {app}\demos\ode
-Type: dirifempty; Name: {app}\demos
-Type: dirifempty; Name: {app}
-
-;
-; I REALLY DON'T like doing this but if people have used a previous version of Python-Ogre
-; I need to remove it to force any existing source code to fail and hence have them
-; update to the new directory structure..
-; being very conservative in this!!!!!!!!!!!!!
-;
-[InstallDelete]
-Type: files; Name: {code:GetPythonSiteDir}\Ogre\*.pyd
-Type: files; Name: {code:GetPythonSiteDir}\OIS\*.pyd
-Type: files; Name: {code:GetPythonSiteDir}\GUI\*.pyd
-Type: files; Name: {code:GetPythonSiteDir}\OgreOde\*.pyd
-Type: files; Name: {code:GetPythonSiteDir}\OgreNewt\*.pyd
-Type: files; Name: {code:GetPythonSiteDir}\OgreAL\*.pyd
-Type: files; Name: {code:GetPythonSiteDir}\OgreRefApp\*.pyd
-Type: files; Name: {code:GetPythonSiteDir}\ODE\*.pyd
-Type: files; Name: {code:GetPythonSiteDir}\FMOD\*.pyd
-
-Type: files; Name: {code:GetPythonSiteDir}\Ogre\*.dll
-Type: files; Name: {code:GetPythonSiteDir}\OIS\*.dll
-Type: files; Name: {code:GetPythonSiteDir}\GUI\*.dll
-Type: files; Name: {code:GetPythonSiteDir}\OgreOde\*.dll
-Type: files; Name: {code:GetPythonSiteDir}\OgreNewt\*.dll
-Type: files; Name: {code:GetPythonSiteDir}\OgreAL\*.dll
-Type: files; Name: {code:GetPythonSiteDir}\OgreRefApp\*.dll
-Type: files; Name: {code:GetPythonSiteDir}\ODE\*.dll
-Type: files; Name: {code:GetPythonSiteDir}\FMOD\*.dll
-
-Type: files; Name: {code:GetPythonSiteDir}\Ogre\_*.p*
-Type: files; Name: {code:GetPythonSiteDir}\OIS\_*.p*
-Type: files; Name: {code:GetPythonSiteDir}\GUI\_*.p*
-Type: files; Name: {code:GetPythonSiteDir}\OgreOde\_*.p*
-Type: files; Name: {code:GetPythonSiteDir}\OgreNewt\_*.p*
-Type: files; Name: {code:GetPythonSiteDir}\OgreAL\_*.p*
-Type: files; Name: {code:GetPythonSiteDir}\OgreRefApp\_*.p*
-Type: files; Name: {code:GetPythonSiteDir}\ODE\_*.p*
-Type: files; Name: {code:GetPythonSiteDir}\FMOD\_*.p*
-
-Type: files; Name: {code:GetPythonSiteDir}\Ogre\sf_*.*
-
-Type: files; Name: {code:GetPythonSiteDir}\Ogre
-Type: files; Name: {code:GetPythonSiteDir}\OIS
-Type: files; Name: {code:GetPythonSiteDir}\GUI
-Type: files; Name: {code:GetPythonSiteDir}\OgreOde
-Type: files; Name: {code:GetPythonSiteDir}\OgreNewt
-Type: files; Name: {code:GetPythonSiteDir}\OgreAL
-Type: files; Name: {code:GetPythonSiteDir}\OgreRefApp
-Type: files; Name: {code:GetPythonSiteDir}\ODE
-Type: files; Name: {code:GetPythonSiteDir}\FMOD
-
-Type: dirifempty; Name: {code:GetPythonSiteDir}\Ogre
-Type: dirifempty; Name: {code:GetPythonSiteDir}\OIS
-Type: dirifempty; Name: {code:GetPythonSiteDir}\GUI
-Type: dirifempty; Name: {code:GetPythonSiteDir}\OgreOde
-Type: dirifempty; Name: {code:GetPythonSiteDir}\OgreNewt
-Type: dirifempty; Name: {code:GetPythonSiteDir}\OgreAL
-Type: dirifempty; Name: {code:GetPythonSiteDir}\OgreRefApp
-Type: dirifempty; Name: {code:GetPythonSiteDir}\ODE
-
-[Icons]
-Name: {group}\Ogre Demos\Bezier; Filename: {code:GetPythonExe}; Parameters: Demo_Bezier.py; WorkingDir: {app}\Demos\Ogre
-Name: {group}\Ogre Demos\BSP; Filename: {code:GetPythonExe}; Parameters: Demo_BSP.py; WorkingDir: {app}\Demos\Ogre
-Name: {group}\Ogre Demos\BSP_Collision; Filename: {code:GetPythonExe}; Parameters: Demo_BspCollision.py; WorkingDir: {app}\Demos\Ogre
-Name: {group}\Ogre Demos\Camera Tracking; Filename: {code:GetPythonExe}; Parameters: Demo_CameraTracking.py; WorkingDir: {app}\Demos\Ogre
-Name: {group}\Ogre Demos\CEL Shading; Filename: {code:GetPythonExe}; Parameters: Demo_CelShading.py; WorkingDir: {app}\Demos\Ogre
-Name: {group}\Ogre Demos\Compositor; Filename: {code:GetPythonExe}; Parameters: Demo_Compositor.py; WorkingDir: {app}\Demos\Ogre
-Name: {group}\Ogre Demos\ENV Map; Filename: {code:GetPythonExe}; Parameters: Demo_EnvMap.py; WorkingDir: {app}\Demos\Ogre
-Name: {group}\Ogre Demos\Facial; Filename: {code:GetPythonExe}; Parameters: Demo_Facial.py; WorkingDir: {app}\Demos\Ogre
-Name: {group}\Ogre ...
[truncated message content] |