summaryrefslogtreecommitdiffstats
path: root/sca-cpp/trunk/components/logic/nuvem/lookup.py
blob: d61d032636d74646bfadfaf8bd4b180cb4f990f0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#  Licensed to the Apache Software Foundation (ASF) under one
#  or more contributor license agreements.  See the NOTICE file
#  distributed with this work for additional information
#  regarding copyright ownership.  The ASF licenses this file
#  to you 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.

# Return a list of name value pairs that match a name
def get(r, n, l):
    def isList(v):
        if getattr(v, '__iter__', False) == False:
            return False
        if isinstance(v, basestring) or isinstance(v, dict):
            return False
        return True

    def isAssoc(v):
        return isList(v) and len(v) == 2 and isinstance(v[0], basestring) and v[0][0:1] == "'"

    def lookup(nv, lv):
        if lv == ():
            return ()

        # Check if list element is a name value pair assoc
        a = lv[0]
        if not isAssoc(a):
            return lookup(nv, lv[1:])

        # Got a match, return it and lookup rest of the list
        an = "'" + a[0][2:] if a[0][0:2] == "'@" else a[0]
        if an == nv:
            return (a,) + lookup(nv, lv[1:])

        # No match, lookup rest of the list
        return lookup(nv, lv[1:])

    def qsymbol(x):
        if not isinstance(x, basestring):
            return x
        return x if x[0:1] == "'" else "'" + x

    nv = n.get(r)
    lv = l.get(r)
    return lookup(qsymbol(nv), () if lv is None else lv)