зеркало из https://github.com/mozilla/pjs.git
b=534733, add support for fully custom quickstubs; r=jorendorff
This commit is contained in:
Родитель
4f518fbcce
Коммит
d3b1d4abdc
|
@ -264,6 +264,8 @@ class Configuration:
|
||||||
# optional settings
|
# optional settings
|
||||||
self.irregularFilenames = config.get('irregularFilenames', {})
|
self.irregularFilenames = config.get('irregularFilenames', {})
|
||||||
self.customIncludes = config.get('customIncludes', [])
|
self.customIncludes = config.get('customIncludes', [])
|
||||||
|
self.customQuickStubs = config.get('customQuickStubs', [])
|
||||||
|
self.customReturnInterfaces = config.get('customReturnInterfaces', [])
|
||||||
self.customMethodCalls = config.get('customMethodCalls', {})
|
self.customMethodCalls = config.get('customMethodCalls', {})
|
||||||
|
|
||||||
def readConfigFile(filename, includePath, cachedir, traceable):
|
def readConfigFile(filename, includePath, cachedir, traceable):
|
||||||
|
@ -317,7 +319,18 @@ def readConfigFile(filename, includePath, cachedir, traceable):
|
||||||
if member in iface.stubMembers:
|
if member in iface.stubMembers:
|
||||||
raise UserError("Member %s is specified more than once."
|
raise UserError("Member %s is specified more than once."
|
||||||
% memberId)
|
% memberId)
|
||||||
addStubMember(memberId, member, traceable)
|
mayTrace = True
|
||||||
|
if member.noscript:
|
||||||
|
cmc = conf.customMethodCalls.get(interfaceName + "_" + header.methodNativeName(member), None)
|
||||||
|
if cmc is not None and cmc.get('skipgen', False):
|
||||||
|
# We're doing magic custom stuff for this, so pretend it's not noscript
|
||||||
|
member.noscript = False
|
||||||
|
mayTrace = False
|
||||||
|
addStubMember(memberId, member, traceable and mayTrace)
|
||||||
|
|
||||||
|
for iface in conf.customReturnInterfaces:
|
||||||
|
# just ensure that it exists so that we can grab it later
|
||||||
|
iface = getInterface(iface, errorLoc='looking for %s' % (iface,))
|
||||||
|
|
||||||
return conf, interfaces
|
return conf, interfaces
|
||||||
|
|
||||||
|
@ -708,6 +721,8 @@ def writeQuickStub(f, customMethodCalls, member, stubName, isSetter=False):
|
||||||
code = customMethodCall['setter_code']
|
code = customMethodCall['setter_code']
|
||||||
stubName = templateName
|
stubName = templateName
|
||||||
else:
|
else:
|
||||||
|
if customMethodCall.get('skipgen', False):
|
||||||
|
return
|
||||||
callTemplate = ""
|
callTemplate = ""
|
||||||
code = customMethodCall['code']
|
code = customMethodCall['code']
|
||||||
|
|
||||||
|
@ -1105,6 +1120,9 @@ def writeTraceableQuickStub(f, customMethodCalls, member, stubName):
|
||||||
|
|
||||||
customMethodCall = customMethodCalls.get(stubName, None)
|
customMethodCall = customMethodCalls.get(stubName, None)
|
||||||
|
|
||||||
|
if customMethodCall is not None and customMethodCall.get('skipgen', False):
|
||||||
|
return
|
||||||
|
|
||||||
# Write the function
|
# Write the function
|
||||||
f.write("static %sFASTCALL\n" % getTraceType(member.type))
|
f.write("static %sFASTCALL\n" % getTraceType(member.type))
|
||||||
f.write("%s(JSContext *cx, JSObject *obj" % (stubName + "_tn"))
|
f.write("%s(JSContext *cx, JSObject *obj" % (stubName + "_tn"))
|
||||||
|
@ -1458,13 +1476,16 @@ def writeStubFile(filename, headerFilename, conf, interfaces):
|
||||||
try:
|
try:
|
||||||
f.write(stubTopTemplate % os.path.basename(headerFilename))
|
f.write(stubTopTemplate % os.path.basename(headerFilename))
|
||||||
N = 256
|
N = 256
|
||||||
for customInclude in conf.customIncludes:
|
|
||||||
f.write('#include "%s"\n' % customInclude)
|
|
||||||
resulttypes = []
|
resulttypes = []
|
||||||
for iface in interfaces:
|
for iface in interfaces:
|
||||||
resulttypes.extend(writeIncludesForInterface(iface))
|
resulttypes.extend(writeIncludesForInterface(iface))
|
||||||
|
resulttypes.extend(conf.customReturnInterfaces)
|
||||||
|
for customInclude in conf.customIncludes:
|
||||||
|
f.write('#include "%s"\n' % customInclude)
|
||||||
f.write("\n\n")
|
f.write("\n\n")
|
||||||
writeResultXPCInterfacesArray(f, conf, frozenset(resulttypes))
|
writeResultXPCInterfacesArray(f, conf, frozenset(resulttypes))
|
||||||
|
for customQS in conf.customQuickStubs:
|
||||||
|
f.write('#include "%s"\n' % customQS)
|
||||||
for iface in interfaces:
|
for iface in interfaces:
|
||||||
writeStubsForInterface(f, conf.customMethodCalls, iface)
|
writeStubsForInterface(f, conf.customMethodCalls, iface)
|
||||||
writeDefiner(f, conf, interfaces)
|
writeDefiner(f, conf, interfaces)
|
||||||
|
|
Загрузка…
Ссылка в новой задаче