blob: b112b00602e238dcf9c0432b2771f6ca0b4bb5e3 [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.
#
import mllib
import os
import sys
doc = mllib.xml_parse(os.path.join(os.path.dirname(__file__), "transport.xml"))
mdoc = mllib.xml_parse(os.path.join(os.path.dirname(__file__), "messaging.xml"))
tdoc = mllib.xml_parse(os.path.join(os.path.dirname(__file__), "transactions.xml"))
sdoc = mllib.xml_parse(os.path.join(os.path.dirname(__file__), "security.xml"))
def eq(attr, value):
return lambda nd: nd[attr] == value
TYPEStmp = doc.query["amqp/section/type", eq("@class", "composite")] + \
mdoc.query["amqp/section/type", eq("@class", "composite")] + \
tdoc.query["amqp/section/type", eq("@class", "composite")] + \
sdoc.query["amqp/section/type", eq("@class", "composite")] + \
mdoc.query["amqp/section/type", eq("@provides", "section")]
TYPES = []
for ty in TYPEStmp:
if ty not in TYPES:
TYPES.append(ty)
RESTRICTIONS = {}
COMPOSITES = {}
for type in doc.query["amqp/section/type"] + mdoc.query["amqp/section/type"] + \
sdoc.query["amqp/section/type"] + tdoc.query["amqp/section/type"]:
source = type["@source"]
if source:
RESTRICTIONS[type["@name"]] = source
if type["@class"] == "composite":
COMPOSITES[type["@name"]] = type
def resolve(name):
if name in RESTRICTIONS:
return resolve(RESTRICTIONS[name])
else:
return name
TYPEMAP = {
"boolean": ("bool", "", ""),
"binary": ("pn_binary_t", "*", ""),
"string": ("wchar_t", "*", ""),
"symbol": ("char", "*", ""),
"ubyte": ("uint8_t", "", ""),
"ushort": ("uint16_t", "", ""),
"uint": ("uint32_t", "", ""),
"ulong": ("uint64_t", "", ""),
"timestamp": ("uint64_t", "", ""),
"list": ("pn_list_t", "*", ""),
"map": ("pn_map_t", "*", ""),
"box": ("pn_box_t", "*", ""),
"*": ("pn_object_t", "*", "")
}
CONSTRUCTORS = {
"boolean": "boolean",
"string": "string",
"symbol": "symbol",
"ubyte": "ubyte",
"ushort": "ushort",
"uint": "uint",
"ulong": "ulong",
"timestamp": "ulong"
}
NULLABLE = set(["string", "symbol"])
def fname(field):
return field["@name"].replace("-", "_")
def tname(t):
return t["@name"].replace("-", "_")
def multi(f):
return f["@multiple"] == "true"
def ftype(field):
if multi(field):
return "list"
elif field["@type"] in COMPOSITES:
return "box"
else:
return resolve(field["@type"]).replace("-", "_")
def fconstruct(field, expr):
type = ftype(field)
if type in CONSTRUCTORS:
result = "pn_%s(mem, %s)" % (CONSTRUCTORS[type], expr)
if type in NULLABLE:
result = "%s ? %s : NULL" % (expr, result)
else:
result = expr
if multi(field):
result = "pn_box(mem, pn_boolean(mem, true), %s)" % result
return result
def declaration(field):
name = fname(field)
type = ftype(field)
t, pre, post = TYPEMAP.get(type, (type, "", ""))
return t, "%s%s%s" % (pre, name, post)
def field_kw(field):
return fname(field).upper()