
Both properties and methods can be marked as Usage: Static Statics can be accessed using ns:Class.property / ns:Class.method(), :Class.property / :Class.method() to access class from current namespace or type('full.name').property / type('full.name').method() to use full type name. In static method $ / $this are referencing current class rather than object. Static properties are not loaded from object model. Also methods of io.murano.configuration.Linux class are now static. Since static methods can be called on the instance it doesn't break backward compatibility. Implements blueprint: muranopl-statics Change-Id: Ic7c6beed9222f4bca118877a60fdabfdd9d65e5a
83 lines
2.7 KiB
Python
83 lines
2.7 KiB
Python
# Copyright (c) 2014 Mirantis, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
import re
|
|
|
|
import six
|
|
from yaql.language import exceptions as yaql_exceptions
|
|
from yaql.language import expressions
|
|
|
|
from murano.dsl import constants
|
|
from murano.dsl import dsl_types
|
|
from murano.dsl import yaql_integration
|
|
|
|
|
|
class YaqlExpression(dsl_types.YaqlExpression):
|
|
def __init__(self, expression, version):
|
|
self._version = version
|
|
if isinstance(expression, six.string_types):
|
|
self._expression = six.text_type(expression)
|
|
self._parsed_expression = yaql_integration.parse(
|
|
self._expression, version)
|
|
self._file_position = None
|
|
elif isinstance(expression, YaqlExpression):
|
|
self._expression = expression._expression
|
|
self._parsed_expression = expression._parsed_expression
|
|
self._file_position = expression._file_position
|
|
elif isinstance(expression, expressions.Statement):
|
|
self._expression = six.text_type(expression)
|
|
self._parsed_expression = expression
|
|
self._file_position = None
|
|
else:
|
|
raise TypeError('expression is not of supported types')
|
|
|
|
@property
|
|
def expression(self):
|
|
return self._expression
|
|
|
|
@property
|
|
def version(self):
|
|
return self._version
|
|
|
|
@property
|
|
def source_file_position(self):
|
|
return self._file_position
|
|
|
|
@source_file_position.setter
|
|
def source_file_position(self, value):
|
|
self._file_position = value
|
|
|
|
def __repr__(self):
|
|
return 'YAQL(%s)' % self._expression
|
|
|
|
def __str__(self):
|
|
return self._expression
|
|
|
|
@staticmethod
|
|
def is_expression(expression, version):
|
|
if not isinstance(expression, six.string_types):
|
|
return False
|
|
if re.match('^[\s\w\d.]*$', expression):
|
|
return False
|
|
try:
|
|
yaql_integration.parse(expression, version)
|
|
return True
|
|
except yaql_exceptions.YaqlParsingException:
|
|
return False
|
|
|
|
def __call__(self, context):
|
|
if context:
|
|
context[constants.CTX_CURRENT_INSTRUCTION] = self
|
|
return self._parsed_expression.evaluate(context=context)
|