notepad-plus-plus/scintilla/scripts/HFacer.py

62 lines
2.0 KiB
Python
Raw Normal View History

#!/usr/bin/env python
# HFacer.py - regenerate the Scintilla.h and SciLexer.h files from the Scintilla.iface interface
# definition file.
# Implemented 2000 by Neil Hodgson neilh@scintilla.org
# Requires Python 2.5 or later
import sys
import os
import Face
from FileGenerator import UpdateFile, Generate, Regenerate, UpdateLineInFile, lineEnd
def printLexHFile(f):
out = []
for name in f.order:
v = f.features[name]
if v["FeatureType"] in ["val"]:
if "SCE_" in name or "SCLEX_" in name:
out.append("#define " + name + " " + v["Value"])
return out
def printHFile(f):
out = []
previousCategory = ""
anyProvisional = False
for name in f.order:
v = f.features[name]
if v["Category"] != "Deprecated":
if v["Category"] == "Provisional" and previousCategory != "Provisional":
out.append("#ifndef SCI_DISABLE_PROVISIONAL")
anyProvisional = True
previousCategory = v["Category"]
if v["FeatureType"] in ["fun", "get", "set"]:
featureDefineName = "SCI_" + name.upper()
out.append("#define " + featureDefineName + " " + v["Value"])
elif v["FeatureType"] in ["evt"]:
featureDefineName = "SCN_" + name.upper()
out.append("#define " + featureDefineName + " " + v["Value"])
elif v["FeatureType"] in ["val"]:
if not ("SCE_" in name or "SCLEX_" in name):
out.append("#define " + name + " " + v["Value"])
if anyProvisional:
out.append("#endif")
return out
def RegenerateAll(root, showMaxID):
f = Face.Face()
f.ReadFromFile(root + "include/Scintilla.iface")
Regenerate(root + "include/Scintilla.h", "/* ", printHFile(f))
Regenerate(root + "include/SciLexer.h", "/* ", printLexHFile(f))
if showMaxID:
valueSet = set(int(x) for x in f.values if int(x) < 3000)
maximumID = max(valueSet)
print("Maximum ID is %d" % maximumID)
#~ valuesUnused = sorted(x for x in range(2001,maximumID) if x not in valueSet)
#~ print("\nUnused values")
#~ for v in valuesUnused:
#~ print(v)
if __name__ == "__main__":
RegenerateAll("../", True)