Commit e8f4e48f authored by Evan Simpson's avatar Evan Simpson

Make METAL names strictly follow NAME_RE pattern, with leading and

following whitespace ignored.
parent d380a9c3
...@@ -334,9 +334,12 @@ class TALGenerator: ...@@ -334,9 +334,12 @@ class TALGenerator:
def emitDefineMacro(self, macroName, position=(None, None)): def emitDefineMacro(self, macroName, position=(None, None)):
program = self.popProgram() program = self.popProgram()
macroName = string.strip(macroName)
if self.macros.has_key(macroName): if self.macros.has_key(macroName):
raise METALError("duplicate macro definition: %s" % macroName, raise METALError("duplicate macro definition: %s" % `macroName`,
position) position)
if not re.match('%s$' % NAME_RE, macroName):
raise METALError("invalid macro name: %s" % `macroName`, position)
self.macros[macroName] = program self.macros[macroName] = program
self.emit("defineMacro", macroName, program) self.emit("defineMacro", macroName, program)
...@@ -345,15 +348,21 @@ class TALGenerator: ...@@ -345,15 +348,21 @@ class TALGenerator:
program = self.popProgram() program = self.popProgram()
self.emit("useMacro", expr, cexpr, self.popSlots(), program) self.emit("useMacro", expr, cexpr, self.popSlots(), program)
def emitDefineSlot(self, slotName): def emitDefineSlot(self, slotName, position=(None, None)):
program = self.popProgram() program = self.popProgram()
slotName = string.strip(slotName)
if not re.match('%s$' % NAME_RE, slotName):
raise METALError("invalid slot name: %s" % `slotName`, position)
self.emit("defineSlot", slotName, program) self.emit("defineSlot", slotName, program)
def emitFillSlot(self, slotName, position=(None, None)): def emitFillSlot(self, slotName, position=(None, None)):
program = self.popProgram() program = self.popProgram()
slotName = string.strip(slotName)
if self.slots.has_key(slotName): if self.slots.has_key(slotName):
raise METALError("duplicate fill-slot name: %s" % slotName, raise METALError("duplicate fill-slot name: %s" % `slotName`,
position) position)
if not re.match('%s$' % NAME_RE, slotName):
raise METALError("invalid slot name: %s" % `slotName`, position)
self.slots[slotName] = program self.slots[slotName] = program
self.emit("fillSlot", slotName, program) self.emit("fillSlot", slotName, program)
...@@ -580,7 +589,7 @@ class TALGenerator: ...@@ -580,7 +589,7 @@ class TALGenerator:
if scope: if scope:
self.emit("endScope") self.emit("endScope")
if defineSlot: if defineSlot:
self.emitDefineSlot(defineSlot) self.emitDefineSlot(defineSlot, position)
if fillSlot: if fillSlot:
self.emitFillSlot(fillSlot, position) self.emitFillSlot(fillSlot, position)
if useMacro: if useMacro:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment