Mercurial > hg > MakeItSo
annotate makeitso/template.py @ 113:c3b8ce33d3ad
make variable getting logic a little less horrible
| author | Jeff Hammel <jhammel@mozilla.com> | 
|---|---|
| date | Mon, 17 Jan 2011 14:32:07 -0800 | 
| parents | 51c9cb49edec | 
| children | b2152efec89a | 
| rev | line source | 
|---|---|
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 1 """ | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 2 basic API template class | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 3 """ | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 4 | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 5 import os | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 6 import sys | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 7 from makeitso import ContentTemplate | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 8 from makeitso import PolyTemplate | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 9 | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 10 class Undefined(object): | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 11 """marker class for variables""" | 
| 65 
0152741621c1
check in a failing test wrt location
 Jeff Hammel <jhammel@mozilla.com> parents: 
64diff
changeset | 12 def __nonzero__(self): | 
| 
0152741621c1
check in a failing test wrt location
 Jeff Hammel <jhammel@mozilla.com> parents: 
64diff
changeset | 13 return False | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 14 Undefined = Undefined() # singleton | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 15 | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 16 class Variable(object): | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 17 """variable object for MakeItSo templates""" | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 18 | 
| 58 
112bf081148c
make a full CLI class for a single API template
 Jeff Hammel <jhammel@mozilla.com> parents: 
56diff
changeset | 19 def __init__(self, name, description=None, default=Undefined, | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 20 cast=None): | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 21 self.name = name | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 22 self.default = default | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 23 self.description = description | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 24 | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 25 # TODO (maybe): get cast from default variable type if not None | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 26 self.cast = cast | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 27 | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 28 self._set = False | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 29 | 
| 71 
95d1bb85ab3c
add a copy method to a variable to get a non-futzed copy
 Jeff Hammel <jhammel@mozilla.com> parents: 
70diff
changeset | 30 def copy(self): | 
| 
95d1bb85ab3c
add a copy method to a variable to get a non-futzed copy
 Jeff Hammel <jhammel@mozilla.com> parents: 
70diff
changeset | 31 """returns a copy of the variable""" | 
| 
95d1bb85ab3c
add a copy method to a variable to get a non-futzed copy
 Jeff Hammel <jhammel@mozilla.com> parents: 
70diff
changeset | 32 return Variable(self.name, self.description, self.default, self.cast) | 
| 
95d1bb85ab3c
add a copy method to a variable to get a non-futzed copy
 Jeff Hammel <jhammel@mozilla.com> parents: 
70diff
changeset | 33 | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 34 def set(self, value): | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 35 if self.cast: | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 36 self.value = self.cast(value) | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 37 else: | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 38 self.value = value | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 39 self._set = True | 
| 99 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 40 return self.value | 
| 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 41 | 
| 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 42 def isset(self): | 
| 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 43 """whether the variable has been set or not""" | 
| 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 44 return self._set | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 45 | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 46 def read(self, fd=sys.stdout): | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 47 """prompt and read the variable from stdin""" | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 48 fd.write(self.display()) | 
| 100 
b54898f7d8a9
now API template variables seem to work
 Jeff Hammel <jhammel@mozilla.com> parents: 
99diff
changeset | 49 return self.set(raw_input()) | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 50 | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 51 def display(self): | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 52 description = self.description or self.name | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 53 if self.default: | 
| 99 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 54 return 'Enter %s [DEFAULT: %s]: ' % (description, repr(self.default)) | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 55 else: | 
| 99 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 56 return 'Enter %s: ' % description | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 57 | 
| 75 
ec35e5763b52
* fix with assemble function
 Jeff Hammel <jhammel@mozilla.com> parents: 
74diff
changeset | 58 def __repr__(self): | 
| 
ec35e5763b52
* fix with assemble function
 Jeff Hammel <jhammel@mozilla.com> parents: 
74diff
changeset | 59 return "Variable(name='%s')" % self.name | 
| 
ec35e5763b52
* fix with assemble function
 Jeff Hammel <jhammel@mozilla.com> parents: 
74diff
changeset | 60 | 
| 72 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 61 def assemble(*args): | 
| 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 62 names = set() | 
| 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 63 retval = [] | 
| 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 64 for arg in args: | 
| 74 
d16823fd8c4a
check for subclassing, not instance of
 Jeff Hammel <jhammel@mozilla.com> parents: 
73diff
changeset | 65 if issubclass(arg, MakeItSoTemplate): | 
| 72 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 66 arg = arg.vars | 
| 73 | 67 for variable in arg: | 
| 72 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 68 if variable.name in names: | 
| 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 69 continue | 
| 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 70 retval.append(variable.copy()) | 
| 75 
ec35e5763b52
* fix with assemble function
 Jeff Hammel <jhammel@mozilla.com> parents: 
74diff
changeset | 71 names.add(variable.name) | 
| 72 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 72 return retval | 
| 
f44af8f30147
add function to assemble variables
 Jeff Hammel <jhammel@mozilla.com> parents: 
71diff
changeset | 73 | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 74 class MakeItSoTemplate(ContentTemplate): | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 75 """API template for MakeItSo""" | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 76 | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 77 # name of the template | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 78 name = '' | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 79 | 
| 56 
728cae02a6ed
* fix another variable-related bug
 Jeff Hammel <jhammel@mozilla.com> parents: 
44diff
changeset | 80 # description of the template | 
| 
728cae02a6ed
* fix another variable-related bug
 Jeff Hammel <jhammel@mozilla.com> parents: 
44diff
changeset | 81 description = '' | 
| 
728cae02a6ed
* fix another variable-related bug
 Jeff Hammel <jhammel@mozilla.com> parents: 
44diff
changeset | 82 | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 83 # templates to interpolate | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 84 # paths are relative to __file__ unless absolute or URIs | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 85 templates = [] | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 86 | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 87 # variables | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 88 vars = [] | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 89 | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 90 # inspect the templates for more variables | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 91 look = False | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 92 | 
| 90 
26b9c3bba04e
make the api for substitute() variables, output
 Jeff Hammel <jhammel@mozilla.com> parents: 
88diff
changeset | 93 def __init__(self, interactive=True, usedefaults=True, variables=None): | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 94 """ | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 95 - output : output file or directory | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 96 - interactive : whether tointeractively get variables | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 97 - usedefaults : try to use the default values if not specified | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 98 """ | 
| 63 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 99 | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 100 # boilerplate | 
| 65 
0152741621c1
check in a failing test wrt location
 Jeff Hammel <jhammel@mozilla.com> parents: 
64diff
changeset | 101 variables = variables or {} | 
| 78 
d4184945f8a8
stub out python package creation
 Jeff Hammel <jhammel@mozilla.com> parents: 
75diff
changeset | 102 if not self.description and hasattr(self, '__doc__'): | 
| 
d4184945f8a8
stub out python package creation
 Jeff Hammel <jhammel@mozilla.com> parents: 
75diff
changeset | 103 self.description = self.__doc__ | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 104 self.interactive = interactive | 
| 66 
7821c82772f5
determine the location in a better way
 Jeff Hammel <jhammel@mozilla.com> parents: 
65diff
changeset | 105 _file = sys.modules[self.__class__.__module__].__file__ | 
| 
7821c82772f5
determine the location in a better way
 Jeff Hammel <jhammel@mozilla.com> parents: 
65diff
changeset | 106 self.location = os.path.dirname(os.path.abspath(_file)) | 
| 58 
112bf081148c
make a full CLI class for a single API template
 Jeff Hammel <jhammel@mozilla.com> parents: 
56diff
changeset | 107 self.defaults = variables.copy() | 
| 63 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 108 self.usedefaults = usedefaults | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 109 | 
| 58 
112bf081148c
make a full CLI class for a single API template
 Jeff Hammel <jhammel@mozilla.com> parents: 
56diff
changeset | 110 # make a dictionary of the variables for lookup convenience | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 111 self.vardict = {} | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 112 for i in self.vars: | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 113 self.vardict[i.name] = i | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 114 | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 115 # ensure all of these templates exist | 
| 65 
0152741621c1
check in a failing test wrt location
 Jeff Hammel <jhammel@mozilla.com> parents: 
64diff
changeset | 116 self._templates = [] | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 117 for template in self.templates: | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 118 if template.startswith('http://') or template.startswith('https://'): | 
| 65 
0152741621c1
check in a failing test wrt location
 Jeff Hammel <jhammel@mozilla.com> parents: 
64diff
changeset | 119 self._templates.append(template) | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 120 continue | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 121 if os.path.isabs(template): | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 122 path = template | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 123 else: | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 124 path = os.path.join(self.location, template) | 
| 65 
0152741621c1
check in a failing test wrt location
 Jeff Hammel <jhammel@mozilla.com> parents: 
64diff
changeset | 125 assert os.path.exists(path), "%s does not exist" % path | 
| 
0152741621c1
check in a failing test wrt location
 Jeff Hammel <jhammel@mozilla.com> parents: 
64diff
changeset | 126 self._templates.append(path) | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 127 | 
| 63 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 128 def get_variables(self, **variables): | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 129 # XXX could do this in the ctor | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 130 vars = ContentTemplate.get_variables(self, **variables) | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 131 if self.usedefaults: | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 132 for variable in self.vars: | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 133 if variable.name in vars: | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 134 continue | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 135 if variable.default is not Undefined: | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 136 vars[variable.name] = variable.default | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 137 return vars | 
| 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 138 | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 139 def missing(self, **variables): | 
| 113 
c3b8ce33d3ad
make variable getting logic a little less horrible
 Jeff Hammel <jhammel@mozilla.com> parents: 
112diff
changeset | 140 | 
| 
c3b8ce33d3ad
make variable getting logic a little less horrible
 Jeff Hammel <jhammel@mozilla.com> parents: 
112diff
changeset | 141 # boilerplate | 
| 63 
b91133e3b02d
override get_variables for API template; could instead do this in the ctor, alternately
 Jeff Hammel <jhammel@mozilla.com> parents: 
62diff
changeset | 142 vars = self.get_variables(**variables) | 
| 62 
30100690ad3f
display defaults with command line --help option
 Jeff Hammel <jhammel@mozilla.com> parents: 
58diff
changeset | 143 missing = set([]) | 
| 64 | 144 | 
| 145 # get known needed variables | |
| 146 for var in self.vars: | |
| 113 
c3b8ce33d3ad
make variable getting logic a little less horrible
 Jeff Hammel <jhammel@mozilla.com> parents: 
112diff
changeset | 147 if var.name not in vars: | 
| 99 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 148 if var.default is Undefined: | 
| 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 149 missing.add(var.name) | 
| 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 150 continue | 
| 100 
b54898f7d8a9
now API template variables seem to work
 Jeff Hammel <jhammel@mozilla.com> parents: 
99diff
changeset | 151 if (not self.usedefaults) and (not var.isset()): | 
| 99 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 152 missing.add(var.name) | 
| 64 | 153 | 
| 113 
c3b8ce33d3ad
make variable getting logic a little less horrible
 Jeff Hammel <jhammel@mozilla.com> parents: 
112diff
changeset | 154 # scan templates for other variables | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 155 if self.look: | 
| 99 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 156 template = PolyTemplate(self._templates, | 
| 112 | 157 interactive=False, | 
| 99 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 158 variables=vars) | 
| 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 159 missing.update(template.missing()) | 
| 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 160 | 
| 64 | 161 return missing | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 162 | 
| 101 | 163 def pre(self, variables, output): | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 164 """do stuff before interpolation""" | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 165 | 
| 100 
b54898f7d8a9
now API template variables seem to work
 Jeff Hammel <jhammel@mozilla.com> parents: 
99diff
changeset | 166 def substitute(self, variables, output=None): | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 167 """do the substitution""" | 
| 113 
c3b8ce33d3ad
make variable getting logic a little less horrible
 Jeff Hammel <jhammel@mozilla.com> parents: 
112diff
changeset | 168 | 
| 
c3b8ce33d3ad
make variable getting logic a little less horrible
 Jeff Hammel <jhammel@mozilla.com> parents: 
112diff
changeset | 169 # get the variables | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 170 vars = self.get_variables(**variables) | 
| 101 | 171 self.pre(vars, output) | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 172 self.check_missing(vars) | 
| 64 | 173 | 
| 174 # do the substitution | |
| 67 
a0f7bfa98755
API templates now hobble along on their own two feet
 Jeff Hammel <jhammel@mozilla.com> parents: 
66diff
changeset | 175 template = PolyTemplate(self._templates, | 
| 
a0f7bfa98755
API templates now hobble along on their own two feet
 Jeff Hammel <jhammel@mozilla.com> parents: 
66diff
changeset | 176 interactive=self.interactive, | 
| 
a0f7bfa98755
API templates now hobble along on their own two feet
 Jeff Hammel <jhammel@mozilla.com> parents: 
66diff
changeset | 177 variables=vars) | 
| 88 
712a6d358083
fixed output broke other things
 Jeff Hammel <jhammel@mozilla.com> parents: 
78diff
changeset | 178 template.check_output(output) | 
| 90 
26b9c3bba04e
make the api for substitute() variables, output
 Jeff Hammel <jhammel@mozilla.com> parents: 
88diff
changeset | 179 template.substitute({}, output) | 
| 113 
c3b8ce33d3ad
make variable getting logic a little less horrible
 Jeff Hammel <jhammel@mozilla.com> parents: 
112diff
changeset | 180 | 
| 
c3b8ce33d3ad
make variable getting logic a little less horrible
 Jeff Hammel <jhammel@mozilla.com> parents: 
112diff
changeset | 181 # do whatever you need to do afterwards | 
| 101 | 182 self.post(vars, output) | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 183 | 
| 101 | 184 def post(self, variables, output): | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 185 """do stuff after interpolation""" | 
| 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 186 | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 187 def read_variables(self, variables): | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 188 """read variables from stdin""" | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 189 retval = {} | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 190 for i in variables: | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 191 if i in self.vardict: | 
| 99 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 192 value = self.vardict[i].read() | 
| 
d9c6e26a42ff
fix up interactivity of API template a bit.  still doesnt quite work
 Jeff Hammel <jhammel@mozilla.com> parents: 
90diff
changeset | 193 retval[i] = value | 
| 44 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 194 else: | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 195 retval.update(ContentTemplate.read_variables(self, (i,))) | 
| 
6e08cca7d656
do API variable reading and stubbing a bit for control flow
 Jeff Hammel <jhammel@mozilla.com> parents: 
42diff
changeset | 196 return retval | 
| 41 
9956e13558dd
stub out what API templates will look like; put these in a separate file as theres no reason to clutter up the command line entry point any further
 Jeff Hammel <jhammel@mozilla.com> parents: diff
changeset | 197 | 
| 42 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 198 class PasteScriptTemplate(MakeItSoTemplate): | 
| 
73dac34d2692
more stubbing of API class; first get something off the ground; then rewrite
 Jeff Hammel <jhammel@mozilla.com> parents: 
41diff
changeset | 199 """template for backwards compatability with PasteScript""" | 
