Difference between revisions of "Piraha Parser Discussion"

From Einstein Toolkit Documentation
Jump to: navigation, search
Line 4: Line 4:
 
* New format tag at the top to allow backwards compatibility
 
* New format tag at the top to allow backwards compatibility
 
** RH: possibly in the form similar to activethorns, ie like a global parameter but that is required to be first in the file
 
** RH: possibly in the form similar to activethorns, ie like a global parameter but that is required to be first in the file
 +
** Or could be a structured comment starting with an exclamation mark
 
* Require triple quotes for multiline quotes
 
* Require triple quotes for multiline quotes
 +
* Require quotes for all strings and keywords
 +
* Disallow quotes for integers and reals
 
* Require yes/no for booleans
 
* Require yes/no for booleans
 
** RH: allowing 1/0 can be useful for parameter file scripts since then the same variable can be used in the scripting languages "if" statement and in the Cactus parameter file (since both "yes" and "no" tend to evaluate as logical true in these languages).  
 
** RH: allowing 1/0 can be useful for parameter file scripts since then the same variable can be used in the scripting languages "if" statement and in the Cactus parameter file (since both "yes" and "no" tend to evaluate as logical true in these languages).  
 
** SRB: We could standardize on True/False instead, if we want to be Python-like.
 
** SRB: We could standardize on True/False instead, if we want to be Python-like.
 
* compiled() option to provide compiled-in values for parameters
 
* compiled() option to provide compiled-in values for parameters
 +
** ES: I prefer the name "fixed" over "compiled", and it doesn't need to look like a function call, it should be more like an attribute of a parameter
 +
* Could have a different format for lists (i.e. ActiveThorns and list of variables that should be output) that doesn't require multi-line strings; this could instead be a list of strings (using e.g. square brackets and commas), which is then converted to a single string after parsing
 +
** This would also get rid of comments-in-strings, and possible multi-line comments
 +
* Could allow "+=" with such lists, so that they don't have to be defined in a single place; this would be useful for I/O variable lists
 +
* The "=" sign should be mandatory when setting parameters

Revision as of 11:57, 12 March 2013

It was suggested that a new improved parser format be put forward, one closer to python.

Suggestions:

  • New format tag at the top to allow backwards compatibility
    • RH: possibly in the form similar to activethorns, ie like a global parameter but that is required to be first in the file
    • Or could be a structured comment starting with an exclamation mark
  • Require triple quotes for multiline quotes
  • Require quotes for all strings and keywords
  • Disallow quotes for integers and reals
  • Require yes/no for booleans
    • RH: allowing 1/0 can be useful for parameter file scripts since then the same variable can be used in the scripting languages "if" statement and in the Cactus parameter file (since both "yes" and "no" tend to evaluate as logical true in these languages).
    • SRB: We could standardize on True/False instead, if we want to be Python-like.
  • compiled() option to provide compiled-in values for parameters
    • ES: I prefer the name "fixed" over "compiled", and it doesn't need to look like a function call, it should be more like an attribute of a parameter
  • Could have a different format for lists (i.e. ActiveThorns and list of variables that should be output) that doesn't require multi-line strings; this could instead be a list of strings (using e.g. square brackets and commas), which is then converted to a single string after parsing
    • This would also get rid of comments-in-strings, and possible multi-line comments
  • Could allow "+=" with such lists, so that they don't have to be defined in a single place; this would be useful for I/O variable lists
  • The "=" sign should be mandatory when setting parameters