Bases: RompyBaseModel
Base class for model templates.
The template class provides the object that is used to set up the model configuration.
When implemented for a given model, can move along a scale of complexity
to suit the application.
In its most basic form, as implemented in this base object, it consists of path to a cookiecutter template
with the class providing the context for the {{config}} values in that template. Note that any
{{runtime}} values are filled from the ModelRun object.
If the template is a git repo, the checkout parameter can be used to specify a branch or tag and it
will be cloned and used.
If the object is callable, it will be colled prior to rendering the template. This mechanism can be
used to perform tasks such as fetching exteral data, or providing additional context to the template
beyond the arguments provided by the user..
Source code in rompy/core/config.py
| class BaseConfig(RompyBaseModel):
"""Base class for model templates.
The template class provides the object that is used to set up the model configuration.
When implemented for a given model, can move along a scale of complexity
to suit the application.
In its most basic form, as implemented in this base object, it consists of path to a cookiecutter template
with the class providing the context for the {{config}} values in that template. Note that any
{{runtime}} values are filled from the ModelRun object.
If the template is a git repo, the checkout parameter can be used to specify a branch or tag and it
will be cloned and used.
If the object is callable, it will be colled prior to rendering the template. This mechanism can be
used to perform tasks such as fetching exteral data, or providing additional context to the template
beyond the arguments provided by the user..
"""
model_type: Literal["base"] = "base"
template: Optional[str] = Field(
description="The path to the model template",
default=DEFAULT_TEMPLATE,
)
checkout: Optional[str] = Field(
description="The git branch to use if the template is a git repo",
default="main",
)
model_config = ConfigDict(extra="allow")
def __call__(self, *args, **kwargs):
return self
|
Attributes
model_type
class-attribute
instance-attribute
model_type: Literal['base'] = 'base'
template
class-attribute
instance-attribute
template: Optional[str] = Field(description='The path to the model template', default=DEFAULT_TEMPLATE)
checkout
class-attribute
instance-attribute
checkout: Optional[str] = Field(description='The git branch to use if the template is a git repo', default='main')
model_config
class-attribute
instance-attribute
model_config = ConfigDict(extra='allow')