Esempio n. 1
0
    def test_nums(self):
        s = '''
        66
        '''

        result = DeclareRvalue().parse(s)
        self.assertEqual(result['format_items'][0], '66')
Esempio n. 2
0
    def test_str_cat(self):
        s = '''
        "abc" + "111"
        '''

        result = DeclareRvalue().parse(s)
        self.assertCountEqual(result['format_items'], ['"abc"', '+', '"111"'])
Esempio n. 3
0
    def test_class_attr(self):
        s = '''
        DateTime.Today
        '''

        result = DeclareRvalue().parse(s)
        self.assertCountEqual(result['format_items'], ['DateTime.Today'])
Esempio n. 4
0
    def test_param_str(self):
        s = '''
        @"@@KWRawPath@@"; //comment'
        '''

        result = DeclareRvalue().parse(s)
        self.assertCountEqual(result['format_items'], ['@"@@KWRawPath@@"'])
Esempio n. 5
0
    def test_bool(self):
        s = '''
        false 
        '''

        result = DeclareRvalue().parse(s)
        self.assertCountEqual(result['format_items'], ['false'])
Esempio n. 6
0
    def test_func_chain(self):
        s = '''
        DateTime.Parse("@@RunDate@@")
        '''

        result = DeclareRvalue().parse(s)
        self.assertCountEqual(result['format_items'],
                              ['DateTime.Parse("@@RunDate@@")'])
Esempio n. 7
0
    def test_func_chain_int_parse(self):
        s = '''
        int.Parse("@@AuctionDataGetRatio@@");
        '''

        result = DeclareRvalue().parse(s)
        self.assertCountEqual(result['format_items'],
                              ['int.Parse("@@AuctionDataGetRatio@@")'])
Esempio n. 8
0
    def test_func_param_str_cat(self):
        s = '''
        DateTime.Parse("2018" + " " + "20" + ":00:00") 
        '''

        result = DeclareRvalue().parse(s)
        self.assertCountEqual(result['format_items'],
                              ['DateTime.Parse("2018"+" "+"20"+":00:00")'])
Esempio n. 9
0
    def test_ref_func_chain(self):
        s = '''
        @RunDate.AddDays(-6).ToString("yyyy-MM-dd") 
        '''

        result = DeclareRvalue().parse(s)
        self.assertCountEqual(result['format_items'],
                              ['@RunDate.AddDays(-6).ToString("yyyy-MM-dd")'])
Esempio n. 10
0
    def test_format_str_param(self):
        s = '''
        string.Format(@IdNamePath, @BidOptFolder, @RunDateTime, "OrderItemIdNameMap") 
        '''

        result = DeclareRvalue().parse(s)
        self.assertCountEqual(
            result['format_items'],
            ['@BidOptFolder', '@RunDateTime', '"OrderItemIdNameMap"'])
Esempio n. 11
0
    def test_str_format_item_str(self):
        s = '''
        string.Format("{0}/{1:yyyy/MM/dd}/Delta{2}_", @"/local/prod/pipelines/Optimization/KeywordOpportunity/Preparations/MPIProcessing/Debug", DateTime.Parse(@RunDate), @DateDelta); 
        '''

        result = DeclareRvalue().parse(s)
        self.assertTrue(result['format_str'] == '{0}/{1:yyyy/MM/dd}/Delta{2}_')
        self.assertCountEqual(result['format_items'], [
            '@"/local/prod/pipelines/Optimization/KeywordOpportunity/Preparations/MPIProcessing/Debug"',
            'DateTime.Parse(@RunDate)', '@DateDelta'
        ])
Esempio n. 12
0
    def test_str_format_query_param(self):
        s = '''
        string.Format("{0}/BidEstimation/Result/%Y/%m/KeywordAuction_%Y-%m-%d.ss?date={1:yyyy-MM-dd}", @BTEPath, @BTERunDate);
        '''

        result = DeclareRvalue().parse(s)
        self.assertTrue(
            result['format_str'] ==
            '{0}/BidEstimation/Result/%Y/%m/KeywordAuction_%Y-%m-%d.ss?date={1:yyyy-MM-dd}'
        )
        self.assertCountEqual(result['format_items'],
                              ['@BTEPath', '@BTERunDate'])
Esempio n. 13
0
    def test_str_format_item_fun(self):
        s = '''
        string.Format(@"{0}/Preparations/MPIProcessing/{1:yyyy/MM/dd}/Campaign_TargetInfo_{1:yyyyMMdd}.ss", @KWRawPath,  DateTime.Parse(@RunDate));
        '''

        result = DeclareRvalue().parse(s)
        self.assertTrue(
            result['format_str'] ==
            '{0}/Preparations/MPIProcessing/{1:yyyy/MM/dd}/Campaign_TargetInfo_{1:yyyyMMdd}.ss'
        )
        self.assertCountEqual(result['format_items'],
                              ['@KWRawPath', 'DateTime.Parse(@RunDate)'])
Esempio n. 14
0
class ScopeResolver(object):
    logger = logging.getLogger(__name__)

    def __init__(self):
        self.dr = DeclareRvalue()
        self.default_datetime_obj = datetime.now() - timedelta(5)
        pass

    def check_and_eval_extend_str_cat(self, the_str):
        self.logger.debug('check_and_eval_extend_str_cat [{}]'.format(the_str))
        # for case "2018-01-01 " + 22 + ":00:00"
        if ParseUtil.is_extend_str_cat(the_str):
            parts = []
            for part in the_str.split('+'):
                part = part.strip()

                if not part.startswith('"'):
                    parts.append('"{}"'.format(part))
                    continue

                parts.append(part)

            to_eval = '+'.join(parts)
            self.logger.info(
                'found extend_str_cat, change to_eval from [{}] to [{}]'.
                format(the_str, to_eval))

            # make it also look like string
            return '"{}"'.format(eval(to_eval))

        return the_str

    def resolve_datetime_parseexact(self, the_str, declare_map):
        ''' The params of DateTime.ParseExact is different from DateTime.Parse
        We need to process this separately

        :param the_str:
        :param declare_map:
        :return:
        '''
        match = re.match(r'DateTime\.ParseExact?\((.*?)\)', the_str)

        if match:
            param = match.group(1)

            items = param.split(',')
            the_datetime_str = items[0]
            # don't care the format and other calibration

            the_datetime_str = self.replace_declare_items(
                the_datetime_str, declare_map)
            the_datetime_str = declare_map.get(the_datetime_str,
                                               the_datetime_str)
            the_datetime_str = self.check_and_eval_extend_str_cat(
                the_datetime_str)

            if isinstance(the_datetime_str, str):
                # clean up before parsing
                the_datetime_str = the_datetime_str.replace('"', '')
                the_datetime_str = the_datetime_str.replace("'", '')

                self.logger.debug(
                    'try to do datetime parse [{}]'.format(the_datetime_str))
                the_datetime_str = parser.parse(the_datetime_str)

            return the_datetime_str

        return the_str

    def resolve_datetime_parse(self, the_str, declare_map):
        match = re.match(r'DateTime\.Parse?\((.*?)\)', the_str)

        if match:
            param = match.group(1)
            param = self.replace_declare_items(param, declare_map)
            param = declare_map.get(param, param)
            param = self.check_and_eval_extend_str_cat(param)

            if isinstance(param, str):
                # clean up before parsing
                param = param.replace('"', '')
                param = param.replace("'", '')

                self.logger.debug(
                    'try to do datetime parse [{}]'.format(param))
                param = parser.parse(param)

            return param

    def resolve_datetime_related(self, format_item, declare_map):
        self.logger.debug(
            'resolve_datetime_related of [{}]'.format(format_item))

        the_data = None
        datetime_obj = None

        try:

            the_obj_name = format_item.split('.')[0]
            if the_obj_name in declare_map:
                datetime_obj = declare_map[the_obj_name]

            if 'DateTime.ParseExact' in format_item:
                datetime_obj = self.resolve_datetime_parseexact(
                    format_item, declare_map)
                self.logger.debug(
                    'parsed datetime_obj = {}'.format(datetime_obj))
            elif 'DateTime.Parse' in format_item:
                datetime_obj = self.resolve_datetime_parse(
                    format_item, declare_map)
                self.logger.debug(
                    'parsed datetime_obj = {}'.format(datetime_obj))

            if 'AddDays' in format_item:
                datetime_obj = self.process_add_days(datetime_obj, format_item)

            if 'ToString' in format_item:
                if datetime_obj:
                    the_data = self.process_to_string(datetime_obj,
                                                      format_item)

            if not the_data:
                the_data = datetime_obj

            return the_data, datetime_obj
        except Exception as ex:
            self.logger.warning(
                "Exception occurs while resolving dates of [{}]: {}, use default datetime_obj instead",
                format_item, ex)
            return the_data, datetime.now()

    def resolve_basic(self, format_items, declare_map):
        ret = []

        datetime_obj = None

        for format_item in format_items:
            if format_item in declare_map:
                the_data = declare_map[format_item]
            else:
                if 'DateTime' in format_item or 'AddDays' in format_item or 'ToString' in format_item:
                    the_data, datetime_obj = self.resolve_datetime_related(
                        format_item, declare_map)
                else:
                    # change
                    match = re.match('@"(.*)"', format_item)
                    if match:
                        the_data = match.group(1)
                    else:
                        the_data = format_item

            ret.append(the_data)

        # add quote for strings
        for i, item in enumerate(ret):
            try:
                _ = int(item)
            except ValueError:
                # it's string
                if not item.startswith('"') and item not in [
                        '+', '-', '*', '/'
                ]:
                    ret[i] = '"{}"'.format(ret[i])

        to_eval = ''.join(ret)

        to_eval = self.check_and_eval_extend_str_cat(to_eval)

        self.logger.debug('prepare to eval [{}]'.format(to_eval))
        result = eval(to_eval)

        # final checking fot %Y %m %d
        if datetime_obj:
            result = self.to_python_datetime_format(result)
            result = datetime_obj.strftime(result)

        return result

    def is_time_format(self, the_str):
        if 'yyyy' in the_str: return True
        if 'MM' in the_str: return True
        if 'dd' in the_str: return True
        if 'HH' in the_str: return True

        return False

    @staticmethod
    def to_normalized_time_format(the_str):
        return the_str.replace('yyyy', '%Y')\
                      .replace('MM', '%m')\
                      .replace('dd', '%d')\
                      .replace('HH', '%H')\
                      .replace('mm', '%M')\
                      .replace('ss', '%S')

    def process_to_string(self, the_obj, func_str):
        found = re.findall('ToString\((.*?)\)', func_str)
        if found:
            if self.is_time_format(found[0]):
                try:
                    return the_obj.strftime(
                        self.to_normalized_time_format(found[0]))
                except Exception as ex:
                    logging.warning(
                        "failed doing strftime of [{}]: {}, fall back to try any date instead."
                        .format(the_obj, ex))
                    return datetime.now().strftime(
                        self.to_normalized_time_format(found[0]))

            return str(the_obj)

        return the_obj

    def process_add_days(self, datetime_obj, func_str):
        found = re.findall('AddDays\((.*?)\)', func_str)
        if found:
            self.logger.debug('datetime_obj = [{}], found AddDays [{}]'.format(
                datetime_obj, found))
            return datetime_obj + timedelta(int(found[0].replace(
                ' ', '')))  # clean flexible SCOPE format " - 3"

        return datetime_obj

    def do_run_replace(self, func_str, declare_map):
        the_obj_name = func_str.split('.')[0]

        value = the_obj_name
        if the_obj_name in declare_map:
            value = declare_map[the_obj_name]

        match = re.search(r'\.Replace\("(.*?)".*,.*?"(.*)".*\)', func_str)
        if match:
            key = match.group(1)
            replace_to = match.group(2)

            return value.replace(key, replace_to)

        return func_str

    def do_run_trim(self, func_str, declare_map):
        the_obj_name = func_str.split('.')[0]

        value = the_obj_name
        if the_obj_name in declare_map:
            value = declare_map[the_obj_name]

        match = re.match(r'.*\.TrimEnd\((.*)\)', func_str)
        if match:
            target_chars = match.group(1).replace("'", '').split(',')
            return value.rstrip(target_chars)

        match = re.match(r'.*\.Trim\((.*)\)', func_str)
        if match:
            target_chars = match.group(1).replace("'", '').split(',')
            return value.strip(target_chars)

        return func_str

    def resolve_func(self, func_str, declare_map={}):
        self.logger.debug('resolve_func of {}'.format(func_str))

        func_str = func_str.strip()
        params = re.findall(r'\((.*?)\)', func_str)
        param = params[0].lstrip('"').rstrip('"')

        self.logger.debug('param = {}'.format(param))
        param = self.replace_declare_items(param, declare_map)
        self.logger.debug(
            'param after replace_declare_items = {}'.format(param))

        result = func_str

        if 'DateTime.Parse' in func_str or 'AddDays' in func_str:
            result, _ = self.resolve_datetime_related(func_str, declare_map)
            self.logger.debug('resolved [{}] as datetime_obj {}'.format(
                func_str, result))
        elif func_str.startswith('int.Parse') or func_str.startswith(
                'Int32.Parse'):
            result = int(param)
        elif func_str.startswith('Math.Abs'):
            self.logger.debug('Math.Abs of [{}]'.format(param))
            result = abs(int(param))
        elif 'ToString' in func_str:
            # check if it's DateTime.ToString('xxx')
            the_obj_name = func_str.split('.')[0]

            if the_obj_name in declare_map:
                datetime_obj = declare_map[the_obj_name]
                result = self.process_to_string(datetime_obj, func_str)
        elif 'Replace(' in func_str:
            result = self.do_run_replace(func_str, declare_map)
        elif 'Trim(' in func_str or 'TrimEnd(' in func_str:
            result = self.do_run_trim(func_str, declare_map)

        if 'ToString()' in func_str:
            # purely to string
            result = str(result)

        return result

    def resolve_ymd(self, fmt_str, datetime_obj):
        return datetime_obj.strftime(fmt_str)

    def get_format_str_declared(self, format_str, declare_map):
        if not format_str:
            return format_str

        # CASE: string.Format(@IdNamePath, @BidOptFolder, @RunDateTime, "OrderItemIdNameMap")
        if '@' + format_str in declare_map:
            format_str = declare_map['@' + format_str]

        return format_str

    def convert_datetime_obj(self, datetime_obj):
        if isinstance(datetime_obj, str):
            self.logger.warning(
                'datetime_obj is str [{}], try to parse it.'.format(
                    datetime_obj))
            return parser.parse(datetime_obj)

        return datetime_obj

    def has_datetime_format(self, the_str):
        if 'yyyy' in the_str or\
           'MM' in the_str or\
           'dd' in the_str or\
           '%Y' in the_str or\
           '%m' in the_str or\
           '%d' in the_str or\
           '%H' in the_str or\
           '%h' in the_str or\
           '%M' in the_str or\
           '%S' in the_str:
            return True

        return False

    def get_implicit_datetime_obj(self, format_str, format_items, declare_map):
        if self.has_datetime_format(format_str):
            datetime_obj = None

            # use the first occurrence
            for format_item in format_items:
                # check if it's declared
                format_item = declare_map.get(format_item, format_item)

                try:
                    datetime_obj = parser.parse(format_item)
                    return datetime_obj
                except Exception:
                    pass

        return None

    def to_python_datetime_format(self, format_str):
        return format_str.replace('%h', '%H')

    def resolve_str_format(self, format_str, format_items, declare_map):
        self.logger.debug(
            'resolve_str_format of [{}], format_items = [{}]'.format(
                format_str, format_items))

        format_str = self.get_format_str_declared(format_str, declare_map)
        format_str = self.check_and_eval_extend_str_cat(format_str)

        # special handling for %n - streamset format placeholder
        format_str = format_str.replace('%n', '1')  # fixed

        placeholders = re.findall(r'{(.*?)}', format_str)

        datetime_obj = None

        # resolve placeholder values and find if any datetime obj
        for i, format_item in enumerate(format_items):
            # check if Datetime related. Use last occurrence as hidden datetime obj
            _, tmp_datetime_obj = self.resolve_datetime_related(
                format_item, declare_map)

            if tmp_datetime_obj:
                datetime_obj = tmp_datetime_obj

            format_items[i] = self.resolve_declare_rvalue(
                None, format_item, declare_map)

        self.logger.debug('format_items = ' + str(format_items))

        replace_map = {}

        for ph in placeholders:
            if ':' in ph:
                idx, fmt = ph.split(':')
                replace_to = format_items[int(idx)]

                self.logger.debug('fmt = {}, idx = {}'.format(fmt, idx))
                if self.has_datetime_format(fmt):
                    item = format_items[int(idx)]

                    if item in declare_map:
                        datetime_obj = declare_map[item]
                    else:
                        datetime_obj = item

                    datetime_obj = self.convert_datetime_obj(datetime_obj)

                    date_Y = datetime_obj.strftime('%Y')
                    date_m = datetime_obj.strftime('%m')
                    date_d = datetime_obj.strftime('%d')
                    date_h = datetime_obj.strftime('%H')
                    date_M = datetime_obj.strftime('%M')
                    date_S = datetime_obj.strftime('%S')

                    replace_to = fmt.replace('yyyy', date_Y)\
                                    .replace('MM', date_m)\
                                    .replace('dd', date_d)\
                                    .replace('HH', date_h)\
                                    .replace('mm', date_M)\
                                    .replace('ss', date_S)
            else:
                idx = ph
                replace_to = format_items[int(idx)]

            if not replace_to in replace_map:
                replace_map[replace_to] = []

            replace_map[replace_to].append('{' + ph + '}')

        result = format_str

        self.logger.debug('replace_map = ' + str(replace_map))

        for key in replace_map:
            if key in declare_map:
                value = declare_map[key]
            else:
                value = key

            for to_replace_str in replace_map[key]:
                result = result.replace(to_replace_str, str(value))

        if not datetime_obj:
            datetime_obj = self.get_implicit_datetime_obj(
                format_str, format_items, declare_map)

        # final checking fot %Y %m %d
        if datetime_obj:
            # implicit datetime in SCOPE
            if isinstance(datetime_obj, str):
                datetime_obj = parser.parse(datetime_obj)

            result = self.to_python_datetime_format(result)
            result = datetime_obj.strftime(result)

        return result

    def is_int(self, item):
        try:
            int(item)
            return True
        except Exception:
            return False

    def is_datetime(self, item):
        return isinstance(item, datetime)

    def replace_declare_items(self, s, declare_map):
        recur_max = 5

        while recur_max > 0:
            self.logger.debug(
                'replace_declare_items of [{}], recur_max = {}'.format(
                    s, recur_max))
            #            items = re.findall(r'([^@]@[^ ,/\)\@]+)', s)
            items = re.findall(r'([^@]?@[^ ,/\)\@]+)', s)

            self.logger.debug('items = [{}]'.format(items))
            if len(items) == 0:
                break

            # special handling for datetime assignment, CASE: #DECLARE ObjDate DateTime = @PDATE;
            if len(items
                   ) == 1 and items[0] in declare_map and self.is_datetime(
                       declare_map[items[0]]):
                if s.strip().startswith('@'):
                    self.logger.debug(
                        'found pure datetime assignment str [{}], return datetime object'
                        .format(s))
                    return declare_map[items[0]]

            tmp = s
            for item in items:
                if item.startswith('@@'):
                    continue  # ignore external params

                item = item.replace('(', '').strip()

                if item in declare_map:
                    self.logger.debug(
                        'item {} in declare_map, value = [{}]'.format(
                            item, declare_map[item]))
                    if self.is_int(declare_map[item]):
                        tmp = tmp.replace(item, str(declare_map[item]))
                    else:
                        tt = '"{}"'.format(declare_map[item]).replace(
                            '""', '"')  # wrong format while replacing

                        # for merged single quotedString, remove incorrect double quote inside
                        if tt.startswith('"') and tt.endswith(
                                '"') and '+' not in tt:
                            tt = '"{}"'.format(tt.replace('"', ''))

                        tmp = tmp.replace(item, tt)

                        self.logger.debug(
                            'replace declare item [{}] to [{}], type is [{}]'.
                            format(item, tt, type(tt)))
                else:
                    self.logger.debug(
                        'item [{}] is not in declare_map'.format(item))

            if tmp == s:
                # no update, break
                break

            s = tmp

            # to prevent infinite loop.
            # CASE: #SET OutputFolder = @OutputFolder + @OrderItemId + "/";
            recur_max -= 1

        return s

    def replace_ref_strings(self, s):
        self.logger.debug('replace_ref_strings of [{}]'.format(s))

        # CASE: "/path/to"/subpath"
        if s.startswith('"') and s.endswith('"') and '+' not in s:
            s = '"{}"'.format(s.replace('"', ''))

        return re.sub(r'@(".*?")', '\g<1>', s)

    def replace_uncaught_external_params(self, s, declare_map):
        '''
        #DECLARE ReportLevel int = 0;
        #IF(NOT "@@ReportLevel@@".Contains("ReportLevel"))
            #SET ReportLevel = int.Parse("@@ReportLevel@@");
        #ENDIF
        '''

        match = re.search('@@(.*)@@', s)
        if match and '@' + match.group(1) in declare_map:
            return s.replace(match.group(0), '@{}'.format(match.group(1)))

        return s

    def resolve_boolean(self, s):
        if s == 'true':
            return True

        return False

    def resolve_class_attr(self, s):
        ''' Limited support for encountered type only
        Add more if you need

        :param s:
        :return:
        '''
        if s == 'DateTime.Today':
            return datetime.today()

    def search_inner_str_format(self, s):
        results = re.findall(r'.*?([sS]tring\.Format\(.*\))', s)

        return results

    def resolve_inner_str_format(self, s, declare_map):
        replace_map = {}

        for str_format_part in self.search_inner_str_format(s):
            self.logger.debug('str_format_part = [{}]'.format(str_format_part))

            ret_declare_rvalue = self.dr.parse(str_format_part)

            format_str = ret_declare_rvalue['format_str']
            format_items = ret_declare_rvalue['format_items']
            type_ = ret_declare_rvalue['type']

            if type_ != 'format_str':
                self.logger.warning(
                    '?? resolve_inner_str_format gets not recognized format')
                continue

            replace_map[str_format_part] = '"{}"'.format(
                self.resolve_str_format(format_str, format_items, declare_map))

        result = s
        for key in replace_map:
            result = result.replace(key, replace_map[key])

        # clean up double double quotes if any because we added it
        result = result.replace('""', '"')

        return result

    def resolve_set_rvalue(self, rvalue, declare_map):
        # for SET operation, resolve current declare_map first
        #        self.scope_resolver.resolve_declare(declare_map)

        return self.resolve_declare_rvalue(None, rvalue, declare_map)

    def resolve_declare_rvalue(self, declare_lvalue, declare_rvalue,
                               declare_map):
        self.logger.debug(
            'resolve_declare_rvalue: declare_lvalue [{}], declare_rvalue [{}]'.
            format(declare_lvalue, declare_rvalue))

        try:
            declare_rvalue = self.replace_uncaught_external_params(
                declare_rvalue, declare_map)

            # replace local reference of @"strings"
            declare_rvalue = self.replace_ref_strings(declare_rvalue)

            # replace those declare items inside rvalue, if any remains
            declare_rvalue = self.replace_declare_items(
                declare_rvalue, declare_map)

            # special handling for datetime object, no parsing, just keep it
            if self.is_datetime(declare_rvalue):
                return declare_rvalue

            # special handling inner string.Format
            declare_rvalue = self.resolve_inner_str_format(
                declare_rvalue, declare_map)

            self.logger.debug(
                'finished replace_declare_items, start to parse [{}].'.format(
                    declare_rvalue))
            ret_declare_rvalue = self.dr.parse(declare_rvalue)
        except Exception as ex:
            self.logger.warning(
                'Exception in resolve_declare_rvalue: {}'.format(ex))
            self.logger.warning('declare_rvalue = {}'.format(declare_rvalue))

            return declare_rvalue

        format_str = ret_declare_rvalue['format_str']
        format_items = ret_declare_rvalue['format_items']
        type_ = ret_declare_rvalue['type']

        self.logger.debug('declare_rvalue type is [{}]'.format(type_))

        format_str = self.get_format_str_declared(format_str, declare_map)

        result = ""

        # update declare_map
        if type_ == 'func_chain':
            self.logger.info(
                'found func_chain, update declare value of [{}]'.format(
                    declare_lvalue))
            self.logger.debug('format_items = ' + str(format_items))
            result = self.resolve_func(format_items[0], declare_map)
        elif type_ == 'format_str':
            result = self.resolve_str_format(format_str, format_items,
                                             declare_map)
        elif type_ == "str_cat":
            try:
                result = self.resolve_basic(format_items, declare_map)
            except Exception as ex:
                self.logger.warning('error resolving [{}]: {}'.format(
                    declare_rvalue, ex))
                result = format_items[0]
        elif type_ == 'nums':
            result = format_items[0]
        elif type_ == 'boolean':
            result = self.resolve_boolean(format_items[0])
        elif type_ == 'class_attr':
            result = self.resolve_class_attr(format_items[0])

        self.logger.debug('[resolve_declare_rvalue] result = ' + str(result))

        # post process to change @"str" to pure "str"
        if isinstance(result, str) and '@"' in result:
            match = re.match(r'@"(.*)"', result)
            if match:
                result = match.group(1)

        # post process to remove double quotes
        if isinstance(result, str):
            result = result.lstrip('"').rstrip('"')

        return result

    def resolve_declare(self, declare_map):
        for declare_lvalue in declare_map:
            try:
                declare_rvalue = declare_map[declare_lvalue]

                resolved = self.resolve_declare_rvalue(declare_lvalue,
                                                       declare_rvalue,
                                                       declare_map)
                self.logger.info(
                    'update resolved [{}] to [{}] type [{}]'.format(
                        declare_lvalue, resolved, type(resolved)))
                declare_map[declare_lvalue] = resolved
            except Exception as ex:
                self.logger.debug(
                    'Exception in resolve_declare: {}'.format(ex))
                # ignore unsupported syntax
                pass
Esempio n. 15
0
 def __init__(self):
     self.dr = DeclareRvalue()
     self.default_datetime_obj = datetime.now() - timedelta(5)
     pass