Separate the parts of make_bindings.py out into common parts, and SWIG and SIP specific parts.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@60491 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
		
							
								
								
									
										84
									
								
								docs/doxygen/scripts/sip_tools.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										84
									
								
								docs/doxygen/scripts/sip_tools.py
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,84 @@
 | 
			
		||||
import os
 | 
			
		||||
 | 
			
		||||
from common import *
 | 
			
		||||
 | 
			
		||||
class SIPBuilder:
 | 
			
		||||
    def __init__(self, doxyparse, outputdir):
 | 
			
		||||
        self.doxyparser = doxyparse
 | 
			
		||||
        self.output_dir = outputdir
 | 
			
		||||
 | 
			
		||||
    def make_bindings(self):
 | 
			
		||||
        output_dir = os.path.abspath(os.path.join(self.output_dir, "sip"))
 | 
			
		||||
        if not os.path.exists(output_dir):
 | 
			
		||||
            os.makedirs(output_dir)
 | 
			
		||||
    
 | 
			
		||||
        for aclass in self.doxyparser.classes:
 | 
			
		||||
            if aclass.name in excluded_classes:
 | 
			
		||||
                print "Skipping %s" % aclass.name
 | 
			
		||||
                continue
 | 
			
		||||
        
 | 
			
		||||
            header_name = aclass.name[2:].lower()
 | 
			
		||||
            filename = os.path.join(output_dir, header_name + ".sip")
 | 
			
		||||
            enums_text = make_enums(aclass)
 | 
			
		||||
            method_text = self.make_sip_methods(aclass)
 | 
			
		||||
            base_class = get_first_value(aclass.bases)
 | 
			
		||||
            if base_class != "":
 | 
			
		||||
                base_class = ": %s" % base_class
 | 
			
		||||
            
 | 
			
		||||
            text = """
 | 
			
		||||
%s
 | 
			
		||||
class %s %s
 | 
			
		||||
{
 | 
			
		||||
%%TypeHeaderCode
 | 
			
		||||
#include <%s>
 | 
			
		||||
%%End
 | 
			
		||||
 | 
			
		||||
public:
 | 
			
		||||
%s
 | 
			
		||||
};
 | 
			
		||||
""" % (enums_text, aclass.name, base_class, get_first_value(aclass.includes), method_text)
 | 
			
		||||
 | 
			
		||||
            afile = open(filename, "wb")
 | 
			
		||||
            afile.write(text)
 | 
			
		||||
            afile.close()
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    def make_sip_methods(self, aclass):
 | 
			
		||||
        retval = ""
 | 
			
		||||
    
 | 
			
		||||
        for amethod in aclass.constructors + aclass.methods:
 | 
			
		||||
            transfer = ""
 | 
			
		||||
            
 | 
			
		||||
            # FIXME: we need to come up with a way of filtering the methods out by various criteria
 | 
			
		||||
            # including parameters and method name, and how to deal with overloads 
 | 
			
		||||
            if aclass.name in ignored_methods:
 | 
			
		||||
                should_ignore = False
 | 
			
		||||
                for method in ignored_methods[aclass.name]:
 | 
			
		||||
                    print "method = %s" % method
 | 
			
		||||
                    if method == amethod.name:
 | 
			
		||||
                        params = ignored_methods[aclass.name][method]
 | 
			
		||||
                        should_ignore = True
 | 
			
		||||
                        for i in xrange(len(params)):
 | 
			
		||||
                            if i >= len(amethod.params):
 | 
			
		||||
                                should_ignore = False
 | 
			
		||||
                                break
 | 
			
		||||
                            elif amethod.params[i]["type"] != params[i]:
 | 
			
		||||
                                print "param type = %s, amethod.param type = %s" % (params[i], amethod.params[i]["type"])
 | 
			
		||||
                                should_ignore = False
 | 
			
		||||
                                break
 | 
			
		||||
                        
 | 
			
		||||
                if should_ignore:
 | 
			
		||||
                    continue
 | 
			
		||||
            
 | 
			
		||||
            # We need to let SIP know when wx is responsible for deleting the object.
 | 
			
		||||
            # We do this if the class is derived from wxWindow, since wxTLW manages child windows
 | 
			
		||||
            # and wxApp deletes all wxTLWs on shutdown
 | 
			
		||||
            if amethod in aclass.constructors and self.doxyparser.is_derived_from_base(aclass, "wxWindow"):
 | 
			
		||||
                transfer = "/Transfer/"
 | 
			
		||||
                
 | 
			
		||||
            if amethod.name.startswith("operator"):
 | 
			
		||||
                continue
 | 
			
		||||
            
 | 
			
		||||
            retval += "    %s %s%s%s;\n\n" % (amethod.return_type.replace("virtual ", ""), amethod.name, amethod.argsstring, transfer)
 | 
			
		||||
        
 | 
			
		||||
        return retval
 | 
			
		||||
		Reference in New Issue
	
	Block a user