mirror of
https://github.com/python/cpython.git
synced 2025-07-07 19:35:27 +00:00
New batch from Fred
This commit is contained in:
parent
3a1fbb4c70
commit
4747887880
6 changed files with 1192 additions and 470 deletions
79
Lib/token.py
79
Lib/token.py
|
@ -1,5 +1,18 @@
|
|||
# Tokens (from "token.h")
|
||||
#! /usr/bin/env python
|
||||
#
|
||||
# Tokens (from "token.h")
|
||||
#
|
||||
# This file is automatically generated; please don't muck it up!
|
||||
#
|
||||
# To update the symbols in this file, 'cd' to the top directory of
|
||||
# the python source tree after building the interpreter and run:
|
||||
#
|
||||
# PYTHONPATH=./Lib ./python Lib/token.py
|
||||
#
|
||||
# (this path allows the import of string.py and regexmodule.so
|
||||
# for a site with no installation in place)
|
||||
|
||||
#--start constants--
|
||||
ENDMARKER = 0
|
||||
NAME = 1
|
||||
NUMBER = 2
|
||||
|
@ -39,6 +52,9 @@ RIGHTSHIFT = 35
|
|||
DOUBLESTAR = 36
|
||||
OP = 37
|
||||
ERRORTOKEN = 38
|
||||
N_TOKENS = 39
|
||||
NT_OFFSET = 256
|
||||
#--end constants--
|
||||
|
||||
names = dir()
|
||||
tok_name = {}
|
||||
|
@ -47,9 +63,6 @@ for name in names:
|
|||
if type(number) is type(0):
|
||||
tok_name[number] = name
|
||||
|
||||
N_TOKENS = 39 # Number of tokens including ERRORTOKEN
|
||||
NT_OFFSET = 256 # Start of non-terminal symbols
|
||||
|
||||
def ISTERMINAL(x):
|
||||
return x < NT_OFFSET
|
||||
|
||||
|
@ -58,3 +71,61 @@ def ISNONTERMINAL(x):
|
|||
|
||||
def ISEOF(x):
|
||||
return x == ENDMARKER
|
||||
|
||||
|
||||
def main():
|
||||
import regex
|
||||
import string
|
||||
import sys
|
||||
args = sys.argv[1:]
|
||||
inFileName = args and args[0] or "Include/token.h"
|
||||
outFileName = "Lib/token.py"
|
||||
if len(args) > 1:
|
||||
outFileName = args[1]
|
||||
try:
|
||||
fp = open(inFileName)
|
||||
except IOError, err:
|
||||
sys.stdout.write("I/O error: %s\n" % str(err))
|
||||
sys.exit(1)
|
||||
lines = string.splitfields(fp.read(), "\n")
|
||||
fp.close()
|
||||
re = regex.compile(
|
||||
"#define[ \t][ \t]*\([A-Z][A-Z_]*\)[ \t][ \t]*\([0-9][0-9]*\)",
|
||||
regex.casefold)
|
||||
tokens = {}
|
||||
for line in lines:
|
||||
if re.match(line) > -1:
|
||||
name, val = re.group(1, 2)
|
||||
val = string.atoi(val)
|
||||
tokens[val] = name # reverse so we can sort them...
|
||||
keys = tokens.keys()
|
||||
keys.sort()
|
||||
# load the output skeleton from the target:
|
||||
try:
|
||||
fp = open(outFileName)
|
||||
except IOError, err:
|
||||
sys.stderr.write("I/O error: %s\n" % str(err))
|
||||
sys.exit(2)
|
||||
format = string.splitfields(fp.read(), "\n")
|
||||
fp.close()
|
||||
try:
|
||||
start = format.index("#--start constants--") + 1
|
||||
end = format.index("#--end constants--")
|
||||
except ValueError:
|
||||
sys.stderr.write("target does not contain format markers")
|
||||
sys.exit(3)
|
||||
lines = []
|
||||
for val in keys:
|
||||
lines.append("%s = %d" % (tokens[val], val))
|
||||
format[start:end] = lines
|
||||
try:
|
||||
fp = open(outFileName, 'w')
|
||||
except IOError, err:
|
||||
sys.stderr.write("I/O error: %s\n" % str(err))
|
||||
sys.exit(4)
|
||||
fp.write(string.joinfields(format, "\n"))
|
||||
fp.close()
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue