X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/54173563c3ff0c79a33dd1bc33a13d74fec15df1..8516f4fc7a3f0496418e5b77ef3a539aec253b6b:/src/stc/gen_iface.py diff --git a/src/stc/gen_iface.py b/src/stc/gen_iface.py index f6f329fb30..d332807c83 100755 --- a/src/stc/gen_iface.py +++ b/src/stc/gen_iface.py @@ -6,7 +6,6 @@ # Author: Robin Dunn # # Created: 5-Sept-2000 -# RCS-ID: $Id$ # Copyright: (c) 2000 by Total Control Software # Licence: wxWindows licence #---------------------------------------------------------------------------- @@ -18,13 +17,15 @@ from fileinput import FileInput IFACE = os.path.abspath('./scintilla/include/Scintilla.iface') H_TEMPLATE = os.path.abspath('./stc.h.in') +IH_TEMPLATE = os.path.abspath('./stc.interface.h.in') CPP_TEMPLATE = os.path.abspath('./stc.cpp.in') H_DEST = os.path.abspath('../../include/wx/stc/stc.h') +IH_DEST = os.path.abspath('../../interface/wx/stc/stc.h') CPP_DEST = os.path.abspath('./stc.cpp') if len(sys.argv) > 1 and sys.argv[1] == '--wxpython': DOCSTR_DEST = os.path.abspath('../../../wxPython/src/_stc_gendocs.i') else: - DOCSTR_DEST = '/dev/null' + DOCSTR_DEST = None # Value prefixes to convert @@ -756,7 +757,7 @@ methodOverrideMap = { '''wxString %s() const { int msg = %s; - int len = SendMsg(msg, 0, NULL); + int len = SendMsg(msg, 0, (sptr_t)NULL); if (!len) return wxEmptyString; wxMemoryBuffer mbuf(len+1); @@ -774,7 +775,7 @@ methodOverrideMap = { '''wxString %s(int tagNumber) const { int msg = %s; - int len = SendMsg(msg, tagNumber, NULL); + int len = SendMsg(msg, tagNumber, (sptr_t)NULL); if (!len) return wxEmptyString; wxMemoryBuffer mbuf(len+1); @@ -791,7 +792,7 @@ methodOverrideMap = { '''wxString %s() const { int msg = %s; - int len = SendMsg(msg, 0, NULL); + int len = SendMsg(msg, 0, (sptr_t)NULL); if (!len) return wxEmptyString; wxMemoryBuffer mbuf(len+1); @@ -809,7 +810,7 @@ methodOverrideMap = { '''wxString %s() const { int msg = %s; - int len = SendMsg(msg, 0, NULL); + int len = SendMsg(msg, 0, (sptr_t)NULL); if (!len) return wxEmptyString; wxMemoryBuffer mbuf(len+1); @@ -827,7 +828,7 @@ methodOverrideMap = { '''wxString %s() const { int msg = %s; - int len = SendMsg(msg, 0, NULL); + int len = SendMsg(msg, 0, (sptr_t)NULL); if (!len) return wxEmptyString; wxMemoryBuffer mbuf(len+1); @@ -846,7 +847,7 @@ methodOverrideMap = { '''wxString %s(const wxString& name) const { int msg = %s; - int len = SendMsg(msg, (sptr_t)(const char*)wx2stc(name), NULL); + int len = SendMsg(msg, (sptr_t)(const char*)wx2stc(name), (sptr_t)NULL); if (!len) return wxEmptyString; wxMemoryBuffer mbuf(len+1); @@ -865,7 +866,7 @@ methodOverrideMap = { '''wxString %s() const { int msg = %s; - int len = SendMsg(msg, 0, NULL); + int len = SendMsg(msg, 0, (sptr_t)NULL); if (!len) return wxEmptyString; wxMemoryBuffer mbuf(len+1); @@ -932,7 +933,7 @@ constNonGetterMethods = ( #---------------------------------------------------------------------------- -def processIface(iface, h_tmplt, cpp_tmplt, h_dest, cpp_dest, docstr_dest): +def processIface(iface, h_tmplt, cpp_tmplt, ih_tmplt, h_dest, cpp_dest, docstr_dest, ih_dest): curDocStrings = [] values = [] methods = [] @@ -979,23 +980,27 @@ def processIface(iface, h_tmplt, cpp_tmplt, h_dest, cpp_dest, docstr_dest): data = {} data['VALUES'] = processVals(values) data['CMDS'] = processVals(cmds) - defs, imps, docstrings = processMethods(methods) + defs, imps, docstrings, idefs = processMethods(methods) data['METHOD_DEFS'] = defs + data['METHOD_IDEFS'] = idefs data['METHOD_IMPS'] = imps # get template text h_text = open(h_tmplt).read() + ih_text = open(ih_tmplt).read() cpp_text = open(cpp_tmplt).read() # do the substitutions h_text = h_text % data cpp_text = cpp_text % data + ih_text = ih_text % data # write out destination files open(h_dest, 'w').write(h_text) open(cpp_dest, 'w').write(cpp_text) - open(docstr_dest, 'w').write(docstrings) - + if docstr_dest: + open(docstr_dest, 'w').write(docstrings) + open(ih_dest, 'w').write(ih_text) def joinWithNewLines(values): @@ -1009,7 +1014,7 @@ def processVals(values): if docs: text.append('') for x in docs: - text.append('// ' + x) + text.append('/// ' + x) text.append('#define %s %s' % (name, value)) return joinWithNewLines(text) @@ -1017,6 +1022,7 @@ def processVals(values): def processMethods(methods): defs = [] + idefs = [] imps = [] dstr = [] @@ -1046,6 +1052,18 @@ def processMethods(methods): theDef = theDef + ';' defs.append(theDef) + # Build the method definition for the interface .h file + if docs: + idefs.append('') + idefs.append(' /**') + for x in docs: + idefs.append(' ' + x) + idefs.append(' */') + if name == 'GetCurLine': + idefs.append(' wxString GetCurLine(int* linePos=NULL);') + else: + idefs.append(theDef) + # Build the method implementation string if docs: imps.append('') @@ -1072,7 +1090,7 @@ def processMethods(methods): imps.append(theImp) - return joinWithNewLines(defs), joinWithNewLines(imps), joinWithNewLines(dstr) + return joinWithNewLines(defs), joinWithNewLines(imps), joinWithNewLines(dstr), joinWithNewLines(idefs) #---------------------------------------------------------------------------- @@ -1197,7 +1215,7 @@ def main(args): sys.exit(1) # Now just do it - processIface(IFACE, H_TEMPLATE, CPP_TEMPLATE, H_DEST, CPP_DEST, DOCSTR_DEST) + processIface(IFACE, H_TEMPLATE, CPP_TEMPLATE, IH_TEMPLATE, H_DEST, CPP_DEST, DOCSTR_DEST, IH_DEST)