blob: bf10a756a4dce38c683a8fadd50838cd3ee40266 [file] [log] [blame]
# 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
# Search through nested lists of name value pairs
def get(r, p, 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(pv, lv):
if lv == ():
return ()
if isAssoc(lv):
lv = (lv,)
# Check if list element is a name value pair assoc
a = lv[0]
if not isAssoc(a):
# Lookup children if any and rest of list
if isList(a):
return lookup(pv, a) + lookup(pv, lv[1:])
return lookup(pv, lv[1:])
# Path segment match
an = "'" + a[0][2:] if a[0][0:2] == "'@" else a[0]
if an == pv[0]:
# Found leaf, return it and lookup rest of the list
if len(pv) == 1:
return (a,) + lookup(pv, lv[1:])
# Continue to lookup children if any plus rest of the list
return lookup(pv[1:], a[1:]) + lookup(pv, lv[1:])
# No match, lookup any children and rest of the list
if (isList(a[1])):
return lookup(pv, a[1]) + lookup(pv, a[2:]) + lookup(pv, lv[1:])
return lookup(pv, a[2:]) + lookup(pv, lv[1:])
def qsymbol(x):
if not isinstance(x, basestring):
return x
return x if x[0:1] == "'" else "'" + x
# Support path as a list or a dot separated string
lv = l.get(r)
pv = p.get(r)
if (isList(pv)):
return lookup(map(qsymbol, pv), () if lv is None else lv)
spv = map(qsymbol, qsymbol(pv)[1:].split('.'))
return lookup(spv, () if lv is None else lv)