Merging 'master' into 'wrap'
commit
ec406dd6db
|
@ -27,10 +27,12 @@ jobs:
|
|||
|
||||
- name: Python Dependencies
|
||||
run: |
|
||||
pip3 install -U pip setuptools
|
||||
pip3 install -r requirements.txt
|
||||
|
||||
- name: Build and Test
|
||||
run: |
|
||||
# Build
|
||||
cmake .
|
||||
cd tests
|
||||
# Use Pytest to run all the tests.
|
||||
|
|
|
@ -192,9 +192,9 @@ function(install_python_files source_files dest_directory)
|
|||
endfunction()
|
||||
|
||||
# ~~~
|
||||
# https://stackoverflow.com/questions/13959434/cmake-out-of-source-build-python-files
|
||||
# Copy over the directory from source_folder to dest_foler
|
||||
# ~~~
|
||||
function(create_symlinks source_folder dest_folder)
|
||||
function(copy_directory source_folder dest_folder)
|
||||
if(${source_folder} STREQUAL ${dest_folder})
|
||||
return()
|
||||
endif()
|
||||
|
@ -215,31 +215,13 @@ function(create_symlinks source_folder dest_folder)
|
|||
# Create REAL folder
|
||||
file(MAKE_DIRECTORY "${dest_folder}")
|
||||
|
||||
# Delete symlink if it exists
|
||||
# Delete if it exists
|
||||
file(REMOVE "${dest_folder}/${path_file}")
|
||||
|
||||
# Get OS dependent path to use in `execute_process`
|
||||
file(TO_NATIVE_PATH "${dest_folder}/${path_file}" link)
|
||||
# Get OS dependent path to use in copy
|
||||
file(TO_NATIVE_PATH "${source_folder}/${path_file}" target)
|
||||
|
||||
# cmake-format: off
|
||||
if(UNIX)
|
||||
set(command ln -s ${target} ${link})
|
||||
else()
|
||||
set(command cmd.exe /c mklink ${link} ${target})
|
||||
endif()
|
||||
# cmake-format: on
|
||||
|
||||
execute_process(
|
||||
COMMAND ${command}
|
||||
RESULT_VARIABLE result
|
||||
ERROR_VARIABLE output)
|
||||
|
||||
if(NOT ${result} EQUAL 0)
|
||||
message(
|
||||
FATAL_ERROR
|
||||
"Could not create symbolic link for: ${target} --> ${output}")
|
||||
endif()
|
||||
file(COPY ${target} DESTINATION ${dest_folder})
|
||||
|
||||
endforeach(path_file)
|
||||
endfunction(create_symlinks)
|
||||
endfunction(copy_directory)
|
||||
|
|
|
@ -62,6 +62,10 @@ class Method:
|
|||
|
||||
self.parent = parent
|
||||
|
||||
def to_cpp(self) -> str:
|
||||
"""Generate the C++ code for wrapping."""
|
||||
return self.name
|
||||
|
||||
def __repr__(self) -> str:
|
||||
return "Method: {} {} {}({}){}".format(
|
||||
self.template,
|
||||
|
@ -84,7 +88,8 @@ class StaticMethod:
|
|||
```
|
||||
"""
|
||||
rule = (
|
||||
STATIC #
|
||||
Optional(Template.rule("template")) #
|
||||
+ STATIC #
|
||||
+ ReturnType.rule("return_type") #
|
||||
+ IDENT("name") #
|
||||
+ LPAREN #
|
||||
|
@ -92,16 +97,18 @@ class StaticMethod:
|
|||
+ RPAREN #
|
||||
+ SEMI_COLON # BR
|
||||
).setParseAction(
|
||||
lambda t: StaticMethod(t.name, t.return_type, t.args_list))
|
||||
lambda t: StaticMethod(t.name, t.return_type, t.args_list, t.template))
|
||||
|
||||
def __init__(self,
|
||||
name: str,
|
||||
return_type: ReturnType,
|
||||
args: ArgumentList,
|
||||
template: Union[Template, Any] = None,
|
||||
parent: Union["Class", Any] = ''):
|
||||
self.name = name
|
||||
self.return_type = return_type
|
||||
self.args = args
|
||||
self.template = template
|
||||
|
||||
self.parent = parent
|
||||
|
||||
|
@ -221,8 +228,8 @@ class Class:
|
|||
Rule for all the members within a class.
|
||||
"""
|
||||
rule = ZeroOrMore(Constructor.rule #
|
||||
^ StaticMethod.rule #
|
||||
^ Method.rule #
|
||||
^ StaticMethod.rule #
|
||||
^ Variable.rule #
|
||||
^ Operator.rule #
|
||||
^ Enum.rule #
|
||||
|
|
|
@ -158,6 +158,8 @@ class Type:
|
|||
"""
|
||||
Parsed datatype, can be either a fundamental type or a custom datatype.
|
||||
E.g. void, double, size_t, Matrix.
|
||||
Think of this as a high-level type which encodes the typename and other
|
||||
characteristics of the type.
|
||||
|
||||
The type can optionally be a raw pointer, shared pointer or reference.
|
||||
Can also be optionally qualified with a `const`, e.g. `const int`.
|
||||
|
@ -240,6 +242,9 @@ class Type:
|
|||
or self.typename.name in ["Matrix", "Vector"]) else "",
|
||||
typename=typename))
|
||||
|
||||
def get_typename(self):
|
||||
"""Convenience method to get the typename of this type."""
|
||||
return self.typename.name
|
||||
|
||||
class TemplatedType:
|
||||
"""
|
||||
|
|
|
@ -112,7 +112,7 @@ class FormatMixin:
|
|||
|
||||
if separator == "::": # C++
|
||||
templates = []
|
||||
for idx in range(len(type_name.instantiations)):
|
||||
for idx, _ in enumerate(type_name.instantiations):
|
||||
template = '{}'.format(
|
||||
self._format_type_name(type_name.instantiations[idx],
|
||||
include_namespace=include_namespace,
|
||||
|
@ -124,7 +124,7 @@ class FormatMixin:
|
|||
formatted_type_name += '<{}>'.format(','.join(templates))
|
||||
|
||||
else:
|
||||
for idx in range(len(type_name.instantiations)):
|
||||
for idx, _ in enumerate(type_name.instantiations):
|
||||
formatted_type_name += '{}'.format(
|
||||
self._format_type_name(type_name.instantiations[idx],
|
||||
separator=separator,
|
||||
|
|
|
@ -119,8 +119,11 @@ class PybindWrapper:
|
|||
if py_method in self.python_keywords:
|
||||
py_method = py_method + "_"
|
||||
|
||||
is_method = isinstance(method, instantiator.InstantiatedMethod)
|
||||
is_static = isinstance(method, parser.StaticMethod)
|
||||
is_method = isinstance(
|
||||
method, (parser.Method, instantiator.InstantiatedMethod))
|
||||
is_static = isinstance(
|
||||
method,
|
||||
(parser.StaticMethod, instantiator.InstantiatedStaticMethod))
|
||||
return_void = method.return_type.is_void()
|
||||
args_names = method.args.names()
|
||||
py_args_names = self._py_args_names(method.args)
|
||||
|
|
|
@ -1,714 +0,0 @@
|
|||
"""Code to help instantiate templated classes, methods and functions."""
|
||||
|
||||
# pylint: disable=too-many-arguments, too-many-instance-attributes, no-self-use, no-else-return, too-many-arguments, unused-format-string-argument, unused-variable
|
||||
|
||||
import itertools
|
||||
from copy import deepcopy
|
||||
from typing import Any, Iterable, List, Sequence
|
||||
|
||||
import gtwrap.interface_parser as parser
|
||||
|
||||
|
||||
def is_scoped_template(template_typenames, str_arg_typename):
|
||||
"""
|
||||
Check if the template given by `str_arg_typename` is a scoped template,
|
||||
and if so, return what template and index matches the scoped template correctly.
|
||||
"""
|
||||
for idx, template in enumerate(template_typenames):
|
||||
if template in str_arg_typename.split("::"):
|
||||
return template, idx
|
||||
return False, -1
|
||||
|
||||
|
||||
def instantiate_type(ctype: parser.Type,
|
||||
template_typenames: List[str],
|
||||
instantiations: List[parser.Typename],
|
||||
cpp_typename: parser.Typename,
|
||||
instantiated_class=None):
|
||||
"""
|
||||
Instantiate template typename for @p ctype.
|
||||
|
||||
Args:
|
||||
instiated_class (InstantiatedClass):
|
||||
|
||||
@return If ctype's name is in the @p template_typenames, return the
|
||||
corresponding type to replace in @p instantiations.
|
||||
If ctype name is `This`, return the new typename @p `cpp_typename`.
|
||||
Otherwise, return the original ctype.
|
||||
"""
|
||||
# make a deep copy so that there is no overwriting of original template params
|
||||
ctype = deepcopy(ctype)
|
||||
|
||||
# Check if the return type has template parameters
|
||||
if ctype.typename.instantiations:
|
||||
for idx, instantiation in enumerate(ctype.typename.instantiations):
|
||||
if instantiation.name in template_typenames:
|
||||
template_idx = template_typenames.index(instantiation.name)
|
||||
ctype.typename.instantiations[
|
||||
idx] = instantiations[ # type: ignore
|
||||
template_idx]
|
||||
|
||||
return ctype
|
||||
|
||||
str_arg_typename = str(ctype.typename)
|
||||
|
||||
# Check if template is a scoped template e.g. T::Value where T is the template
|
||||
scoped_template, scoped_idx = is_scoped_template(template_typenames,
|
||||
str_arg_typename)
|
||||
|
||||
# Instantiate templates which have enumerated instantiations in the template.
|
||||
# E.g. `template<T={double}>`.
|
||||
|
||||
# Instantiate scoped templates, e.g. T::Value.
|
||||
if scoped_template:
|
||||
# Create a copy of the instantiation so we can modify it.
|
||||
instantiation = deepcopy(instantiations[scoped_idx])
|
||||
# Replace the part of the template with the instantiation
|
||||
instantiation.name = str_arg_typename.replace(scoped_template,
|
||||
instantiation.name)
|
||||
return parser.Type(
|
||||
typename=instantiation,
|
||||
is_const=ctype.is_const,
|
||||
is_shared_ptr=ctype.is_shared_ptr,
|
||||
is_ptr=ctype.is_ptr,
|
||||
is_ref=ctype.is_ref,
|
||||
is_basic=ctype.is_basic,
|
||||
)
|
||||
# Check for exact template match.
|
||||
elif str_arg_typename in template_typenames:
|
||||
idx = template_typenames.index(str_arg_typename)
|
||||
return parser.Type(
|
||||
typename=instantiations[idx],
|
||||
is_const=ctype.is_const,
|
||||
is_shared_ptr=ctype.is_shared_ptr,
|
||||
is_ptr=ctype.is_ptr,
|
||||
is_ref=ctype.is_ref,
|
||||
is_basic=ctype.is_basic,
|
||||
)
|
||||
|
||||
# If a method has the keyword `This`, we replace it with the (instantiated) class.
|
||||
elif str_arg_typename == 'This':
|
||||
# Check if the class is template instantiated
|
||||
# so we can replace it with the instantiated version.
|
||||
if instantiated_class:
|
||||
name = instantiated_class.original.name
|
||||
namespaces_name = instantiated_class.namespaces()
|
||||
namespaces_name.append(name)
|
||||
cpp_typename = parser.Typename(
|
||||
namespaces_name,
|
||||
instantiations=instantiated_class.instantiations)
|
||||
|
||||
return parser.Type(
|
||||
typename=cpp_typename,
|
||||
is_const=ctype.is_const,
|
||||
is_shared_ptr=ctype.is_shared_ptr,
|
||||
is_ptr=ctype.is_ptr,
|
||||
is_ref=ctype.is_ref,
|
||||
is_basic=ctype.is_basic,
|
||||
)
|
||||
|
||||
# Case when 'This' is present in the type namespace, e.g `This::Subclass`.
|
||||
elif 'This' in str_arg_typename:
|
||||
# Simply get the index of `This` in the namespace and replace it with the instantiated name.
|
||||
namespace_idx = ctype.typename.namespaces.index('This')
|
||||
ctype.typename.namespaces[namespace_idx] = cpp_typename.name
|
||||
return ctype
|
||||
|
||||
else:
|
||||
return ctype
|
||||
|
||||
|
||||
def instantiate_args_list(args_list, template_typenames, instantiations,
|
||||
cpp_typename):
|
||||
"""
|
||||
Instantiate template typenames in an argument list.
|
||||
Type with name `This` will be replaced by @p `cpp_typename`.
|
||||
|
||||
@param[in] args_list A list of `parser.Argument` to instantiate.
|
||||
@param[in] template_typenames List of template typenames to instantiate,
|
||||
e.g. ['T', 'U', 'V'].
|
||||
@param[in] instantiations List of specific types to instantiate, each
|
||||
associated with each template typename. Each type is a parser.Typename,
|
||||
including its name and full namespaces.
|
||||
@param[in] cpp_typename Full-namespace cpp class name of this instantiation
|
||||
to replace for arguments of type named `This`.
|
||||
@return A new list of parser.Argument which types are replaced with their
|
||||
instantiations.
|
||||
"""
|
||||
instantiated_args = []
|
||||
for arg in args_list:
|
||||
new_type = instantiate_type(arg.ctype, template_typenames,
|
||||
instantiations, cpp_typename)
|
||||
instantiated_args.append(
|
||||
parser.Argument(name=arg.name, ctype=new_type,
|
||||
default=arg.default))
|
||||
return instantiated_args
|
||||
|
||||
|
||||
def instantiate_return_type(return_type,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename,
|
||||
instantiated_class=None):
|
||||
"""Instantiate the return type."""
|
||||
new_type1 = instantiate_type(return_type.type1,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename,
|
||||
instantiated_class=instantiated_class)
|
||||
if return_type.type2:
|
||||
new_type2 = instantiate_type(return_type.type2,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename,
|
||||
instantiated_class=instantiated_class)
|
||||
else:
|
||||
new_type2 = ''
|
||||
return parser.ReturnType(new_type1, new_type2)
|
||||
|
||||
|
||||
def instantiate_name(original_name, instantiations):
|
||||
"""
|
||||
Concatenate instantiated types with an @p original name to form a new
|
||||
instantiated name.
|
||||
TODO(duy): To avoid conflicts, we should include the instantiation's
|
||||
namespaces, but I find that too verbose.
|
||||
"""
|
||||
instantiated_names = []
|
||||
for inst in instantiations:
|
||||
# Ensure the first character of the type is capitalized
|
||||
name = inst.instantiated_name()
|
||||
# Using `capitalize` on the complete name causes other caps to be lower case
|
||||
instantiated_names.append(name.replace(name[0], name[0].capitalize()))
|
||||
|
||||
return "{}{}".format(original_name, "".join(instantiated_names))
|
||||
|
||||
|
||||
class InstantiatedGlobalFunction(parser.GlobalFunction):
|
||||
"""
|
||||
Instantiate global functions.
|
||||
|
||||
E.g.
|
||||
template<T = {double}>
|
||||
T add(const T& x, const T& y);
|
||||
"""
|
||||
def __init__(self, original, instantiations=(), new_name=''):
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
self.template = ''
|
||||
self.parent = original.parent
|
||||
|
||||
if not original.template:
|
||||
self.name = original.name
|
||||
self.return_type = original.return_type
|
||||
self.args = original.args
|
||||
else:
|
||||
self.name = instantiate_name(
|
||||
original.name, instantiations) if not new_name else new_name
|
||||
self.return_type = instantiate_return_type(
|
||||
original.return_type,
|
||||
self.original.template.typenames,
|
||||
self.instantiations,
|
||||
# Keyword type name `This` should already be replaced in the
|
||||
# previous class template instantiation round.
|
||||
cpp_typename='',
|
||||
)
|
||||
instantiated_args = instantiate_args_list(
|
||||
original.args.list(),
|
||||
self.original.template.typenames,
|
||||
self.instantiations,
|
||||
# Keyword type name `This` should already be replaced in the
|
||||
# previous class template instantiation round.
|
||||
cpp_typename='',
|
||||
)
|
||||
self.args = parser.ArgumentList(instantiated_args)
|
||||
|
||||
super().__init__(self.name,
|
||||
self.return_type,
|
||||
self.args,
|
||||
self.template,
|
||||
parent=self.parent)
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
if self.original.template:
|
||||
instantiated_names = [
|
||||
inst.instantiated_name() for inst in self.instantiations
|
||||
]
|
||||
ret = "{}<{}>".format(self.original.name,
|
||||
",".join(instantiated_names))
|
||||
else:
|
||||
ret = self.original.name
|
||||
return ret
|
||||
|
||||
def __repr__(self):
|
||||
return "Instantiated {}".format(
|
||||
super(InstantiatedGlobalFunction, self).__repr__())
|
||||
|
||||
|
||||
class InstantiatedMethod(parser.Method):
|
||||
"""
|
||||
Instantiate method with template parameters.
|
||||
|
||||
E.g.
|
||||
class A {
|
||||
template<X, Y>
|
||||
void func(X x, Y y);
|
||||
}
|
||||
"""
|
||||
def __init__(self,
|
||||
original: parser.Method,
|
||||
instantiations: Iterable[parser.Typename] = ()):
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
self.template: Any = ''
|
||||
self.is_const = original.is_const
|
||||
self.parent = original.parent
|
||||
|
||||
# Check for typenames if templated.
|
||||
# This way, we can gracefully handle both templated and non-templated methods.
|
||||
typenames: Sequence = self.original.template.typenames if self.original.template else []
|
||||
self.name = instantiate_name(original.name, self.instantiations)
|
||||
self.return_type = instantiate_return_type(
|
||||
original.return_type,
|
||||
typenames,
|
||||
self.instantiations,
|
||||
# Keyword type name `This` should already be replaced in the
|
||||
# previous class template instantiation round.
|
||||
cpp_typename='',
|
||||
)
|
||||
|
||||
instantiated_args = instantiate_args_list(
|
||||
original.args.list(),
|
||||
typenames,
|
||||
self.instantiations,
|
||||
# Keyword type name `This` should already be replaced in the
|
||||
# previous class template instantiation round.
|
||||
cpp_typename='',
|
||||
)
|
||||
self.args = parser.ArgumentList(instantiated_args)
|
||||
|
||||
super().__init__(self.template,
|
||||
self.name,
|
||||
self.return_type,
|
||||
self.args,
|
||||
self.is_const,
|
||||
parent=self.parent)
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
if self.original.template:
|
||||
# to_cpp will handle all the namespacing and templating
|
||||
instantiation_list = [x.to_cpp() for x in self.instantiations]
|
||||
# now can simply combine the instantiations, separated by commas
|
||||
ret = "{}<{}>".format(self.original.name,
|
||||
",".join(instantiation_list))
|
||||
else:
|
||||
ret = self.original.name
|
||||
return ret
|
||||
|
||||
def __repr__(self):
|
||||
return "Instantiated {}".format(
|
||||
super(InstantiatedMethod, self).__repr__())
|
||||
|
||||
|
||||
class InstantiatedClass(parser.Class):
|
||||
"""
|
||||
Instantiate the class defined in the interface file.
|
||||
"""
|
||||
def __init__(self, original: parser.Class, instantiations=(), new_name=''):
|
||||
"""
|
||||
Template <T, U>
|
||||
Instantiations: [T1, U1]
|
||||
"""
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
|
||||
self.template = None
|
||||
self.is_virtual = original.is_virtual
|
||||
self.parent_class = original.parent_class
|
||||
self.parent = original.parent
|
||||
|
||||
# If the class is templated, check if the number of provided instantiations
|
||||
# match the number of templates, else it's only a partial instantiation which is bad.
|
||||
if original.template:
|
||||
assert len(original.template.typenames) == len(
|
||||
instantiations), "Typenames and instantiations mismatch!"
|
||||
|
||||
# Get the instantiated name of the class. E.g. FuncDouble
|
||||
self.name = instantiate_name(
|
||||
original.name, instantiations) if not new_name else new_name
|
||||
|
||||
# Check for typenames if templated.
|
||||
# By passing in typenames, we can gracefully handle both templated and non-templated classes
|
||||
# This will allow the `This` keyword to be used in both templated and non-templated classes.
|
||||
typenames = self.original.template.typenames if self.original.template else []
|
||||
|
||||
# Instantiate the constructors, static methods, properties, respectively.
|
||||
self.ctors = self.instantiate_ctors(typenames)
|
||||
self.static_methods = self.instantiate_static_methods(typenames)
|
||||
self.properties = self.instantiate_properties(typenames)
|
||||
|
||||
# Instantiate all operator overloads
|
||||
self.operators = self.instantiate_operators(typenames)
|
||||
|
||||
# Set enums
|
||||
self.enums = original.enums
|
||||
|
||||
# Instantiate all instance methods
|
||||
instantiated_methods = \
|
||||
self.instantiate_class_templates_in_methods(typenames)
|
||||
|
||||
# Second instantiation round to instantiate templated methods.
|
||||
# This is done in case both the class and the method are templated.
|
||||
self.methods = []
|
||||
for method in instantiated_methods:
|
||||
if not method.template:
|
||||
self.methods.append(InstantiatedMethod(method, ()))
|
||||
else:
|
||||
instantiations = []
|
||||
# Get all combinations of template parameters
|
||||
for instantiations in itertools.product(
|
||||
*method.template.instantiations):
|
||||
self.methods.append(
|
||||
InstantiatedMethod(method, instantiations))
|
||||
|
||||
super().__init__(
|
||||
self.template,
|
||||
self.is_virtual,
|
||||
self.name,
|
||||
[self.parent_class],
|
||||
self.ctors,
|
||||
self.methods,
|
||||
self.static_methods,
|
||||
self.properties,
|
||||
self.operators,
|
||||
self.enums,
|
||||
parent=self.parent,
|
||||
)
|
||||
|
||||
def __repr__(self):
|
||||
return "{virtual}Class {cpp_class} : {parent_class}\n"\
|
||||
"{ctors}\n{static_methods}\n{methods}\n{operators}".format(
|
||||
virtual="virtual " if self.is_virtual else '',
|
||||
cpp_class=self.to_cpp(),
|
||||
parent_class=self.parent,
|
||||
ctors="\n".join([repr(ctor) for ctor in self.ctors]),
|
||||
static_methods="\n".join([repr(m)
|
||||
for m in self.static_methods]),
|
||||
methods="\n".join([repr(m) for m in self.methods]),
|
||||
operators="\n".join([repr(op) for op in self.operators])
|
||||
)
|
||||
|
||||
def instantiate_ctors(self, typenames):
|
||||
"""
|
||||
Instantiate the class constructors.
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of constructors instantiated with provided template args.
|
||||
"""
|
||||
instantiated_ctors = []
|
||||
|
||||
def instantiate(instantiated_ctors, ctor, typenames, instantiations):
|
||||
instantiated_args = instantiate_args_list(
|
||||
ctor.args.list(),
|
||||
typenames,
|
||||
instantiations,
|
||||
self.cpp_typename(),
|
||||
)
|
||||
instantiated_ctors.append(
|
||||
parser.Constructor(
|
||||
name=self.name,
|
||||
args=parser.ArgumentList(instantiated_args),
|
||||
template=self.original.template,
|
||||
parent=self,
|
||||
))
|
||||
return instantiated_ctors
|
||||
|
||||
for ctor in self.original.ctors:
|
||||
# Add constructor templates to the typenames and instantiations
|
||||
if isinstance(ctor.template, parser.template.Template):
|
||||
typenames.extend(ctor.template.typenames)
|
||||
|
||||
# Get all combinations of template args
|
||||
for instantiations in itertools.product(
|
||||
*ctor.template.instantiations):
|
||||
instantiations = self.instantiations + list(instantiations)
|
||||
|
||||
instantiated_ctors = instantiate(
|
||||
instantiated_ctors,
|
||||
ctor,
|
||||
typenames=typenames,
|
||||
instantiations=instantiations)
|
||||
|
||||
else:
|
||||
# If no constructor level templates, just use the class templates
|
||||
instantiated_ctors = instantiate(
|
||||
instantiated_ctors,
|
||||
ctor,
|
||||
typenames=typenames,
|
||||
instantiations=self.instantiations)
|
||||
|
||||
return instantiated_ctors
|
||||
|
||||
def instantiate_static_methods(self, typenames):
|
||||
"""
|
||||
Instantiate static methods in the class.
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of static methods instantiated with provided template args.
|
||||
"""
|
||||
instantiated_static_methods = []
|
||||
for static_method in self.original.static_methods:
|
||||
instantiated_args = instantiate_args_list(
|
||||
static_method.args.list(), typenames, self.instantiations,
|
||||
self.cpp_typename())
|
||||
instantiated_static_methods.append(
|
||||
parser.StaticMethod(
|
||||
name=static_method.name,
|
||||
return_type=instantiate_return_type(
|
||||
static_method.return_type,
|
||||
typenames,
|
||||
self.instantiations,
|
||||
self.cpp_typename(),
|
||||
instantiated_class=self),
|
||||
args=parser.ArgumentList(instantiated_args),
|
||||
parent=self,
|
||||
))
|
||||
return instantiated_static_methods
|
||||
|
||||
def instantiate_class_templates_in_methods(self, typenames):
|
||||
"""
|
||||
This function only instantiates the class-level templates in the methods.
|
||||
Template methods are instantiated in InstantiatedMethod in the second
|
||||
round.
|
||||
|
||||
E.g.
|
||||
```
|
||||
template<T={string}>
|
||||
class Greeter{
|
||||
void sayHello(T& name);
|
||||
};
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of methods instantiated with provided template args on the class.
|
||||
"""
|
||||
class_instantiated_methods = []
|
||||
for method in self.original.methods:
|
||||
instantiated_args = instantiate_args_list(
|
||||
method.args.list(),
|
||||
typenames,
|
||||
self.instantiations,
|
||||
self.cpp_typename(),
|
||||
)
|
||||
class_instantiated_methods.append(
|
||||
parser.Method(
|
||||
template=method.template,
|
||||
name=method.name,
|
||||
return_type=instantiate_return_type(
|
||||
method.return_type,
|
||||
typenames,
|
||||
self.instantiations,
|
||||
self.cpp_typename(),
|
||||
),
|
||||
args=parser.ArgumentList(instantiated_args),
|
||||
is_const=method.is_const,
|
||||
parent=self,
|
||||
))
|
||||
return class_instantiated_methods
|
||||
|
||||
def instantiate_operators(self, typenames):
|
||||
"""
|
||||
Instantiate the class-level template in the operator overload.
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of methods instantiated with provided template args on the class.
|
||||
"""
|
||||
instantiated_operators = []
|
||||
for operator in self.original.operators:
|
||||
instantiated_args = instantiate_args_list(
|
||||
operator.args.list(),
|
||||
typenames,
|
||||
self.instantiations,
|
||||
self.cpp_typename(),
|
||||
)
|
||||
instantiated_operators.append(
|
||||
parser.Operator(
|
||||
name=operator.name,
|
||||
operator=operator.operator,
|
||||
return_type=instantiate_return_type(
|
||||
operator.return_type,
|
||||
typenames,
|
||||
self.instantiations,
|
||||
self.cpp_typename(),
|
||||
),
|
||||
args=parser.ArgumentList(instantiated_args),
|
||||
is_const=operator.is_const,
|
||||
parent=self,
|
||||
))
|
||||
return instantiated_operators
|
||||
|
||||
def instantiate_properties(self, typenames):
|
||||
"""
|
||||
Instantiate the class properties.
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of properties instantiated with provided template args.
|
||||
"""
|
||||
instantiated_properties = instantiate_args_list(
|
||||
self.original.properties,
|
||||
typenames,
|
||||
self.instantiations,
|
||||
self.cpp_typename(),
|
||||
)
|
||||
return instantiated_properties
|
||||
|
||||
def cpp_typename(self):
|
||||
"""
|
||||
Return a parser.Typename including namespaces and cpp name of this
|
||||
class.
|
||||
"""
|
||||
if self.original.template:
|
||||
name = "{}<{}>".format(
|
||||
self.original.name,
|
||||
", ".join([inst.to_cpp() for inst in self.instantiations]))
|
||||
else:
|
||||
name = self.original.name
|
||||
namespaces_name = self.namespaces()
|
||||
namespaces_name.append(name)
|
||||
return parser.Typename(namespaces_name)
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
return self.cpp_typename().to_cpp()
|
||||
|
||||
|
||||
class InstantiatedDeclaration(parser.ForwardDeclaration):
|
||||
"""
|
||||
Instantiate typedefs of forward declarations.
|
||||
This is useful when we wish to typedef a templated class
|
||||
which is not defined in the current project.
|
||||
|
||||
E.g.
|
||||
class FactorFromAnotherMother;
|
||||
|
||||
typedef FactorFromAnotherMother<gtsam::Pose3> FactorWeCanUse;
|
||||
"""
|
||||
def __init__(self, original, instantiations=(), new_name=''):
|
||||
super().__init__(original.typename,
|
||||
original.parent_type,
|
||||
original.is_virtual,
|
||||
parent=original.parent)
|
||||
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
self.parent = original.parent
|
||||
|
||||
self.name = instantiate_name(
|
||||
original.name, instantiations) if not new_name else new_name
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
instantiated_names = [
|
||||
inst.qualified_name() for inst in self.instantiations
|
||||
]
|
||||
name = "{}<{}>".format(self.original.name,
|
||||
",".join(instantiated_names))
|
||||
namespaces_name = self.namespaces()
|
||||
namespaces_name.append(name)
|
||||
# Leverage Typename to generate the fully qualified C++ name
|
||||
return parser.Typename(namespaces_name).to_cpp()
|
||||
|
||||
def __repr__(self):
|
||||
return "Instantiated {}".format(
|
||||
super(InstantiatedDeclaration, self).__repr__())
|
||||
|
||||
|
||||
def instantiate_namespace(namespace):
|
||||
"""
|
||||
Instantiate the classes and other elements in the `namespace` content and
|
||||
assign it back to the namespace content attribute.
|
||||
|
||||
@param[in/out] namespace The namespace whose content will be replaced with
|
||||
the instantiated content.
|
||||
"""
|
||||
instantiated_content = []
|
||||
typedef_content = []
|
||||
|
||||
for element in namespace.content:
|
||||
if isinstance(element, parser.Class):
|
||||
original_class = element
|
||||
if not original_class.template:
|
||||
instantiated_content.append(
|
||||
InstantiatedClass(original_class, []))
|
||||
else:
|
||||
# This case is for when the templates have enumerated instantiations.
|
||||
|
||||
# Use itertools to get all possible combinations of instantiations
|
||||
# Works even if one template does not have an instantiation list
|
||||
for instantiations in itertools.product(
|
||||
*original_class.template.instantiations):
|
||||
instantiated_content.append(
|
||||
InstantiatedClass(original_class,
|
||||
list(instantiations)))
|
||||
|
||||
elif isinstance(element, parser.GlobalFunction):
|
||||
original_func = element
|
||||
if not original_func.template:
|
||||
instantiated_content.append(
|
||||
InstantiatedGlobalFunction(original_func, []))
|
||||
else:
|
||||
# Use itertools to get all possible combinations of instantiations
|
||||
# Works even if one template does not have an instantiation list
|
||||
for instantiations in itertools.product(
|
||||
*original_func.template.instantiations):
|
||||
instantiated_content.append(
|
||||
InstantiatedGlobalFunction(original_func,
|
||||
list(instantiations)))
|
||||
|
||||
elif isinstance(element, parser.TypedefTemplateInstantiation):
|
||||
# This is for the case where `typedef` statements are used
|
||||
# to specify the template parameters.
|
||||
typedef_inst = element
|
||||
top_level = namespace.top_level()
|
||||
original_element = top_level.find_class_or_function(
|
||||
typedef_inst.typename)
|
||||
|
||||
# Check if element is a typedef'd class, function or
|
||||
# forward declaration from another project.
|
||||
if isinstance(original_element, parser.Class):
|
||||
typedef_content.append(
|
||||
InstantiatedClass(original_element,
|
||||
typedef_inst.typename.instantiations,
|
||||
typedef_inst.new_name))
|
||||
elif isinstance(original_element, parser.GlobalFunction):
|
||||
typedef_content.append(
|
||||
InstantiatedGlobalFunction(
|
||||
original_element, typedef_inst.typename.instantiations,
|
||||
typedef_inst.new_name))
|
||||
elif isinstance(original_element, parser.ForwardDeclaration):
|
||||
typedef_content.append(
|
||||
InstantiatedDeclaration(
|
||||
original_element, typedef_inst.typename.instantiations,
|
||||
typedef_inst.new_name))
|
||||
|
||||
elif isinstance(element, parser.Namespace):
|
||||
element = instantiate_namespace(element)
|
||||
instantiated_content.append(element)
|
||||
else:
|
||||
instantiated_content.append(element)
|
||||
|
||||
instantiated_content.extend(typedef_content)
|
||||
namespace.content = instantiated_content
|
||||
|
||||
return namespace
|
|
@ -0,0 +1,14 @@
|
|||
"""Code to help instantiate templated classes, methods and functions."""
|
||||
|
||||
# pylint: disable=too-many-arguments, too-many-instance-attributes, no-self-use, no-else-return, too-many-arguments, unused-format-string-argument, unused-variable. unused-argument, too-many-branches
|
||||
|
||||
from typing import Iterable, Sequence, Union
|
||||
|
||||
import gtwrap.interface_parser as parser
|
||||
from gtwrap.template_instantiator.classes import *
|
||||
from gtwrap.template_instantiator.constructor import *
|
||||
from gtwrap.template_instantiator.declaration import *
|
||||
from gtwrap.template_instantiator.function import *
|
||||
from gtwrap.template_instantiator.helpers import *
|
||||
from gtwrap.template_instantiator.method import *
|
||||
from gtwrap.template_instantiator.namespace import *
|
|
@ -0,0 +1,206 @@
|
|||
"""Instantiate a class and its members."""
|
||||
|
||||
import gtwrap.interface_parser as parser
|
||||
from gtwrap.template_instantiator.constructor import InstantiatedConstructor
|
||||
from gtwrap.template_instantiator.helpers import (InstantiationHelper,
|
||||
instantiate_args_list,
|
||||
instantiate_name,
|
||||
instantiate_return_type)
|
||||
from gtwrap.template_instantiator.method import (InstantiatedMethod,
|
||||
InstantiatedStaticMethod)
|
||||
|
||||
|
||||
class InstantiatedClass(parser.Class):
|
||||
"""
|
||||
Instantiate the class defined in the interface file.
|
||||
"""
|
||||
def __init__(self, original: parser.Class, instantiations=(), new_name=''):
|
||||
"""
|
||||
Template <T, U>
|
||||
Instantiations: [T1, U1]
|
||||
"""
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
|
||||
self.template = None
|
||||
self.is_virtual = original.is_virtual
|
||||
self.parent_class = original.parent_class
|
||||
self.parent = original.parent
|
||||
|
||||
# If the class is templated, check if the number of provided instantiations
|
||||
# match the number of templates, else it's only a partial instantiation which is bad.
|
||||
if original.template:
|
||||
assert len(original.template.typenames) == len(
|
||||
instantiations), "Typenames and instantiations mismatch!"
|
||||
|
||||
# Get the instantiated name of the class. E.g. FuncDouble
|
||||
self.name = instantiate_name(
|
||||
original.name, instantiations) if not new_name else new_name
|
||||
|
||||
# Check for typenames if templated.
|
||||
# By passing in typenames, we can gracefully handle both templated and non-templated classes
|
||||
# This will allow the `This` keyword to be used in both templated and non-templated classes.
|
||||
typenames = self.original.template.typenames if self.original.template else []
|
||||
|
||||
# Instantiate the constructors, static methods, properties, respectively.
|
||||
self.ctors = self.instantiate_ctors(typenames)
|
||||
self.static_methods = self.instantiate_static_methods(typenames)
|
||||
self.properties = self.instantiate_properties(typenames)
|
||||
|
||||
# Instantiate all operator overloads
|
||||
self.operators = self.instantiate_operators(typenames)
|
||||
|
||||
# Set enums
|
||||
self.enums = original.enums
|
||||
|
||||
# Instantiate all instance methods
|
||||
self.methods = self.instantiate_methods(typenames)
|
||||
|
||||
super().__init__(
|
||||
self.template,
|
||||
self.is_virtual,
|
||||
self.name,
|
||||
[self.parent_class],
|
||||
self.ctors,
|
||||
self.methods,
|
||||
self.static_methods,
|
||||
self.properties,
|
||||
self.operators,
|
||||
self.enums,
|
||||
parent=self.parent,
|
||||
)
|
||||
|
||||
def __repr__(self):
|
||||
return "{virtual}Class {cpp_class} : {parent_class}\n"\
|
||||
"{ctors}\n{static_methods}\n{methods}\n{operators}".format(
|
||||
virtual="virtual " if self.is_virtual else '',
|
||||
cpp_class=self.to_cpp(),
|
||||
parent_class=self.parent,
|
||||
ctors="\n".join([repr(ctor) for ctor in self.ctors]),
|
||||
static_methods="\n".join([repr(m)
|
||||
for m in self.static_methods]),
|
||||
methods="\n".join([repr(m) for m in self.methods]),
|
||||
operators="\n".join([repr(op) for op in self.operators])
|
||||
)
|
||||
|
||||
def instantiate_ctors(self, typenames):
|
||||
"""
|
||||
Instantiate the class constructors.
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of constructors instantiated with provided template args.
|
||||
"""
|
||||
|
||||
helper = InstantiationHelper(
|
||||
instantiation_type=InstantiatedConstructor)
|
||||
|
||||
instantiated_ctors = helper.multilevel_instantiation(
|
||||
self.original.ctors, typenames, self)
|
||||
|
||||
return instantiated_ctors
|
||||
|
||||
def instantiate_static_methods(self, typenames):
|
||||
"""
|
||||
Instantiate static methods in the class.
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of static methods instantiated with provided template args.
|
||||
"""
|
||||
helper = InstantiationHelper(
|
||||
instantiation_type=InstantiatedStaticMethod)
|
||||
|
||||
instantiated_static_methods = helper.multilevel_instantiation(
|
||||
self.original.static_methods, typenames, self)
|
||||
|
||||
return instantiated_static_methods
|
||||
|
||||
def instantiate_methods(self, typenames):
|
||||
"""
|
||||
Instantiate regular methods in the class.
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of methods instantiated with provided template args.
|
||||
"""
|
||||
instantiated_methods = []
|
||||
|
||||
helper = InstantiationHelper(instantiation_type=InstantiatedMethod)
|
||||
|
||||
instantiated_methods = helper.multilevel_instantiation(
|
||||
self.original.methods, typenames, self)
|
||||
|
||||
return instantiated_methods
|
||||
|
||||
def instantiate_operators(self, typenames):
|
||||
"""
|
||||
Instantiate the class-level template in the operator overload.
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of methods instantiated with provided template args on the class.
|
||||
"""
|
||||
instantiated_operators = []
|
||||
for operator in self.original.operators:
|
||||
instantiated_args = instantiate_args_list(
|
||||
operator.args.list(),
|
||||
typenames,
|
||||
self.instantiations,
|
||||
self.cpp_typename(),
|
||||
)
|
||||
instantiated_operators.append(
|
||||
parser.Operator(
|
||||
name=operator.name,
|
||||
operator=operator.operator,
|
||||
return_type=instantiate_return_type(
|
||||
operator.return_type,
|
||||
typenames,
|
||||
self.instantiations,
|
||||
self.cpp_typename(),
|
||||
),
|
||||
args=parser.ArgumentList(instantiated_args),
|
||||
is_const=operator.is_const,
|
||||
parent=self,
|
||||
))
|
||||
return instantiated_operators
|
||||
|
||||
def instantiate_properties(self, typenames):
|
||||
"""
|
||||
Instantiate the class properties.
|
||||
|
||||
Args:
|
||||
typenames: List of template types to instantiate.
|
||||
|
||||
Return: List of properties instantiated with provided template args.
|
||||
"""
|
||||
instantiated_properties = instantiate_args_list(
|
||||
self.original.properties,
|
||||
typenames,
|
||||
self.instantiations,
|
||||
self.cpp_typename(),
|
||||
)
|
||||
return instantiated_properties
|
||||
|
||||
def cpp_typename(self):
|
||||
"""
|
||||
Return a parser.Typename including namespaces and cpp name of this
|
||||
class.
|
||||
"""
|
||||
if self.original.template:
|
||||
name = "{}<{}>".format(
|
||||
self.original.name,
|
||||
", ".join([inst.to_cpp() for inst in self.instantiations]))
|
||||
else:
|
||||
name = self.original.name
|
||||
namespaces_name = self.namespaces()
|
||||
namespaces_name.append(name)
|
||||
return parser.Typename(namespaces_name)
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
return self.cpp_typename().to_cpp()
|
|
@ -0,0 +1,64 @@
|
|||
"""Class constructor instantiator."""
|
||||
|
||||
# pylint: disable=unused-argument
|
||||
|
||||
from typing import Iterable, List
|
||||
|
||||
import gtwrap.interface_parser as parser
|
||||
|
||||
|
||||
class InstantiatedConstructor(parser.Constructor):
|
||||
"""
|
||||
Instantiate constructor with template parameters.
|
||||
|
||||
E.g.
|
||||
class A {
|
||||
template<X, Y>
|
||||
A(X x, Y y);
|
||||
}
|
||||
"""
|
||||
def __init__(self,
|
||||
original: parser.Constructor,
|
||||
instantiations: Iterable[parser.Typename] = ()):
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
self.name = original.name
|
||||
self.args = original.args
|
||||
self.template = original.template
|
||||
self.parent = original.parent
|
||||
|
||||
super().__init__(self.name,
|
||||
self.args,
|
||||
self.template,
|
||||
parent=self.parent)
|
||||
|
||||
@classmethod
|
||||
def construct(cls, original: parser.Constructor, typenames: List[str],
|
||||
class_instantiations: List[parser.Typename],
|
||||
method_instantiations: List[parser.Typename],
|
||||
instantiated_args: List[parser.Argument],
|
||||
parent: 'InstantiatedClass'):
|
||||
"""Class method to construct object as required by InstantiationHelper."""
|
||||
method = parser.Constructor(
|
||||
name=parent.name,
|
||||
args=parser.ArgumentList(instantiated_args),
|
||||
template=original.template,
|
||||
parent=parent,
|
||||
)
|
||||
return InstantiatedConstructor(method,
|
||||
instantiations=method_instantiations)
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
if self.original.template:
|
||||
# to_cpp will handle all the namespacing and templating
|
||||
instantiation_list = [x.to_cpp() for x in self.instantiations]
|
||||
# now can simply combine the instantiations, separated by commas
|
||||
ret = "{}<{}>".format(self.original.name,
|
||||
",".join(instantiation_list))
|
||||
else:
|
||||
ret = self.original.name
|
||||
return ret
|
||||
|
||||
def __repr__(self):
|
||||
return "Instantiated {}".format(super().__repr__())
|
|
@ -0,0 +1,45 @@
|
|||
"""Instantiate a forward declaration."""
|
||||
|
||||
import gtwrap.interface_parser as parser
|
||||
from gtwrap.template_instantiator.helpers import instantiate_name
|
||||
|
||||
|
||||
class InstantiatedDeclaration(parser.ForwardDeclaration):
|
||||
"""
|
||||
Instantiate typedefs of forward declarations.
|
||||
This is useful when we wish to typedef a templated class
|
||||
which is not defined in the current project.
|
||||
|
||||
E.g.
|
||||
class FactorFromAnotherMother;
|
||||
|
||||
typedef FactorFromAnotherMother<gtsam::Pose3> FactorWeCanUse;
|
||||
"""
|
||||
def __init__(self, original, instantiations=(), new_name=''):
|
||||
super().__init__(original.typename,
|
||||
original.parent_type,
|
||||
original.is_virtual,
|
||||
parent=original.parent)
|
||||
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
self.parent = original.parent
|
||||
|
||||
self.name = instantiate_name(
|
||||
original.name, instantiations) if not new_name else new_name
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
instantiated_names = [
|
||||
inst.qualified_name() for inst in self.instantiations
|
||||
]
|
||||
name = "{}<{}>".format(self.original.name,
|
||||
",".join(instantiated_names))
|
||||
namespaces_name = self.namespaces()
|
||||
namespaces_name.append(name)
|
||||
# Leverage Typename to generate the fully qualified C++ name
|
||||
return parser.Typename(namespaces_name).to_cpp()
|
||||
|
||||
def __repr__(self):
|
||||
return "Instantiated {}".format(
|
||||
super(InstantiatedDeclaration, self).__repr__())
|
|
@ -0,0 +1,68 @@
|
|||
"""Instantiate global function."""
|
||||
|
||||
import gtwrap.interface_parser as parser
|
||||
from gtwrap.template_instantiator.helpers import (instantiate_args_list,
|
||||
instantiate_name,
|
||||
instantiate_return_type)
|
||||
|
||||
|
||||
class InstantiatedGlobalFunction(parser.GlobalFunction):
|
||||
"""
|
||||
Instantiate global functions.
|
||||
|
||||
E.g.
|
||||
template<T = {double}>
|
||||
T add(const T& x, const T& y);
|
||||
"""
|
||||
def __init__(self, original, instantiations=(), new_name=''):
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
self.template = ''
|
||||
self.parent = original.parent
|
||||
|
||||
if not original.template:
|
||||
self.name = original.name
|
||||
self.return_type = original.return_type
|
||||
self.args = original.args
|
||||
else:
|
||||
self.name = instantiate_name(
|
||||
original.name, instantiations) if not new_name else new_name
|
||||
self.return_type = instantiate_return_type(
|
||||
original.return_type,
|
||||
self.original.template.typenames,
|
||||
self.instantiations,
|
||||
# Keyword type name `This` should already be replaced in the
|
||||
# previous class template instantiation round.
|
||||
cpp_typename='',
|
||||
)
|
||||
instantiated_args = instantiate_args_list(
|
||||
original.args.list(),
|
||||
self.original.template.typenames,
|
||||
self.instantiations,
|
||||
# Keyword type name `This` should already be replaced in the
|
||||
# previous class template instantiation round.
|
||||
cpp_typename='',
|
||||
)
|
||||
self.args = parser.ArgumentList(instantiated_args)
|
||||
|
||||
super().__init__(self.name,
|
||||
self.return_type,
|
||||
self.args,
|
||||
self.template,
|
||||
parent=self.parent)
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
if self.original.template:
|
||||
instantiated_names = [
|
||||
inst.instantiated_name() for inst in self.instantiations
|
||||
]
|
||||
ret = "{}<{}>".format(self.original.name,
|
||||
",".join(instantiated_names))
|
||||
else:
|
||||
ret = self.original.name
|
||||
return ret
|
||||
|
||||
def __repr__(self):
|
||||
return "Instantiated {}".format(
|
||||
super(InstantiatedGlobalFunction, self).__repr__())
|
|
@ -0,0 +1,293 @@
|
|||
"""Various helpers for instantiation."""
|
||||
|
||||
import itertools
|
||||
from copy import deepcopy
|
||||
from typing import List, Sequence, Union
|
||||
|
||||
import gtwrap.interface_parser as parser
|
||||
|
||||
ClassMembers = Union[parser.Constructor, parser.Method, parser.StaticMethod,
|
||||
parser.GlobalFunction, parser.Operator, parser.Variable,
|
||||
parser.Enum]
|
||||
InstantiatedMembers = Union['InstantiatedConstructor', 'InstantiatedMethod',
|
||||
'InstantiatedStaticMethod',
|
||||
'InstantiatedGlobalFunction']
|
||||
|
||||
|
||||
def is_scoped_template(template_typenames: Sequence[str],
|
||||
str_arg_typename: str):
|
||||
"""
|
||||
Check if the template given by `str_arg_typename` is a scoped template e.g. T::Value,
|
||||
and if so, return what template from `template_typenames` and
|
||||
the corresponding index matches the scoped template correctly.
|
||||
"""
|
||||
for idx, template in enumerate(template_typenames):
|
||||
if "::" in str_arg_typename and \
|
||||
template in str_arg_typename.split("::"):
|
||||
return template, idx
|
||||
return False, -1
|
||||
|
||||
|
||||
def instantiate_type(
|
||||
ctype: parser.Type,
|
||||
template_typenames: Sequence[str],
|
||||
instantiations: Sequence[parser.Typename],
|
||||
cpp_typename: parser.Typename,
|
||||
instantiated_class: 'InstantiatedClass' = None) -> parser.Type:
|
||||
"""
|
||||
Instantiate template typename for `ctype`.
|
||||
|
||||
Args:
|
||||
ctype: The original argument type.
|
||||
template_typenames: List of strings representing the templates.
|
||||
instantiations: List of the instantiations of the templates in `template_typenames`.
|
||||
cpp_typename: Full-namespace cpp class name of this instantiation
|
||||
to replace for arguments of type named `This`.
|
||||
instiated_class: The instantiated class which, if provided,
|
||||
will be used for instantiating `This`.
|
||||
|
||||
Returns:
|
||||
If `ctype`'s name is in the `template_typenames`, return the
|
||||
corresponding type to replace in `instantiations`.
|
||||
If ctype name is `This`, return the new typename `cpp_typename`.
|
||||
Otherwise, return the original ctype.
|
||||
"""
|
||||
# make a deep copy so that there is no overwriting of original template params
|
||||
ctype = deepcopy(ctype)
|
||||
|
||||
# Check if the return type has template parameters
|
||||
if ctype.typename.instantiations:
|
||||
for idx, instantiation in enumerate(ctype.typename.instantiations):
|
||||
if instantiation.name in template_typenames:
|
||||
template_idx = template_typenames.index(instantiation.name)
|
||||
ctype.typename.instantiations[
|
||||
idx] = instantiations[ # type: ignore
|
||||
template_idx]
|
||||
|
||||
return ctype
|
||||
|
||||
str_arg_typename = str(ctype.typename)
|
||||
|
||||
# Check if template is a scoped template e.g. T::Value where T is the template
|
||||
scoped_template, scoped_idx = is_scoped_template(template_typenames,
|
||||
str_arg_typename)
|
||||
|
||||
# Instantiate templates which have enumerated instantiations in the template.
|
||||
# E.g. `template<T={double}>`.
|
||||
|
||||
# Instantiate scoped templates, e.g. T::Value.
|
||||
if scoped_template:
|
||||
# Create a copy of the instantiation so we can modify it.
|
||||
instantiation = deepcopy(instantiations[scoped_idx])
|
||||
# Replace the part of the template with the instantiation
|
||||
instantiation.name = str_arg_typename.replace(scoped_template,
|
||||
instantiation.name)
|
||||
return parser.Type(
|
||||
typename=instantiation,
|
||||
is_const=ctype.is_const,
|
||||
is_shared_ptr=ctype.is_shared_ptr,
|
||||
is_ptr=ctype.is_ptr,
|
||||
is_ref=ctype.is_ref,
|
||||
is_basic=ctype.is_basic,
|
||||
)
|
||||
# Check for exact template match.
|
||||
elif str_arg_typename in template_typenames:
|
||||
idx = template_typenames.index(str_arg_typename)
|
||||
return parser.Type(
|
||||
typename=instantiations[idx],
|
||||
is_const=ctype.is_const,
|
||||
is_shared_ptr=ctype.is_shared_ptr,
|
||||
is_ptr=ctype.is_ptr,
|
||||
is_ref=ctype.is_ref,
|
||||
is_basic=ctype.is_basic,
|
||||
)
|
||||
|
||||
# If a method has the keyword `This`, we replace it with the (instantiated) class.
|
||||
elif str_arg_typename == 'This':
|
||||
# Check if the class is template instantiated
|
||||
# so we can replace it with the instantiated version.
|
||||
if instantiated_class:
|
||||
name = instantiated_class.original.name
|
||||
namespaces_name = instantiated_class.namespaces()
|
||||
namespaces_name.append(name)
|
||||
cpp_typename = parser.Typename(
|
||||
namespaces_name,
|
||||
instantiations=instantiated_class.instantiations)
|
||||
|
||||
return parser.Type(
|
||||
typename=cpp_typename,
|
||||
is_const=ctype.is_const,
|
||||
is_shared_ptr=ctype.is_shared_ptr,
|
||||
is_ptr=ctype.is_ptr,
|
||||
is_ref=ctype.is_ref,
|
||||
is_basic=ctype.is_basic,
|
||||
)
|
||||
|
||||
# Case when 'This' is present in the type namespace, e.g `This::Subclass`.
|
||||
elif 'This' in str_arg_typename:
|
||||
# Simply get the index of `This` in the namespace and replace it with the instantiated name.
|
||||
namespace_idx = ctype.typename.namespaces.index('This')
|
||||
ctype.typename.namespaces[namespace_idx] = cpp_typename.name
|
||||
return ctype
|
||||
|
||||
else:
|
||||
return ctype
|
||||
|
||||
|
||||
def instantiate_args_list(
|
||||
args_list: Sequence[parser.Argument],
|
||||
template_typenames: Sequence[parser.template.Typename],
|
||||
instantiations: Sequence, cpp_typename: parser.Typename):
|
||||
"""
|
||||
Instantiate template typenames in an argument list.
|
||||
Type with name `This` will be replaced by @p `cpp_typename`.
|
||||
|
||||
@param[in] args_list A list of `parser.Argument` to instantiate.
|
||||
@param[in] template_typenames List of template typenames to instantiate,
|
||||
e.g. ['T', 'U', 'V'].
|
||||
@param[in] instantiations List of specific types to instantiate, each
|
||||
associated with each template typename. Each type is a parser.Typename,
|
||||
including its name and full namespaces.
|
||||
@param[in] cpp_typename Full-namespace cpp class name of this instantiation
|
||||
to replace for arguments of type named `This`.
|
||||
@return A new list of parser.Argument which types are replaced with their
|
||||
instantiations.
|
||||
"""
|
||||
instantiated_args = []
|
||||
for arg in args_list:
|
||||
new_type = instantiate_type(arg.ctype, template_typenames,
|
||||
instantiations, cpp_typename)
|
||||
instantiated_args.append(
|
||||
parser.Argument(name=arg.name, ctype=new_type,
|
||||
default=arg.default))
|
||||
return instantiated_args
|
||||
|
||||
|
||||
def instantiate_return_type(
|
||||
return_type: parser.ReturnType,
|
||||
template_typenames: Sequence[parser.template.Typename],
|
||||
instantiations: Sequence[parser.Typename],
|
||||
cpp_typename: parser.Typename,
|
||||
instantiated_class: 'InstantiatedClass' = None):
|
||||
"""Instantiate the return type."""
|
||||
new_type1 = instantiate_type(return_type.type1,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename,
|
||||
instantiated_class=instantiated_class)
|
||||
if return_type.type2:
|
||||
new_type2 = instantiate_type(return_type.type2,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename,
|
||||
instantiated_class=instantiated_class)
|
||||
else:
|
||||
new_type2 = ''
|
||||
return parser.ReturnType(new_type1, new_type2)
|
||||
|
||||
|
||||
def instantiate_name(original_name: str,
|
||||
instantiations: Sequence[parser.Typename]):
|
||||
"""
|
||||
Concatenate instantiated types with `original_name` to form a new
|
||||
instantiated name.
|
||||
|
||||
NOTE: To avoid conflicts, we should include the instantiation's
|
||||
namespaces, but that is too verbose.
|
||||
"""
|
||||
instantiated_names = []
|
||||
for inst in instantiations:
|
||||
# Ensure the first character of the type is capitalized
|
||||
name = inst.instantiated_name()
|
||||
# Using `capitalize` on the complete name causes other caps to be lower case
|
||||
instantiated_names.append(name.replace(name[0], name[0].capitalize()))
|
||||
|
||||
return "{}{}".format(original_name, "".join(instantiated_names))
|
||||
|
||||
|
||||
class InstantiationHelper:
|
||||
"""
|
||||
Helper class for instantiation templates.
|
||||
Requires that `instantiation_type` defines a class method called
|
||||
`construct` to generate the appropriate object type.
|
||||
|
||||
Signature for `construct` should be
|
||||
```
|
||||
construct(method,
|
||||
typenames,
|
||||
class_instantiations,
|
||||
method_instantiations,
|
||||
instantiated_args,
|
||||
parent=parent)
|
||||
```
|
||||
"""
|
||||
def __init__(self, instantiation_type: InstantiatedMembers):
|
||||
self.instantiation_type = instantiation_type
|
||||
|
||||
def instantiate(self, instantiated_methods: List[InstantiatedMembers],
|
||||
method: ClassMembers, typenames: Sequence[str],
|
||||
class_instantiations: Sequence[parser.Typename],
|
||||
method_instantiations: Sequence[parser.Typename],
|
||||
parent: 'InstantiatedClass'):
|
||||
"""
|
||||
Instantiate both the class and method level templates.
|
||||
"""
|
||||
instantiations = class_instantiations + method_instantiations
|
||||
|
||||
instantiated_args = instantiate_args_list(method.args.list(),
|
||||
typenames, instantiations,
|
||||
parent.cpp_typename())
|
||||
|
||||
instantiated_methods.append(
|
||||
self.instantiation_type.construct(method,
|
||||
typenames,
|
||||
class_instantiations,
|
||||
method_instantiations,
|
||||
instantiated_args,
|
||||
parent=parent))
|
||||
|
||||
return instantiated_methods
|
||||
|
||||
def multilevel_instantiation(self, methods_list: Sequence[ClassMembers],
|
||||
typenames: Sequence[str],
|
||||
parent: 'InstantiatedClass'):
|
||||
"""
|
||||
Helper to instantiate methods at both the class and method level.
|
||||
|
||||
Args:
|
||||
methods_list: The list of methods in the class to instantiated.
|
||||
typenames: List of class level template parameters, e.g. ['T'].
|
||||
parent: The instantiated class to which `methods_list` belongs.
|
||||
"""
|
||||
instantiated_methods = []
|
||||
|
||||
for method in methods_list:
|
||||
# We creare a copy since we will modify the typenames list.
|
||||
method_typenames = deepcopy(typenames)
|
||||
|
||||
if isinstance(method.template, parser.template.Template):
|
||||
method_typenames.extend(method.template.typenames)
|
||||
|
||||
# Get all combinations of template args
|
||||
for instantiations in itertools.product(
|
||||
*method.template.instantiations):
|
||||
|
||||
instantiated_methods = self.instantiate(
|
||||
instantiated_methods,
|
||||
method,
|
||||
typenames=method_typenames,
|
||||
class_instantiations=parent.instantiations,
|
||||
method_instantiations=list(instantiations),
|
||||
parent=parent)
|
||||
|
||||
else:
|
||||
# If no constructor level templates, just use the class templates
|
||||
instantiated_methods = self.instantiate(
|
||||
instantiated_methods,
|
||||
method,
|
||||
typenames=method_typenames,
|
||||
class_instantiations=parent.instantiations,
|
||||
method_instantiations=[],
|
||||
parent=parent)
|
||||
|
||||
return instantiated_methods
|
|
@ -0,0 +1,124 @@
|
|||
"""Class method and static method instantiators."""
|
||||
|
||||
from typing import Iterable
|
||||
|
||||
import gtwrap.interface_parser as parser
|
||||
from gtwrap.template_instantiator.helpers import (instantiate_name,
|
||||
instantiate_return_type)
|
||||
|
||||
|
||||
class InstantiatedMethod(parser.Method):
|
||||
"""
|
||||
Instantiate method with template parameters.
|
||||
|
||||
E.g.
|
||||
class A {
|
||||
template<X, Y>
|
||||
void func(X x, Y y);
|
||||
}
|
||||
"""
|
||||
def __init__(self,
|
||||
original: parser.Method,
|
||||
instantiations: Iterable[parser.Typename] = ()):
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
self.template = original.template
|
||||
self.is_const = original.is_const
|
||||
self.parent = original.parent
|
||||
|
||||
self.name = instantiate_name(original.name, self.instantiations)
|
||||
self.return_type = original.return_type
|
||||
self.args = original.args
|
||||
|
||||
super().__init__(self.template,
|
||||
self.name,
|
||||
self.return_type,
|
||||
self.args,
|
||||
self.is_const,
|
||||
parent=self.parent)
|
||||
|
||||
@classmethod
|
||||
def construct(cls, original, typenames, class_instantiations,
|
||||
method_instantiations, instantiated_args, parent):
|
||||
"""Class method to construct object as required by InstantiationHelper."""
|
||||
method = parser.Method(
|
||||
template=original.template,
|
||||
name=original.name,
|
||||
return_type=instantiate_return_type(
|
||||
original.return_type, typenames,
|
||||
class_instantiations + method_instantiations,
|
||||
parent.cpp_typename()),
|
||||
args=parser.ArgumentList(instantiated_args),
|
||||
is_const=original.is_const,
|
||||
parent=parent,
|
||||
)
|
||||
return InstantiatedMethod(method, instantiations=method_instantiations)
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
if self.original.template:
|
||||
# to_cpp will handle all the namespacing and templating
|
||||
instantiation_list = [x.to_cpp() for x in self.instantiations]
|
||||
# now can simply combine the instantiations, separated by commas
|
||||
ret = "{}<{}>".format(self.original.name,
|
||||
",".join(instantiation_list))
|
||||
else:
|
||||
ret = self.original.name
|
||||
return ret
|
||||
|
||||
def __repr__(self):
|
||||
return "Instantiated {}".format(super().__repr__())
|
||||
|
||||
|
||||
class InstantiatedStaticMethod(parser.StaticMethod):
|
||||
"""
|
||||
Instantiate static method with template parameters.
|
||||
"""
|
||||
def __init__(self,
|
||||
original: parser.StaticMethod,
|
||||
instantiations: Iterable[parser.Typename] = ()):
|
||||
self.original = original
|
||||
self.instantiations = instantiations
|
||||
|
||||
self.name = instantiate_name(original.name, self.instantiations)
|
||||
self.return_type = original.return_type
|
||||
self.args = original.args
|
||||
self.template = original.template
|
||||
self.parent = original.parent
|
||||
|
||||
super().__init__(self.name, self.return_type, self.args, self.template,
|
||||
self.parent)
|
||||
|
||||
@classmethod
|
||||
def construct(cls, original, typenames, class_instantiations,
|
||||
method_instantiations, instantiated_args, parent):
|
||||
"""Class method to construct object as required by InstantiationHelper."""
|
||||
method = parser.StaticMethod(
|
||||
name=original.name,
|
||||
return_type=instantiate_return_type(original.return_type,
|
||||
typenames,
|
||||
class_instantiations +
|
||||
method_instantiations,
|
||||
parent.cpp_typename(),
|
||||
instantiated_class=parent),
|
||||
args=parser.ArgumentList(instantiated_args),
|
||||
template=original.template,
|
||||
parent=parent,
|
||||
)
|
||||
return InstantiatedStaticMethod(method,
|
||||
instantiations=method_instantiations)
|
||||
|
||||
def to_cpp(self):
|
||||
"""Generate the C++ code for wrapping."""
|
||||
if self.original.template:
|
||||
# to_cpp will handle all the namespacing and templating
|
||||
instantiation_list = [x.to_cpp() for x in self.instantiations]
|
||||
# now can simply combine the instantiations, separated by commas
|
||||
ret = "{}<{}>".format(self.original.name,
|
||||
",".join(instantiation_list))
|
||||
else:
|
||||
ret = self.original.name
|
||||
return ret
|
||||
|
||||
def __repr__(self):
|
||||
return "Instantiated {}".format(super().__repr__())
|
|
@ -0,0 +1,88 @@
|
|||
"""Instantiate a namespace."""
|
||||
|
||||
import itertools
|
||||
|
||||
import gtwrap.interface_parser as parser
|
||||
from gtwrap.template_instantiator.classes import InstantiatedClass
|
||||
from gtwrap.template_instantiator.declaration import InstantiatedDeclaration
|
||||
from gtwrap.template_instantiator.function import InstantiatedGlobalFunction
|
||||
|
||||
|
||||
def instantiate_namespace(namespace):
|
||||
"""
|
||||
Instantiate the classes and other elements in the `namespace` content and
|
||||
assign it back to the namespace content attribute.
|
||||
|
||||
@param[in/out] namespace The namespace whose content will be replaced with
|
||||
the instantiated content.
|
||||
"""
|
||||
instantiated_content = []
|
||||
typedef_content = []
|
||||
|
||||
for element in namespace.content:
|
||||
if isinstance(element, parser.Class):
|
||||
original_class = element
|
||||
if not original_class.template:
|
||||
instantiated_content.append(
|
||||
InstantiatedClass(original_class, []))
|
||||
else:
|
||||
# This case is for when the templates have enumerated instantiations.
|
||||
|
||||
# Use itertools to get all possible combinations of instantiations
|
||||
# Works even if one template does not have an instantiation list
|
||||
for instantiations in itertools.product(
|
||||
*original_class.template.instantiations):
|
||||
instantiated_content.append(
|
||||
InstantiatedClass(original_class,
|
||||
list(instantiations)))
|
||||
|
||||
elif isinstance(element, parser.GlobalFunction):
|
||||
original_func = element
|
||||
if not original_func.template:
|
||||
instantiated_content.append(
|
||||
InstantiatedGlobalFunction(original_func, []))
|
||||
else:
|
||||
# Use itertools to get all possible combinations of instantiations
|
||||
# Works even if one template does not have an instantiation list
|
||||
for instantiations in itertools.product(
|
||||
*original_func.template.instantiations):
|
||||
instantiated_content.append(
|
||||
InstantiatedGlobalFunction(original_func,
|
||||
list(instantiations)))
|
||||
|
||||
elif isinstance(element, parser.TypedefTemplateInstantiation):
|
||||
# This is for the case where `typedef` statements are used
|
||||
# to specify the template parameters.
|
||||
typedef_inst = element
|
||||
top_level = namespace.top_level()
|
||||
original_element = top_level.find_class_or_function(
|
||||
typedef_inst.typename)
|
||||
|
||||
# Check if element is a typedef'd class, function or
|
||||
# forward declaration from another project.
|
||||
if isinstance(original_element, parser.Class):
|
||||
typedef_content.append(
|
||||
InstantiatedClass(original_element,
|
||||
typedef_inst.typename.instantiations,
|
||||
typedef_inst.new_name))
|
||||
elif isinstance(original_element, parser.GlobalFunction):
|
||||
typedef_content.append(
|
||||
InstantiatedGlobalFunction(
|
||||
original_element, typedef_inst.typename.instantiations,
|
||||
typedef_inst.new_name))
|
||||
elif isinstance(original_element, parser.ForwardDeclaration):
|
||||
typedef_content.append(
|
||||
InstantiatedDeclaration(
|
||||
original_element, typedef_inst.typename.instantiations,
|
||||
typedef_inst.new_name))
|
||||
|
||||
elif isinstance(element, parser.Namespace):
|
||||
element = instantiate_namespace(element)
|
||||
instantiated_content.append(element)
|
||||
else:
|
||||
instantiated_content.append(element)
|
||||
|
||||
instantiated_content.extend(typedef_content)
|
||||
namespace.content = instantiated_content
|
||||
|
||||
return namespace
|
|
@ -1,2 +1,2 @@
|
|||
pyparsing
|
||||
pytest
|
||||
pyparsing==2.4.7
|
||||
pytest>=6.2.4
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
%
|
||||
%-------Static Methods-------
|
||||
%staticMethodWithThis() : returns Fun<double>
|
||||
%templatedStaticMethodInt(int m) : returns double
|
||||
%
|
||||
%-------Serialization Interface-------
|
||||
%string_serialize() : returns string
|
||||
|
@ -69,5 +70,16 @@ classdef FunDouble < handle
|
|||
error('Arguments do not match any overload of function FunDouble.staticMethodWithThis');
|
||||
end
|
||||
|
||||
function varargout = TemplatedStaticMethodInt(varargin)
|
||||
% TEMPLATEDSTATICMETHODINT usage: templatedStaticMethodInt(int m) : returns double
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'numeric')
|
||||
varargout{1} = class_wrapper(10, varargin{:});
|
||||
return
|
||||
end
|
||||
|
||||
error('Arguments do not match any overload of function FunDouble.templatedStaticMethodInt');
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
|
|
|
@ -9,7 +9,7 @@ classdef MultipleTemplatesIntDouble < handle
|
|||
function obj = MultipleTemplatesIntDouble(varargin)
|
||||
if nargin == 2 && isa(varargin{1}, 'uint64') && varargin{1} == uint64(5139824614673773682)
|
||||
my_ptr = varargin{2};
|
||||
class_wrapper(49, my_ptr);
|
||||
class_wrapper(50, my_ptr);
|
||||
else
|
||||
error('Arguments do not match any overload of MultipleTemplatesIntDouble constructor');
|
||||
end
|
||||
|
@ -17,7 +17,7 @@ classdef MultipleTemplatesIntDouble < handle
|
|||
end
|
||||
|
||||
function delete(obj)
|
||||
class_wrapper(50, obj.ptr_MultipleTemplatesIntDouble);
|
||||
class_wrapper(51, obj.ptr_MultipleTemplatesIntDouble);
|
||||
end
|
||||
|
||||
function display(obj), obj.print(''); end
|
||||
|
|
|
@ -9,7 +9,7 @@ classdef MultipleTemplatesIntFloat < handle
|
|||
function obj = MultipleTemplatesIntFloat(varargin)
|
||||
if nargin == 2 && isa(varargin{1}, 'uint64') && varargin{1} == uint64(5139824614673773682)
|
||||
my_ptr = varargin{2};
|
||||
class_wrapper(51, my_ptr);
|
||||
class_wrapper(52, my_ptr);
|
||||
else
|
||||
error('Arguments do not match any overload of MultipleTemplatesIntFloat constructor');
|
||||
end
|
||||
|
@ -17,7 +17,7 @@ classdef MultipleTemplatesIntFloat < handle
|
|||
end
|
||||
|
||||
function delete(obj)
|
||||
class_wrapper(52, obj.ptr_MultipleTemplatesIntFloat);
|
||||
class_wrapper(53, obj.ptr_MultipleTemplatesIntFloat);
|
||||
end
|
||||
|
||||
function display(obj), obj.print(''); end
|
||||
|
|
|
@ -15,9 +15,9 @@ classdef MyFactorPosePoint2 < handle
|
|||
function obj = MyFactorPosePoint2(varargin)
|
||||
if nargin == 2 && isa(varargin{1}, 'uint64') && varargin{1} == uint64(5139824614673773682)
|
||||
my_ptr = varargin{2};
|
||||
class_wrapper(62, my_ptr);
|
||||
class_wrapper(63, my_ptr);
|
||||
elseif nargin == 4 && isa(varargin{1},'numeric') && isa(varargin{2},'numeric') && isa(varargin{3},'double') && isa(varargin{4},'gtsam.noiseModel.Base')
|
||||
my_ptr = class_wrapper(63, varargin{1}, varargin{2}, varargin{3}, varargin{4});
|
||||
my_ptr = class_wrapper(64, varargin{1}, varargin{2}, varargin{3}, varargin{4});
|
||||
else
|
||||
error('Arguments do not match any overload of MyFactorPosePoint2 constructor');
|
||||
end
|
||||
|
@ -25,7 +25,7 @@ classdef MyFactorPosePoint2 < handle
|
|||
end
|
||||
|
||||
function delete(obj)
|
||||
class_wrapper(64, obj.ptr_MyFactorPosePoint2);
|
||||
class_wrapper(65, obj.ptr_MyFactorPosePoint2);
|
||||
end
|
||||
|
||||
function display(obj), obj.print(''); end
|
||||
|
@ -36,7 +36,7 @@ classdef MyFactorPosePoint2 < handle
|
|||
% PRINT usage: print(string s, KeyFormatter keyFormatter) : returns void
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 2 && isa(varargin{1},'char') && isa(varargin{2},'gtsam.KeyFormatter')
|
||||
class_wrapper(65, this, varargin{:});
|
||||
class_wrapper(66, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function MyFactorPosePoint2.print');
|
||||
|
|
|
@ -12,9 +12,9 @@ classdef MyVector12 < handle
|
|||
function obj = MyVector12(varargin)
|
||||
if nargin == 2 && isa(varargin{1}, 'uint64') && varargin{1} == uint64(5139824614673773682)
|
||||
my_ptr = varargin{2};
|
||||
class_wrapper(46, my_ptr);
|
||||
class_wrapper(47, my_ptr);
|
||||
elseif nargin == 0
|
||||
my_ptr = class_wrapper(47);
|
||||
my_ptr = class_wrapper(48);
|
||||
else
|
||||
error('Arguments do not match any overload of MyVector12 constructor');
|
||||
end
|
||||
|
@ -22,7 +22,7 @@ classdef MyVector12 < handle
|
|||
end
|
||||
|
||||
function delete(obj)
|
||||
class_wrapper(48, obj.ptr_MyVector12);
|
||||
class_wrapper(49, obj.ptr_MyVector12);
|
||||
end
|
||||
|
||||
function display(obj), obj.print(''); end
|
||||
|
|
|
@ -12,9 +12,9 @@ classdef MyVector3 < handle
|
|||
function obj = MyVector3(varargin)
|
||||
if nargin == 2 && isa(varargin{1}, 'uint64') && varargin{1} == uint64(5139824614673773682)
|
||||
my_ptr = varargin{2};
|
||||
class_wrapper(43, my_ptr);
|
||||
class_wrapper(44, my_ptr);
|
||||
elseif nargin == 0
|
||||
my_ptr = class_wrapper(44);
|
||||
my_ptr = class_wrapper(45);
|
||||
else
|
||||
error('Arguments do not match any overload of MyVector3 constructor');
|
||||
end
|
||||
|
@ -22,7 +22,7 @@ classdef MyVector3 < handle
|
|||
end
|
||||
|
||||
function delete(obj)
|
||||
class_wrapper(45, obj.ptr_MyVector3);
|
||||
class_wrapper(46, obj.ptr_MyVector3);
|
||||
end
|
||||
|
||||
function display(obj), obj.print(''); end
|
||||
|
|
|
@ -19,9 +19,9 @@ classdef PrimitiveRefDouble < handle
|
|||
function obj = PrimitiveRefDouble(varargin)
|
||||
if nargin == 2 && isa(varargin{1}, 'uint64') && varargin{1} == uint64(5139824614673773682)
|
||||
my_ptr = varargin{2};
|
||||
class_wrapper(39, my_ptr);
|
||||
class_wrapper(40, my_ptr);
|
||||
elseif nargin == 0
|
||||
my_ptr = class_wrapper(40);
|
||||
my_ptr = class_wrapper(41);
|
||||
else
|
||||
error('Arguments do not match any overload of PrimitiveRefDouble constructor');
|
||||
end
|
||||
|
@ -29,7 +29,7 @@ classdef PrimitiveRefDouble < handle
|
|||
end
|
||||
|
||||
function delete(obj)
|
||||
class_wrapper(41, obj.ptr_PrimitiveRefDouble);
|
||||
class_wrapper(42, obj.ptr_PrimitiveRefDouble);
|
||||
end
|
||||
|
||||
function display(obj), obj.print(''); end
|
||||
|
@ -43,7 +43,7 @@ classdef PrimitiveRefDouble < handle
|
|||
% BRUTAL usage: Brutal(double t) : returns PrimitiveRefdouble
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'double')
|
||||
varargout{1} = class_wrapper(42, varargin{:});
|
||||
varargout{1} = class_wrapper(43, varargin{:});
|
||||
return
|
||||
end
|
||||
|
||||
|
|
|
@ -40,11 +40,11 @@ classdef Test < handle
|
|||
function obj = Test(varargin)
|
||||
if nargin == 2 && isa(varargin{1}, 'uint64') && varargin{1} == uint64(5139824614673773682)
|
||||
my_ptr = varargin{2};
|
||||
class_wrapper(10, my_ptr);
|
||||
class_wrapper(11, my_ptr);
|
||||
elseif nargin == 0
|
||||
my_ptr = class_wrapper(11);
|
||||
my_ptr = class_wrapper(12);
|
||||
elseif nargin == 2 && isa(varargin{1},'double') && isa(varargin{2},'double')
|
||||
my_ptr = class_wrapper(12, varargin{1}, varargin{2});
|
||||
my_ptr = class_wrapper(13, varargin{1}, varargin{2});
|
||||
else
|
||||
error('Arguments do not match any overload of Test constructor');
|
||||
end
|
||||
|
@ -52,7 +52,7 @@ classdef Test < handle
|
|||
end
|
||||
|
||||
function delete(obj)
|
||||
class_wrapper(13, obj.ptr_Test);
|
||||
class_wrapper(14, obj.ptr_Test);
|
||||
end
|
||||
|
||||
function display(obj), obj.print(''); end
|
||||
|
@ -63,7 +63,7 @@ classdef Test < handle
|
|||
% ARG_EIGENCONSTREF usage: arg_EigenConstRef(Matrix value) : returns void
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'double')
|
||||
class_wrapper(14, this, varargin{:});
|
||||
class_wrapper(15, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.arg_EigenConstRef');
|
||||
|
@ -73,7 +73,7 @@ classdef Test < handle
|
|||
% CREATE_MIXEDPTRS usage: create_MixedPtrs() : returns pair< Test, Test >
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 0
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(15, this, varargin{:});
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(16, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.create_MixedPtrs');
|
||||
|
@ -83,7 +83,7 @@ classdef Test < handle
|
|||
% CREATE_PTRS usage: create_ptrs() : returns pair< Test, Test >
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 0
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(16, this, varargin{:});
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(17, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.create_ptrs');
|
||||
|
@ -93,7 +93,7 @@ classdef Test < handle
|
|||
% GET_CONTAINER usage: get_container() : returns std.vectorTest
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 0
|
||||
varargout{1} = class_wrapper(17, this, varargin{:});
|
||||
varargout{1} = class_wrapper(18, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.get_container');
|
||||
|
@ -103,7 +103,7 @@ classdef Test < handle
|
|||
% LAMBDA usage: lambda() : returns void
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 0
|
||||
class_wrapper(18, this, varargin{:});
|
||||
class_wrapper(19, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.lambda');
|
||||
|
@ -113,7 +113,7 @@ classdef Test < handle
|
|||
% PRINT usage: print() : returns void
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 0
|
||||
class_wrapper(19, this, varargin{:});
|
||||
class_wrapper(20, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.print');
|
||||
|
@ -123,7 +123,7 @@ classdef Test < handle
|
|||
% RETURN_POINT2PTR usage: return_Point2Ptr(bool value) : returns Point2
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'logical')
|
||||
varargout{1} = class_wrapper(20, this, varargin{:});
|
||||
varargout{1} = class_wrapper(21, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_Point2Ptr');
|
||||
|
@ -133,7 +133,7 @@ classdef Test < handle
|
|||
% RETURN_TEST usage: return_Test(Test value) : returns Test
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'Test')
|
||||
varargout{1} = class_wrapper(21, this, varargin{:});
|
||||
varargout{1} = class_wrapper(22, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_Test');
|
||||
|
@ -143,7 +143,7 @@ classdef Test < handle
|
|||
% RETURN_TESTPTR usage: return_TestPtr(Test value) : returns Test
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'Test')
|
||||
varargout{1} = class_wrapper(22, this, varargin{:});
|
||||
varargout{1} = class_wrapper(23, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_TestPtr');
|
||||
|
@ -153,7 +153,7 @@ classdef Test < handle
|
|||
% RETURN_BOOL usage: return_bool(bool value) : returns bool
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'logical')
|
||||
varargout{1} = class_wrapper(23, this, varargin{:});
|
||||
varargout{1} = class_wrapper(24, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_bool');
|
||||
|
@ -163,7 +163,7 @@ classdef Test < handle
|
|||
% RETURN_DOUBLE usage: return_double(double value) : returns double
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'double')
|
||||
varargout{1} = class_wrapper(24, this, varargin{:});
|
||||
varargout{1} = class_wrapper(25, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_double');
|
||||
|
@ -173,7 +173,7 @@ classdef Test < handle
|
|||
% RETURN_FIELD usage: return_field(Test t) : returns bool
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'Test')
|
||||
varargout{1} = class_wrapper(25, this, varargin{:});
|
||||
varargout{1} = class_wrapper(26, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_field');
|
||||
|
@ -183,7 +183,7 @@ classdef Test < handle
|
|||
% RETURN_INT usage: return_int(int value) : returns int
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'numeric')
|
||||
varargout{1} = class_wrapper(26, this, varargin{:});
|
||||
varargout{1} = class_wrapper(27, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_int');
|
||||
|
@ -193,7 +193,7 @@ classdef Test < handle
|
|||
% RETURN_MATRIX1 usage: return_matrix1(Matrix value) : returns Matrix
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'double')
|
||||
varargout{1} = class_wrapper(27, this, varargin{:});
|
||||
varargout{1} = class_wrapper(28, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_matrix1');
|
||||
|
@ -203,7 +203,7 @@ classdef Test < handle
|
|||
% RETURN_MATRIX2 usage: return_matrix2(Matrix value) : returns Matrix
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'double')
|
||||
varargout{1} = class_wrapper(28, this, varargin{:});
|
||||
varargout{1} = class_wrapper(29, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_matrix2');
|
||||
|
@ -213,13 +213,13 @@ classdef Test < handle
|
|||
% RETURN_PAIR usage: return_pair(Vector v, Matrix A) : returns pair< Vector, Matrix >
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 2 && isa(varargin{1},'double') && size(varargin{1},2)==1 && isa(varargin{2},'double')
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(29, this, varargin{:});
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(30, this, varargin{:});
|
||||
return
|
||||
end
|
||||
% RETURN_PAIR usage: return_pair(Vector v) : returns pair< Vector, Matrix >
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'double') && size(varargin{1},2)==1
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(30, this, varargin{:});
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(31, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_pair');
|
||||
|
@ -229,7 +229,7 @@ classdef Test < handle
|
|||
% RETURN_PTRS usage: return_ptrs(Test p1, Test p2) : returns pair< Test, Test >
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 2 && isa(varargin{1},'Test') && isa(varargin{2},'Test')
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(31, this, varargin{:});
|
||||
[ varargout{1} varargout{2} ] = class_wrapper(32, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_ptrs');
|
||||
|
@ -239,7 +239,7 @@ classdef Test < handle
|
|||
% RETURN_SIZE_T usage: return_size_t(size_t value) : returns size_t
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'numeric')
|
||||
varargout{1} = class_wrapper(32, this, varargin{:});
|
||||
varargout{1} = class_wrapper(33, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_size_t');
|
||||
|
@ -249,7 +249,7 @@ classdef Test < handle
|
|||
% RETURN_STRING usage: return_string(string value) : returns string
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'char')
|
||||
varargout{1} = class_wrapper(33, this, varargin{:});
|
||||
varargout{1} = class_wrapper(34, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_string');
|
||||
|
@ -259,7 +259,7 @@ classdef Test < handle
|
|||
% RETURN_VECTOR1 usage: return_vector1(Vector value) : returns Vector
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'double') && size(varargin{1},2)==1
|
||||
varargout{1} = class_wrapper(34, this, varargin{:});
|
||||
varargout{1} = class_wrapper(35, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_vector1');
|
||||
|
@ -269,19 +269,13 @@ classdef Test < handle
|
|||
% RETURN_VECTOR2 usage: return_vector2(Vector value) : returns Vector
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'double') && size(varargin{1},2)==1
|
||||
varargout{1} = class_wrapper(35, this, varargin{:});
|
||||
varargout{1} = class_wrapper(36, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.return_vector2');
|
||||
end
|
||||
|
||||
function varargout = set_container(this, varargin)
|
||||
% SET_CONTAINER usage: set_container(vector<Test> container) : returns void
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'std.vectorTest')
|
||||
class_wrapper(36, this, varargin{:});
|
||||
return
|
||||
end
|
||||
% SET_CONTAINER usage: set_container(vector<Test> container) : returns void
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'std.vectorTest')
|
||||
|
@ -294,6 +288,12 @@ classdef Test < handle
|
|||
class_wrapper(38, this, varargin{:});
|
||||
return
|
||||
end
|
||||
% SET_CONTAINER usage: set_container(vector<Test> container) : returns void
|
||||
% Doxygen can be found at https://gtsam.org/doxygen/
|
||||
if length(varargin) == 1 && isa(varargin{1},'std.vectorTest')
|
||||
class_wrapper(39, this, varargin{:});
|
||||
return
|
||||
end
|
||||
error('Arguments do not match any overload of function Test.set_container');
|
||||
end
|
||||
|
||||
|
|
|
@ -246,7 +246,14 @@ void FunDouble_staticMethodWithThis_9(int nargout, mxArray *out[], int nargin, c
|
|||
out[0] = wrap_shared_ptr(boost::make_shared<Fun<double>>(Fun<double>::staticMethodWithThis()),"Fundouble", false);
|
||||
}
|
||||
|
||||
void Test_collectorInsertAndMakeBase_10(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void FunDouble_templatedStaticMethodInt_10(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("FunDouble.templatedStaticMethodInt",nargout,nargin,1);
|
||||
int m = unwrap< int >(in[0]);
|
||||
out[0] = wrap< double >(Fun<double>::templatedStaticMethodInt(m));
|
||||
}
|
||||
|
||||
void Test_collectorInsertAndMakeBase_11(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<Test> Shared;
|
||||
|
@ -255,7 +262,7 @@ void Test_collectorInsertAndMakeBase_10(int nargout, mxArray *out[], int nargin,
|
|||
collector_Test.insert(self);
|
||||
}
|
||||
|
||||
void Test_constructor_11(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_constructor_12(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<Test> Shared;
|
||||
|
@ -266,7 +273,7 @@ void Test_constructor_11(int nargout, mxArray *out[], int nargin, const mxArray
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void Test_constructor_12(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_constructor_13(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<Test> Shared;
|
||||
|
@ -279,7 +286,7 @@ void Test_constructor_12(int nargout, mxArray *out[], int nargin, const mxArray
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void Test_deconstructor_13(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_deconstructor_14(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
typedef boost::shared_ptr<Test> Shared;
|
||||
checkArguments("delete_Test",nargout,nargin,1);
|
||||
|
@ -292,7 +299,7 @@ void Test_deconstructor_13(int nargout, mxArray *out[], int nargin, const mxArra
|
|||
}
|
||||
}
|
||||
|
||||
void Test_arg_EigenConstRef_14(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_arg_EigenConstRef_15(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("arg_EigenConstRef",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -300,7 +307,7 @@ void Test_arg_EigenConstRef_14(int nargout, mxArray *out[], int nargin, const mx
|
|||
obj->arg_EigenConstRef(value);
|
||||
}
|
||||
|
||||
void Test_create_MixedPtrs_15(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_create_MixedPtrs_16(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("create_MixedPtrs",nargout,nargin-1,0);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -309,7 +316,7 @@ void Test_create_MixedPtrs_15(int nargout, mxArray *out[], int nargin, const mxA
|
|||
out[1] = wrap_shared_ptr(pairResult.second,"Test", false);
|
||||
}
|
||||
|
||||
void Test_create_ptrs_16(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_create_ptrs_17(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("create_ptrs",nargout,nargin-1,0);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -318,28 +325,28 @@ void Test_create_ptrs_16(int nargout, mxArray *out[], int nargin, const mxArray
|
|||
out[1] = wrap_shared_ptr(pairResult.second,"Test", false);
|
||||
}
|
||||
|
||||
void Test_get_container_17(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_get_container_18(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("get_container",nargout,nargin-1,0);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
out[0] = wrap_shared_ptr(boost::make_shared<std::vector<testing::Test>>(obj->get_container()),"std.vectorTest", false);
|
||||
}
|
||||
|
||||
void Test_lambda_18(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_lambda_19(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("lambda",nargout,nargin-1,0);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
obj->lambda();
|
||||
}
|
||||
|
||||
void Test_print_19(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_print_20(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("print",nargout,nargin-1,0);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
obj->print();
|
||||
}
|
||||
|
||||
void Test_return_Point2Ptr_20(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_Point2Ptr_21(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_Point2Ptr",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -350,7 +357,7 @@ void Test_return_Point2Ptr_20(int nargout, mxArray *out[], int nargin, const mxA
|
|||
}
|
||||
}
|
||||
|
||||
void Test_return_Test_21(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_Test_22(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_Test",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -358,7 +365,7 @@ void Test_return_Test_21(int nargout, mxArray *out[], int nargin, const mxArray
|
|||
out[0] = wrap_shared_ptr(boost::make_shared<Test>(obj->return_Test(value)),"Test", false);
|
||||
}
|
||||
|
||||
void Test_return_TestPtr_22(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_TestPtr_23(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_TestPtr",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -366,7 +373,7 @@ void Test_return_TestPtr_22(int nargout, mxArray *out[], int nargin, const mxArr
|
|||
out[0] = wrap_shared_ptr(obj->return_TestPtr(value),"Test", false);
|
||||
}
|
||||
|
||||
void Test_return_bool_23(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_bool_24(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_bool",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -374,7 +381,7 @@ void Test_return_bool_23(int nargout, mxArray *out[], int nargin, const mxArray
|
|||
out[0] = wrap< bool >(obj->return_bool(value));
|
||||
}
|
||||
|
||||
void Test_return_double_24(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_double_25(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_double",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -382,7 +389,7 @@ void Test_return_double_24(int nargout, mxArray *out[], int nargin, const mxArra
|
|||
out[0] = wrap< double >(obj->return_double(value));
|
||||
}
|
||||
|
||||
void Test_return_field_25(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_field_26(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_field",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -390,7 +397,7 @@ void Test_return_field_25(int nargout, mxArray *out[], int nargin, const mxArray
|
|||
out[0] = wrap< bool >(obj->return_field(t));
|
||||
}
|
||||
|
||||
void Test_return_int_26(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_int_27(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_int",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -398,7 +405,7 @@ void Test_return_int_26(int nargout, mxArray *out[], int nargin, const mxArray *
|
|||
out[0] = wrap< int >(obj->return_int(value));
|
||||
}
|
||||
|
||||
void Test_return_matrix1_27(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_matrix1_28(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_matrix1",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -406,7 +413,7 @@ void Test_return_matrix1_27(int nargout, mxArray *out[], int nargin, const mxArr
|
|||
out[0] = wrap< Matrix >(obj->return_matrix1(value));
|
||||
}
|
||||
|
||||
void Test_return_matrix2_28(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_matrix2_29(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_matrix2",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -414,7 +421,7 @@ void Test_return_matrix2_28(int nargout, mxArray *out[], int nargin, const mxArr
|
|||
out[0] = wrap< Matrix >(obj->return_matrix2(value));
|
||||
}
|
||||
|
||||
void Test_return_pair_29(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_pair_30(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_pair",nargout,nargin-1,2);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -425,7 +432,7 @@ void Test_return_pair_29(int nargout, mxArray *out[], int nargin, const mxArray
|
|||
out[1] = wrap< Matrix >(pairResult.second);
|
||||
}
|
||||
|
||||
void Test_return_pair_30(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_pair_31(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_pair",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -435,7 +442,7 @@ void Test_return_pair_30(int nargout, mxArray *out[], int nargin, const mxArray
|
|||
out[1] = wrap< Matrix >(pairResult.second);
|
||||
}
|
||||
|
||||
void Test_return_ptrs_31(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_ptrs_32(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_ptrs",nargout,nargin-1,2);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -446,7 +453,7 @@ void Test_return_ptrs_31(int nargout, mxArray *out[], int nargin, const mxArray
|
|||
out[1] = wrap_shared_ptr(pairResult.second,"Test", false);
|
||||
}
|
||||
|
||||
void Test_return_size_t_32(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_size_t_33(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_size_t",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -454,7 +461,7 @@ void Test_return_size_t_32(int nargout, mxArray *out[], int nargin, const mxArra
|
|||
out[0] = wrap< size_t >(obj->return_size_t(value));
|
||||
}
|
||||
|
||||
void Test_return_string_33(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_string_34(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_string",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -462,7 +469,7 @@ void Test_return_string_33(int nargout, mxArray *out[], int nargin, const mxArra
|
|||
out[0] = wrap< string >(obj->return_string(value));
|
||||
}
|
||||
|
||||
void Test_return_vector1_34(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_vector1_35(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_vector1",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -470,7 +477,7 @@ void Test_return_vector1_34(int nargout, mxArray *out[], int nargin, const mxArr
|
|||
out[0] = wrap< Vector >(obj->return_vector1(value));
|
||||
}
|
||||
|
||||
void Test_return_vector2_35(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_return_vector2_36(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("return_vector2",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
|
@ -478,14 +485,6 @@ void Test_return_vector2_35(int nargout, mxArray *out[], int nargin, const mxArr
|
|||
out[0] = wrap< Vector >(obj->return_vector2(value));
|
||||
}
|
||||
|
||||
void Test_set_container_36(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("set_container",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
boost::shared_ptr<std::vector<testing::Test>> container = unwrap_shared_ptr< std::vector<testing::Test> >(in[1], "ptr_stdvectorTest");
|
||||
obj->set_container(*container);
|
||||
}
|
||||
|
||||
void Test_set_container_37(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("set_container",nargout,nargin-1,1);
|
||||
|
@ -502,7 +501,15 @@ void Test_set_container_38(int nargout, mxArray *out[], int nargin, const mxArra
|
|||
obj->set_container(*container);
|
||||
}
|
||||
|
||||
void PrimitiveRefDouble_collectorInsertAndMakeBase_39(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void Test_set_container_39(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("set_container",nargout,nargin-1,1);
|
||||
auto obj = unwrap_shared_ptr<Test>(in[0], "ptr_Test");
|
||||
boost::shared_ptr<std::vector<testing::Test>> container = unwrap_shared_ptr< std::vector<testing::Test> >(in[1], "ptr_stdvectorTest");
|
||||
obj->set_container(*container);
|
||||
}
|
||||
|
||||
void PrimitiveRefDouble_collectorInsertAndMakeBase_40(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<PrimitiveRef<double>> Shared;
|
||||
|
@ -511,7 +518,7 @@ void PrimitiveRefDouble_collectorInsertAndMakeBase_39(int nargout, mxArray *out[
|
|||
collector_PrimitiveRefDouble.insert(self);
|
||||
}
|
||||
|
||||
void PrimitiveRefDouble_constructor_40(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void PrimitiveRefDouble_constructor_41(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<PrimitiveRef<double>> Shared;
|
||||
|
@ -522,7 +529,7 @@ void PrimitiveRefDouble_constructor_40(int nargout, mxArray *out[], int nargin,
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void PrimitiveRefDouble_deconstructor_41(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void PrimitiveRefDouble_deconstructor_42(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
typedef boost::shared_ptr<PrimitiveRef<double>> Shared;
|
||||
checkArguments("delete_PrimitiveRefDouble",nargout,nargin,1);
|
||||
|
@ -535,14 +542,14 @@ void PrimitiveRefDouble_deconstructor_41(int nargout, mxArray *out[], int nargin
|
|||
}
|
||||
}
|
||||
|
||||
void PrimitiveRefDouble_Brutal_42(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void PrimitiveRefDouble_Brutal_43(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("PrimitiveRefDouble.Brutal",nargout,nargin,1);
|
||||
double t = unwrap< double >(in[0]);
|
||||
out[0] = wrap_shared_ptr(boost::make_shared<PrimitiveRef<double>>(PrimitiveRef<double>::Brutal(t)),"PrimitiveRefdouble", false);
|
||||
}
|
||||
|
||||
void MyVector3_collectorInsertAndMakeBase_43(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyVector3_collectorInsertAndMakeBase_44(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<MyVector<3>> Shared;
|
||||
|
@ -551,7 +558,7 @@ void MyVector3_collectorInsertAndMakeBase_43(int nargout, mxArray *out[], int na
|
|||
collector_MyVector3.insert(self);
|
||||
}
|
||||
|
||||
void MyVector3_constructor_44(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyVector3_constructor_45(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<MyVector<3>> Shared;
|
||||
|
@ -562,7 +569,7 @@ void MyVector3_constructor_44(int nargout, mxArray *out[], int nargin, const mxA
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void MyVector3_deconstructor_45(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyVector3_deconstructor_46(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
typedef boost::shared_ptr<MyVector<3>> Shared;
|
||||
checkArguments("delete_MyVector3",nargout,nargin,1);
|
||||
|
@ -575,7 +582,7 @@ void MyVector3_deconstructor_45(int nargout, mxArray *out[], int nargin, const m
|
|||
}
|
||||
}
|
||||
|
||||
void MyVector12_collectorInsertAndMakeBase_46(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyVector12_collectorInsertAndMakeBase_47(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<MyVector<12>> Shared;
|
||||
|
@ -584,7 +591,7 @@ void MyVector12_collectorInsertAndMakeBase_46(int nargout, mxArray *out[], int n
|
|||
collector_MyVector12.insert(self);
|
||||
}
|
||||
|
||||
void MyVector12_constructor_47(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyVector12_constructor_48(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<MyVector<12>> Shared;
|
||||
|
@ -595,7 +602,7 @@ void MyVector12_constructor_47(int nargout, mxArray *out[], int nargin, const mx
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void MyVector12_deconstructor_48(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyVector12_deconstructor_49(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
typedef boost::shared_ptr<MyVector<12>> Shared;
|
||||
checkArguments("delete_MyVector12",nargout,nargin,1);
|
||||
|
@ -608,7 +615,7 @@ void MyVector12_deconstructor_48(int nargout, mxArray *out[], int nargin, const
|
|||
}
|
||||
}
|
||||
|
||||
void MultipleTemplatesIntDouble_collectorInsertAndMakeBase_49(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MultipleTemplatesIntDouble_collectorInsertAndMakeBase_50(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<MultipleTemplates<int, double>> Shared;
|
||||
|
@ -617,7 +624,7 @@ void MultipleTemplatesIntDouble_collectorInsertAndMakeBase_49(int nargout, mxArr
|
|||
collector_MultipleTemplatesIntDouble.insert(self);
|
||||
}
|
||||
|
||||
void MultipleTemplatesIntDouble_deconstructor_50(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MultipleTemplatesIntDouble_deconstructor_51(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
typedef boost::shared_ptr<MultipleTemplates<int, double>> Shared;
|
||||
checkArguments("delete_MultipleTemplatesIntDouble",nargout,nargin,1);
|
||||
|
@ -630,7 +637,7 @@ void MultipleTemplatesIntDouble_deconstructor_50(int nargout, mxArray *out[], in
|
|||
}
|
||||
}
|
||||
|
||||
void MultipleTemplatesIntFloat_collectorInsertAndMakeBase_51(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MultipleTemplatesIntFloat_collectorInsertAndMakeBase_52(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<MultipleTemplates<int, float>> Shared;
|
||||
|
@ -639,7 +646,7 @@ void MultipleTemplatesIntFloat_collectorInsertAndMakeBase_51(int nargout, mxArra
|
|||
collector_MultipleTemplatesIntFloat.insert(self);
|
||||
}
|
||||
|
||||
void MultipleTemplatesIntFloat_deconstructor_52(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MultipleTemplatesIntFloat_deconstructor_53(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
typedef boost::shared_ptr<MultipleTemplates<int, float>> Shared;
|
||||
checkArguments("delete_MultipleTemplatesIntFloat",nargout,nargin,1);
|
||||
|
@ -652,7 +659,7 @@ void MultipleTemplatesIntFloat_deconstructor_52(int nargout, mxArray *out[], int
|
|||
}
|
||||
}
|
||||
|
||||
void ForwardKinematics_collectorInsertAndMakeBase_53(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void ForwardKinematics_collectorInsertAndMakeBase_54(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<ForwardKinematics> Shared;
|
||||
|
@ -661,7 +668,7 @@ void ForwardKinematics_collectorInsertAndMakeBase_53(int nargout, mxArray *out[]
|
|||
collector_ForwardKinematics.insert(self);
|
||||
}
|
||||
|
||||
void ForwardKinematics_constructor_54(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void ForwardKinematics_constructor_55(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<ForwardKinematics> Shared;
|
||||
|
@ -677,7 +684,7 @@ void ForwardKinematics_constructor_54(int nargout, mxArray *out[], int nargin, c
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void ForwardKinematics_deconstructor_55(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void ForwardKinematics_deconstructor_56(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
typedef boost::shared_ptr<ForwardKinematics> Shared;
|
||||
checkArguments("delete_ForwardKinematics",nargout,nargin,1);
|
||||
|
@ -690,7 +697,7 @@ void ForwardKinematics_deconstructor_55(int nargout, mxArray *out[], int nargin,
|
|||
}
|
||||
}
|
||||
|
||||
void TemplatedConstructor_collectorInsertAndMakeBase_56(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void TemplatedConstructor_collectorInsertAndMakeBase_57(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<TemplatedConstructor> Shared;
|
||||
|
@ -699,7 +706,7 @@ void TemplatedConstructor_collectorInsertAndMakeBase_56(int nargout, mxArray *ou
|
|||
collector_TemplatedConstructor.insert(self);
|
||||
}
|
||||
|
||||
void TemplatedConstructor_constructor_57(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void TemplatedConstructor_constructor_58(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<TemplatedConstructor> Shared;
|
||||
|
@ -710,7 +717,7 @@ void TemplatedConstructor_constructor_57(int nargout, mxArray *out[], int nargin
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void TemplatedConstructor_constructor_58(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void TemplatedConstructor_constructor_59(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<TemplatedConstructor> Shared;
|
||||
|
@ -722,7 +729,7 @@ void TemplatedConstructor_constructor_58(int nargout, mxArray *out[], int nargin
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void TemplatedConstructor_constructor_59(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void TemplatedConstructor_constructor_60(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<TemplatedConstructor> Shared;
|
||||
|
@ -734,7 +741,7 @@ void TemplatedConstructor_constructor_59(int nargout, mxArray *out[], int nargin
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void TemplatedConstructor_constructor_60(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void TemplatedConstructor_constructor_61(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<TemplatedConstructor> Shared;
|
||||
|
@ -746,7 +753,7 @@ void TemplatedConstructor_constructor_60(int nargout, mxArray *out[], int nargin
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void TemplatedConstructor_deconstructor_61(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void TemplatedConstructor_deconstructor_62(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
typedef boost::shared_ptr<TemplatedConstructor> Shared;
|
||||
checkArguments("delete_TemplatedConstructor",nargout,nargin,1);
|
||||
|
@ -759,7 +766,7 @@ void TemplatedConstructor_deconstructor_61(int nargout, mxArray *out[], int narg
|
|||
}
|
||||
}
|
||||
|
||||
void MyFactorPosePoint2_collectorInsertAndMakeBase_62(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyFactorPosePoint2_collectorInsertAndMakeBase_63(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<MyFactor<gtsam::Pose2, gtsam::Matrix>> Shared;
|
||||
|
@ -768,7 +775,7 @@ void MyFactorPosePoint2_collectorInsertAndMakeBase_62(int nargout, mxArray *out[
|
|||
collector_MyFactorPosePoint2.insert(self);
|
||||
}
|
||||
|
||||
void MyFactorPosePoint2_constructor_63(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyFactorPosePoint2_constructor_64(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
mexAtExit(&_deleteAllObjects);
|
||||
typedef boost::shared_ptr<MyFactor<gtsam::Pose2, gtsam::Matrix>> Shared;
|
||||
|
@ -783,7 +790,7 @@ void MyFactorPosePoint2_constructor_63(int nargout, mxArray *out[], int nargin,
|
|||
*reinterpret_cast<Shared**> (mxGetData(out[0])) = self;
|
||||
}
|
||||
|
||||
void MyFactorPosePoint2_deconstructor_64(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyFactorPosePoint2_deconstructor_65(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
typedef boost::shared_ptr<MyFactor<gtsam::Pose2, gtsam::Matrix>> Shared;
|
||||
checkArguments("delete_MyFactorPosePoint2",nargout,nargin,1);
|
||||
|
@ -796,7 +803,7 @@ void MyFactorPosePoint2_deconstructor_64(int nargout, mxArray *out[], int nargin
|
|||
}
|
||||
}
|
||||
|
||||
void MyFactorPosePoint2_print_65(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
void MyFactorPosePoint2_print_66(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
||||
{
|
||||
checkArguments("print",nargout,nargin-1,2);
|
||||
auto obj = unwrap_shared_ptr<MyFactor<gtsam::Pose2, gtsam::Matrix>>(in[0], "ptr_MyFactorPosePoint2");
|
||||
|
@ -848,85 +855,85 @@ void mexFunction(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
|||
FunDouble_staticMethodWithThis_9(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 10:
|
||||
Test_collectorInsertAndMakeBase_10(nargout, out, nargin-1, in+1);
|
||||
FunDouble_templatedStaticMethodInt_10(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 11:
|
||||
Test_constructor_11(nargout, out, nargin-1, in+1);
|
||||
Test_collectorInsertAndMakeBase_11(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 12:
|
||||
Test_constructor_12(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 13:
|
||||
Test_deconstructor_13(nargout, out, nargin-1, in+1);
|
||||
Test_constructor_13(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 14:
|
||||
Test_arg_EigenConstRef_14(nargout, out, nargin-1, in+1);
|
||||
Test_deconstructor_14(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 15:
|
||||
Test_create_MixedPtrs_15(nargout, out, nargin-1, in+1);
|
||||
Test_arg_EigenConstRef_15(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 16:
|
||||
Test_create_ptrs_16(nargout, out, nargin-1, in+1);
|
||||
Test_create_MixedPtrs_16(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 17:
|
||||
Test_get_container_17(nargout, out, nargin-1, in+1);
|
||||
Test_create_ptrs_17(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 18:
|
||||
Test_lambda_18(nargout, out, nargin-1, in+1);
|
||||
Test_get_container_18(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 19:
|
||||
Test_print_19(nargout, out, nargin-1, in+1);
|
||||
Test_lambda_19(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 20:
|
||||
Test_return_Point2Ptr_20(nargout, out, nargin-1, in+1);
|
||||
Test_print_20(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 21:
|
||||
Test_return_Test_21(nargout, out, nargin-1, in+1);
|
||||
Test_return_Point2Ptr_21(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 22:
|
||||
Test_return_TestPtr_22(nargout, out, nargin-1, in+1);
|
||||
Test_return_Test_22(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 23:
|
||||
Test_return_bool_23(nargout, out, nargin-1, in+1);
|
||||
Test_return_TestPtr_23(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 24:
|
||||
Test_return_double_24(nargout, out, nargin-1, in+1);
|
||||
Test_return_bool_24(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 25:
|
||||
Test_return_field_25(nargout, out, nargin-1, in+1);
|
||||
Test_return_double_25(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 26:
|
||||
Test_return_int_26(nargout, out, nargin-1, in+1);
|
||||
Test_return_field_26(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 27:
|
||||
Test_return_matrix1_27(nargout, out, nargin-1, in+1);
|
||||
Test_return_int_27(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 28:
|
||||
Test_return_matrix2_28(nargout, out, nargin-1, in+1);
|
||||
Test_return_matrix1_28(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 29:
|
||||
Test_return_pair_29(nargout, out, nargin-1, in+1);
|
||||
Test_return_matrix2_29(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 30:
|
||||
Test_return_pair_30(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 31:
|
||||
Test_return_ptrs_31(nargout, out, nargin-1, in+1);
|
||||
Test_return_pair_31(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 32:
|
||||
Test_return_size_t_32(nargout, out, nargin-1, in+1);
|
||||
Test_return_ptrs_32(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 33:
|
||||
Test_return_string_33(nargout, out, nargin-1, in+1);
|
||||
Test_return_size_t_33(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 34:
|
||||
Test_return_vector1_34(nargout, out, nargin-1, in+1);
|
||||
Test_return_string_34(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 35:
|
||||
Test_return_vector2_35(nargout, out, nargin-1, in+1);
|
||||
Test_return_vector1_35(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 36:
|
||||
Test_set_container_36(nargout, out, nargin-1, in+1);
|
||||
Test_return_vector2_36(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 37:
|
||||
Test_set_container_37(nargout, out, nargin-1, in+1);
|
||||
|
@ -935,61 +942,61 @@ void mexFunction(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
|||
Test_set_container_38(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 39:
|
||||
PrimitiveRefDouble_collectorInsertAndMakeBase_39(nargout, out, nargin-1, in+1);
|
||||
Test_set_container_39(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 40:
|
||||
PrimitiveRefDouble_constructor_40(nargout, out, nargin-1, in+1);
|
||||
PrimitiveRefDouble_collectorInsertAndMakeBase_40(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 41:
|
||||
PrimitiveRefDouble_deconstructor_41(nargout, out, nargin-1, in+1);
|
||||
PrimitiveRefDouble_constructor_41(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 42:
|
||||
PrimitiveRefDouble_Brutal_42(nargout, out, nargin-1, in+1);
|
||||
PrimitiveRefDouble_deconstructor_42(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 43:
|
||||
MyVector3_collectorInsertAndMakeBase_43(nargout, out, nargin-1, in+1);
|
||||
PrimitiveRefDouble_Brutal_43(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 44:
|
||||
MyVector3_constructor_44(nargout, out, nargin-1, in+1);
|
||||
MyVector3_collectorInsertAndMakeBase_44(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 45:
|
||||
MyVector3_deconstructor_45(nargout, out, nargin-1, in+1);
|
||||
MyVector3_constructor_45(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 46:
|
||||
MyVector12_collectorInsertAndMakeBase_46(nargout, out, nargin-1, in+1);
|
||||
MyVector3_deconstructor_46(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 47:
|
||||
MyVector12_constructor_47(nargout, out, nargin-1, in+1);
|
||||
MyVector12_collectorInsertAndMakeBase_47(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 48:
|
||||
MyVector12_deconstructor_48(nargout, out, nargin-1, in+1);
|
||||
MyVector12_constructor_48(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 49:
|
||||
MultipleTemplatesIntDouble_collectorInsertAndMakeBase_49(nargout, out, nargin-1, in+1);
|
||||
MyVector12_deconstructor_49(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 50:
|
||||
MultipleTemplatesIntDouble_deconstructor_50(nargout, out, nargin-1, in+1);
|
||||
MultipleTemplatesIntDouble_collectorInsertAndMakeBase_50(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 51:
|
||||
MultipleTemplatesIntFloat_collectorInsertAndMakeBase_51(nargout, out, nargin-1, in+1);
|
||||
MultipleTemplatesIntDouble_deconstructor_51(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 52:
|
||||
MultipleTemplatesIntFloat_deconstructor_52(nargout, out, nargin-1, in+1);
|
||||
MultipleTemplatesIntFloat_collectorInsertAndMakeBase_52(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 53:
|
||||
ForwardKinematics_collectorInsertAndMakeBase_53(nargout, out, nargin-1, in+1);
|
||||
MultipleTemplatesIntFloat_deconstructor_53(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 54:
|
||||
ForwardKinematics_constructor_54(nargout, out, nargin-1, in+1);
|
||||
ForwardKinematics_collectorInsertAndMakeBase_54(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 55:
|
||||
ForwardKinematics_deconstructor_55(nargout, out, nargin-1, in+1);
|
||||
ForwardKinematics_constructor_55(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 56:
|
||||
TemplatedConstructor_collectorInsertAndMakeBase_56(nargout, out, nargin-1, in+1);
|
||||
ForwardKinematics_deconstructor_56(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 57:
|
||||
TemplatedConstructor_constructor_57(nargout, out, nargin-1, in+1);
|
||||
TemplatedConstructor_collectorInsertAndMakeBase_57(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 58:
|
||||
TemplatedConstructor_constructor_58(nargout, out, nargin-1, in+1);
|
||||
|
@ -1001,19 +1008,22 @@ void mexFunction(int nargout, mxArray *out[], int nargin, const mxArray *in[])
|
|||
TemplatedConstructor_constructor_60(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 61:
|
||||
TemplatedConstructor_deconstructor_61(nargout, out, nargin-1, in+1);
|
||||
TemplatedConstructor_constructor_61(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 62:
|
||||
MyFactorPosePoint2_collectorInsertAndMakeBase_62(nargout, out, nargin-1, in+1);
|
||||
TemplatedConstructor_deconstructor_62(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 63:
|
||||
MyFactorPosePoint2_constructor_63(nargout, out, nargin-1, in+1);
|
||||
MyFactorPosePoint2_collectorInsertAndMakeBase_63(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 64:
|
||||
MyFactorPosePoint2_deconstructor_64(nargout, out, nargin-1, in+1);
|
||||
MyFactorPosePoint2_constructor_64(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 65:
|
||||
MyFactorPosePoint2_print_65(nargout, out, nargin-1, in+1);
|
||||
MyFactorPosePoint2_deconstructor_65(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
case 66:
|
||||
MyFactorPosePoint2_print_66(nargout, out, nargin-1, in+1);
|
||||
break;
|
||||
}
|
||||
} catch(const std::exception& e) {
|
||||
|
|
|
@ -31,7 +31,8 @@ PYBIND11_MODULE(class_py, m_) {
|
|||
py::class_<Fun<double>, std::shared_ptr<Fun<double>>>(m_, "FunDouble")
|
||||
.def("templatedMethodString",[](Fun<double>* self, double d, string t){return self->templatedMethod<string>(d, t);}, py::arg("d"), py::arg("t"))
|
||||
.def("multiTemplatedMethodStringSize_t",[](Fun<double>* self, double d, string t, size_t u){return self->multiTemplatedMethod<string,size_t>(d, t, u);}, py::arg("d"), py::arg("t"), py::arg("u"))
|
||||
.def_static("staticMethodWithThis",[](){return Fun<double>::staticMethodWithThis();});
|
||||
.def_static("staticMethodWithThis",[](){return Fun<double>::staticMethodWithThis();})
|
||||
.def_static("templatedStaticMethodInt",[](const int& m){return Fun<double>::templatedStaticMethod<int>(m);}, py::arg("m"));
|
||||
|
||||
py::class_<Test, std::shared_ptr<Test>>(m_, "Test")
|
||||
.def(py::init<>())
|
||||
|
|
|
@ -10,6 +10,9 @@ class Fun {
|
|||
|
||||
static This staticMethodWithThis();
|
||||
|
||||
template<T={int}>
|
||||
static double templatedStaticMethod(const T& m);
|
||||
|
||||
template<T={string}>
|
||||
This templatedMethod(double d, T t);
|
||||
|
||||
|
|
|
@ -18,11 +18,13 @@ import unittest
|
|||
|
||||
sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
|
||||
|
||||
from gtwrap.interface_parser import (
|
||||
ArgumentList, Class, Constructor, Enum, Enumerator, ForwardDeclaration,
|
||||
GlobalFunction, Include, Method, Module, Namespace, Operator, ReturnType,
|
||||
StaticMethod, TemplatedType, Type, TypedefTemplateInstantiation, Typename,
|
||||
Variable)
|
||||
from gtwrap.interface_parser import (ArgumentList, Class, Constructor, Enum,
|
||||
Enumerator, ForwardDeclaration,
|
||||
GlobalFunction, Include, Method, Module,
|
||||
Namespace, Operator, ReturnType,
|
||||
StaticMethod, TemplatedType, Type,
|
||||
TypedefTemplateInstantiation, Typename,
|
||||
Variable)
|
||||
|
||||
|
||||
class TestInterfaceParser(unittest.TestCase):
|
||||
|
@ -266,6 +268,11 @@ class TestInterfaceParser(unittest.TestCase):
|
|||
self.assertEqual("char", return_type.type1.typename.name)
|
||||
self.assertEqual("int", return_type.type2.typename.name)
|
||||
|
||||
return_type = ReturnType.rule.parseString("pair<Test ,Test*>")[0]
|
||||
self.assertEqual("Test", return_type.type1.typename.name)
|
||||
self.assertEqual("Test", return_type.type2.typename.name)
|
||||
self.assertTrue(return_type.type2.is_shared_ptr)
|
||||
|
||||
def test_method(self):
|
||||
"""Test for a class method."""
|
||||
ret = Method.rule.parseString("int f();")[0]
|
||||
|
@ -283,6 +290,13 @@ class TestInterfaceParser(unittest.TestCase):
|
|||
self.assertEqual("f", ret.name)
|
||||
self.assertEqual(3, len(ret.args))
|
||||
|
||||
ret = Method.rule.parseString(
|
||||
"pair<First ,Second*> create_MixedPtrs();")[0]
|
||||
self.assertEqual("create_MixedPtrs", ret.name)
|
||||
self.assertEqual(0, len(ret.args))
|
||||
self.assertEqual("First", ret.return_type.type1.typename.name)
|
||||
self.assertEqual("Second", ret.return_type.type2.typename.name)
|
||||
|
||||
def test_static_method(self):
|
||||
"""Test for static methods."""
|
||||
ret = StaticMethod.rule.parseString("static int f();")[0]
|
||||
|
|
|
@ -42,17 +42,16 @@ class TestWrap(unittest.TestCase):
|
|||
# Create the `actual/matlab` directory
|
||||
os.makedirs(self.MATLAB_ACTUAL_DIR, exist_ok=True)
|
||||
|
||||
def compare_and_diff(self, file):
|
||||
def compare_and_diff(self, file, actual):
|
||||
"""
|
||||
Compute the comparison between the expected and actual file,
|
||||
and assert if diff is zero.
|
||||
"""
|
||||
output = osp.join(self.MATLAB_ACTUAL_DIR, file)
|
||||
expected = osp.join(self.MATLAB_TEST_DIR, file)
|
||||
success = filecmp.cmp(output, expected)
|
||||
success = filecmp.cmp(actual, expected)
|
||||
|
||||
if not success:
|
||||
print("Differ in file: {}".format(file))
|
||||
os.system("diff {} {}".format(output, expected))
|
||||
os.system("diff {} {}".format(actual, expected))
|
||||
self.assertTrue(success, "Mismatch for file {0}".format(file))
|
||||
|
||||
def test_geometry(self):
|
||||
|
@ -77,7 +76,8 @@ class TestWrap(unittest.TestCase):
|
|||
self.assertTrue(osp.isdir(osp.join(self.MATLAB_ACTUAL_DIR, '+gtsam')))
|
||||
|
||||
for file in files:
|
||||
self.compare_and_diff(file)
|
||||
actual = osp.join(self.MATLAB_ACTUAL_DIR, file)
|
||||
self.compare_and_diff(file, actual)
|
||||
|
||||
def test_functions(self):
|
||||
"""Test interface file with function info."""
|
||||
|
@ -99,7 +99,8 @@ class TestWrap(unittest.TestCase):
|
|||
]
|
||||
|
||||
for file in files:
|
||||
self.compare_and_diff(file)
|
||||
actual = osp.join(self.MATLAB_ACTUAL_DIR, file)
|
||||
self.compare_and_diff(file, actual)
|
||||
|
||||
def test_class(self):
|
||||
"""Test interface file with only class info."""
|
||||
|
@ -121,7 +122,8 @@ class TestWrap(unittest.TestCase):
|
|||
]
|
||||
|
||||
for file in files:
|
||||
self.compare_and_diff(file)
|
||||
actual = osp.join(self.MATLAB_ACTUAL_DIR, file)
|
||||
self.compare_and_diff(file, actual)
|
||||
|
||||
def test_templates(self):
|
||||
"""Test interface file with template info."""
|
||||
|
@ -138,7 +140,8 @@ class TestWrap(unittest.TestCase):
|
|||
files = ['template_wrapper.cpp']
|
||||
|
||||
for file in files:
|
||||
self.compare_and_diff(file)
|
||||
actual = osp.join(self.MATLAB_ACTUAL_DIR, file)
|
||||
self.compare_and_diff(file, actual)
|
||||
|
||||
def test_inheritance(self):
|
||||
"""Test interface file with class inheritance definitions."""
|
||||
|
@ -157,7 +160,8 @@ class TestWrap(unittest.TestCase):
|
|||
]
|
||||
|
||||
for file in files:
|
||||
self.compare_and_diff(file)
|
||||
actual = osp.join(self.MATLAB_ACTUAL_DIR, file)
|
||||
self.compare_and_diff(file, actual)
|
||||
|
||||
def test_namespaces(self):
|
||||
"""
|
||||
|
@ -181,7 +185,8 @@ class TestWrap(unittest.TestCase):
|
|||
]
|
||||
|
||||
for file in files:
|
||||
self.compare_and_diff(file)
|
||||
actual = osp.join(self.MATLAB_ACTUAL_DIR, file)
|
||||
self.compare_and_diff(file, actual)
|
||||
|
||||
def test_special_cases(self):
|
||||
"""
|
||||
|
@ -203,7 +208,8 @@ class TestWrap(unittest.TestCase):
|
|||
]
|
||||
|
||||
for file in files:
|
||||
self.compare_and_diff(file)
|
||||
actual = osp.join(self.MATLAB_ACTUAL_DIR, file)
|
||||
self.compare_and_diff(file, actual)
|
||||
|
||||
def test_multiple_files(self):
|
||||
"""
|
||||
|
@ -228,7 +234,8 @@ class TestWrap(unittest.TestCase):
|
|||
]
|
||||
|
||||
for file in files:
|
||||
self.compare_and_diff(file)
|
||||
actual = osp.join(self.MATLAB_ACTUAL_DIR, file)
|
||||
self.compare_and_diff(file, actual)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
|
|
|
@ -0,0 +1,606 @@
|
|||
"""
|
||||
GTSAM Copyright 2010-2020, Georgia Tech Research Corporation,
|
||||
Atlanta, Georgia 30332-0415
|
||||
All Rights Reserved
|
||||
|
||||
See LICENSE for the license information
|
||||
|
||||
Tests for template_instantiator.
|
||||
|
||||
Author: Varun Agrawal
|
||||
"""
|
||||
|
||||
# pylint: disable=import-error,wrong-import-position
|
||||
|
||||
import os
|
||||
import sys
|
||||
import unittest
|
||||
|
||||
sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
|
||||
|
||||
from gtwrap.interface_parser import (Argument, ArgumentList, Class,
|
||||
Constructor, ForwardDeclaration,
|
||||
GlobalFunction, Include, Method,
|
||||
Namespace, ReturnType, StaticMethod,
|
||||
Typename)
|
||||
from gtwrap.template_instantiator import (
|
||||
InstantiatedClass, InstantiatedConstructor, InstantiatedDeclaration,
|
||||
InstantiatedGlobalFunction, InstantiatedMethod, InstantiatedStaticMethod,
|
||||
InstantiationHelper, instantiate_args_list, instantiate_name,
|
||||
instantiate_namespace, instantiate_return_type, instantiate_type,
|
||||
is_scoped_template)
|
||||
|
||||
|
||||
class TestInstantiationHelper(unittest.TestCase):
|
||||
"""Tests for the InstantiationHelper class."""
|
||||
def test_constructor(self):
|
||||
"""Test constructor."""
|
||||
helper = InstantiationHelper(InstantiatedClass)
|
||||
self.assertEqual(helper.instantiation_type, InstantiatedClass)
|
||||
helper = InstantiationHelper(InstantiatedConstructor)
|
||||
self.assertEqual(helper.instantiation_type, InstantiatedConstructor)
|
||||
helper = InstantiationHelper(InstantiatedDeclaration)
|
||||
self.assertEqual(helper.instantiation_type, InstantiatedDeclaration)
|
||||
helper = InstantiationHelper(InstantiatedGlobalFunction)
|
||||
self.assertEqual(helper.instantiation_type, InstantiatedGlobalFunction)
|
||||
helper = InstantiationHelper(InstantiatedMethod)
|
||||
self.assertEqual(helper.instantiation_type, InstantiatedMethod)
|
||||
helper = InstantiationHelper(InstantiatedStaticMethod)
|
||||
self.assertEqual(helper.instantiation_type, InstantiatedStaticMethod)
|
||||
|
||||
def test_instantiate(self):
|
||||
"""Test instantiate method."""
|
||||
method = Method.rule.parseString("""
|
||||
template<U={double}>
|
||||
double method(const T x, const U& param);
|
||||
""")[0]
|
||||
cls = Class.rule.parseString("""
|
||||
template<T={string}>
|
||||
class Foo {};
|
||||
""")[0]
|
||||
typenames = ['T', 'U']
|
||||
class_instantiations = [Typename.rule.parseString("string")[0]]
|
||||
method_instantiations = [Typename.rule.parseString("double")[0]]
|
||||
|
||||
parent = InstantiatedClass(cls, class_instantiations)
|
||||
|
||||
helper = InstantiationHelper(InstantiatedMethod)
|
||||
instantiated_methods = helper.instantiate([], method, typenames,
|
||||
class_instantiations,
|
||||
method_instantiations,
|
||||
parent)
|
||||
|
||||
self.assertEqual(len(instantiated_methods), 1)
|
||||
args_list = instantiated_methods[0].args.list()
|
||||
self.assertEqual(args_list[0].ctype.get_typename(), 'string')
|
||||
self.assertEqual(args_list[1].ctype.get_typename(), 'double')
|
||||
|
||||
def test_multilevel_instantiation(self):
|
||||
"""
|
||||
Test method for multilevel instantiation
|
||||
i.e. instantiation at both the class and method level.
|
||||
"""
|
||||
cls = Class.rule.parseString("""
|
||||
template<T={string}>
|
||||
class Foo {
|
||||
template<U={double}>
|
||||
double method1(const T x, const U& param);
|
||||
|
||||
template<V={int}>
|
||||
V method2(const T x);
|
||||
};
|
||||
""")[0]
|
||||
|
||||
typenames = ['T']
|
||||
class_instantiations = [Typename.rule.parseString("string")[0]]
|
||||
parent = InstantiatedClass(cls, class_instantiations)
|
||||
|
||||
helper = InstantiationHelper(InstantiatedMethod)
|
||||
|
||||
instantiated_methods = helper.multilevel_instantiation(
|
||||
cls.methods, typenames, parent)
|
||||
self.assertEqual(len(instantiated_methods), 2)
|
||||
self.assertEqual(
|
||||
instantiated_methods[0].args.list()[0].ctype.get_typename(),
|
||||
'string')
|
||||
self.assertEqual(
|
||||
instantiated_methods[0].args.list()[1].ctype.get_typename(),
|
||||
'double')
|
||||
self.assertEqual(
|
||||
instantiated_methods[1].args.list()[0].ctype.get_typename(),
|
||||
'string')
|
||||
self.assertEqual(
|
||||
instantiated_methods[1].return_type.type1.get_typename(), 'int')
|
||||
|
||||
|
||||
class TestInstantiatedGlobalFunction(unittest.TestCase):
|
||||
"""Tests for the InstantiatedGlobalFunction class."""
|
||||
def setUp(self):
|
||||
original = GlobalFunction.rule.parseString("""
|
||||
template<T={int}, R={double}>
|
||||
R function(const T& x);
|
||||
""")[0]
|
||||
instantiations = [
|
||||
Typename.rule.parseString("int")[0],
|
||||
Typename.rule.parseString("double")[0]
|
||||
]
|
||||
self.func = InstantiatedGlobalFunction(original, instantiations)
|
||||
|
||||
def test_constructor(self):
|
||||
"""Test constructor."""
|
||||
self.assertIsInstance(self.func, InstantiatedGlobalFunction)
|
||||
self.assertIsInstance(self.func.original, GlobalFunction)
|
||||
self.assertEqual(self.func.name, "functionIntDouble")
|
||||
self.assertEqual(len(self.func.args.list()), 1)
|
||||
self.assertEqual(self.func.args.list()[0].ctype.get_typename(), "int")
|
||||
self.assertEqual(self.func.return_type.type1.get_typename(), "double")
|
||||
|
||||
def test_to_cpp(self):
|
||||
"""Test to_cpp method."""
|
||||
actual = self.func.to_cpp()
|
||||
self.assertEqual(actual, "function<int,double>")
|
||||
|
||||
|
||||
class TestInstantiatedConstructor(unittest.TestCase):
|
||||
"""Tests for the InstantiatedConstructor class."""
|
||||
def setUp(self):
|
||||
constructor = Constructor.rule.parseString("""
|
||||
template<U={double}>
|
||||
Class(C x, const U& param);
|
||||
""")[0]
|
||||
instantiations = [
|
||||
Typename.rule.parseString("double")[0],
|
||||
Typename.rule.parseString("string")[0]
|
||||
]
|
||||
self.constructor = InstantiatedConstructor(constructor, instantiations)
|
||||
|
||||
def test_constructor(self):
|
||||
"""Test constructor."""
|
||||
self.assertIsInstance(self.constructor, InstantiatedConstructor)
|
||||
self.assertIsInstance(self.constructor.original, Constructor)
|
||||
|
||||
def test_construct(self):
|
||||
"""Test the construct classmethod."""
|
||||
constructor = Constructor.rule.parseString("""
|
||||
template<U={double}>
|
||||
Class(C x, const U& param);
|
||||
""")[0]
|
||||
c = Class.rule.parseString("""
|
||||
template<C={string}>
|
||||
class Class {};
|
||||
""")[0]
|
||||
class_instantiations = [Typename.rule.parseString("double")[0]]
|
||||
method_instantiations = [Typename.rule.parseString("string")[0]]
|
||||
typenames = ['C', 'U']
|
||||
parent = InstantiatedClass(c, class_instantiations)
|
||||
instantiated_args = instantiate_args_list(
|
||||
constructor.args.list(),
|
||||
typenames, class_instantiations + method_instantiations,
|
||||
parent.cpp_typename())
|
||||
|
||||
instantiated_constructor = InstantiatedConstructor.construct(
|
||||
constructor, typenames, class_instantiations,
|
||||
method_instantiations, instantiated_args, parent)
|
||||
self.assertEqual(instantiated_constructor.name, "ClassDouble")
|
||||
self.assertEqual(
|
||||
instantiated_constructor.args.list()[0].ctype.get_typename(),
|
||||
"double")
|
||||
self.assertEqual(
|
||||
instantiated_constructor.args.list()[1].ctype.get_typename(),
|
||||
"string")
|
||||
|
||||
def test_to_cpp(self):
|
||||
"""Test the to_cpp method."""
|
||||
actual = self.constructor.to_cpp()
|
||||
self.assertEqual(actual, "Class<double,string>")
|
||||
|
||||
|
||||
class TestInstantiatedMethod(unittest.TestCase):
|
||||
"""Tests for the InstantiatedMethod class."""
|
||||
def setUp(self):
|
||||
method = Method.rule.parseString("""
|
||||
template<U={double}>
|
||||
double method(const U& param);
|
||||
""")[0]
|
||||
instantiations = [Typename.rule.parseString("double")[0]]
|
||||
self.method = InstantiatedMethod(method, instantiations)
|
||||
|
||||
def test_constructor(self):
|
||||
"""Test constructor."""
|
||||
self.assertIsInstance(self.method, InstantiatedMethod)
|
||||
self.assertIsInstance(self.method.original, Method)
|
||||
self.assertEqual(self.method.name, "methodDouble")
|
||||
|
||||
def test_construct(self):
|
||||
"""Test the construct classmethod."""
|
||||
method = Method.rule.parseString("""
|
||||
template<U={double}>
|
||||
T method(U& param);
|
||||
""")[0]
|
||||
method_instantiations = [Typename.rule.parseString("double")[0]]
|
||||
c = Class.rule.parseString("""
|
||||
template<T={string}>
|
||||
class Class {};
|
||||
""")[0]
|
||||
class_instantiations = [Typename.rule.parseString("string")[0]]
|
||||
|
||||
typenames = ['T', 'U']
|
||||
parent = InstantiatedClass(c, class_instantiations)
|
||||
instantiated_args = instantiate_args_list(
|
||||
method.args.list(),
|
||||
typenames, class_instantiations + method_instantiations,
|
||||
parent.cpp_typename())
|
||||
|
||||
instantiated_method = InstantiatedMethod.construct(
|
||||
method, typenames, class_instantiations, method_instantiations,
|
||||
instantiated_args, parent)
|
||||
self.assertEqual(instantiated_method.name, "methodDouble")
|
||||
self.assertEqual(
|
||||
instantiated_method.args.list()[0].ctype.get_typename(), "double")
|
||||
self.assertEqual(instantiated_method.return_type.type1.get_typename(),
|
||||
"string")
|
||||
|
||||
def test_to_cpp(self):
|
||||
"""Test the to_cpp method."""
|
||||
actual = self.method.to_cpp()
|
||||
self.assertEqual(actual, "method<double>")
|
||||
|
||||
|
||||
class TestInstantiatedStaticMethod(unittest.TestCase):
|
||||
"""Tests for the InstantiatedStaticMethod class."""
|
||||
def setUp(self):
|
||||
static_method = StaticMethod.rule.parseString("""
|
||||
template<U={double}>
|
||||
static T staticMethod(const U& param);
|
||||
""")[0]
|
||||
instantiations = [Typename.rule.parseString("double")[0]]
|
||||
self.static_method = InstantiatedStaticMethod(static_method,
|
||||
instantiations)
|
||||
|
||||
def test_constructor(self):
|
||||
"""Test constructor."""
|
||||
self.assertIsInstance(self.static_method, InstantiatedStaticMethod)
|
||||
self.assertIsInstance(self.static_method.original, StaticMethod)
|
||||
self.assertEqual(self.static_method.name, "staticMethodDouble")
|
||||
|
||||
def test_construct(self):
|
||||
"""Test the construct classmethod."""
|
||||
static_method = StaticMethod.rule.parseString("""
|
||||
template<U={double}>
|
||||
static T staticMethod(U& param);
|
||||
""")[0]
|
||||
method_instantiations = [Typename.rule.parseString("double")[0]]
|
||||
c = Class.rule.parseString("""
|
||||
template<T={string}>
|
||||
class Class {};
|
||||
""")[0]
|
||||
class_instantiations = [Typename.rule.parseString("string")[0]]
|
||||
|
||||
typenames = ['T', 'U']
|
||||
parent = InstantiatedClass(c, class_instantiations)
|
||||
instantiated_args = instantiate_args_list(
|
||||
static_method.args.list(),
|
||||
typenames, class_instantiations + method_instantiations,
|
||||
parent.cpp_typename())
|
||||
|
||||
instantiated_static_method = InstantiatedStaticMethod.construct(
|
||||
static_method, typenames, class_instantiations,
|
||||
method_instantiations, instantiated_args, parent)
|
||||
self.assertEqual(instantiated_static_method.name, "staticMethodDouble")
|
||||
self.assertEqual(
|
||||
instantiated_static_method.args.list()[0].ctype.get_typename(),
|
||||
"double")
|
||||
self.assertEqual(
|
||||
instantiated_static_method.return_type.type1.get_typename(),
|
||||
"string")
|
||||
|
||||
def test_to_cpp(self):
|
||||
"""Test the to_cpp method."""
|
||||
actual = self.static_method.to_cpp()
|
||||
self.assertEqual(actual, "staticMethod<double>")
|
||||
|
||||
|
||||
class TestInstantiatedClass(unittest.TestCase):
|
||||
"""Tests for the InstantiatedClass class."""
|
||||
def setUp(self):
|
||||
cl = Class.rule.parseString("""
|
||||
template<T={string}>
|
||||
class Foo {
|
||||
template<C={int}>
|
||||
Foo(C& c);
|
||||
|
||||
template<S={char}>
|
||||
static T staticMethod(const S& s);
|
||||
|
||||
template<M={double}>
|
||||
T method(const M& m);
|
||||
|
||||
T operator*(T other) const;
|
||||
|
||||
T prop;
|
||||
};
|
||||
""")[0]
|
||||
class_instantiations = [Typename.rule.parseString('string')[0]]
|
||||
self.member_instantiations = [
|
||||
Typename.rule.parseString('int')[0],
|
||||
Typename.rule.parseString('char')[0],
|
||||
Typename.rule.parseString('double')[0],
|
||||
]
|
||||
self.cl = InstantiatedClass(cl, class_instantiations)
|
||||
self.typenames = self.cl.original.template.typenames
|
||||
|
||||
def test_constructor(self):
|
||||
"""Test constructor."""
|
||||
self.assertIsInstance(self.cl, InstantiatedClass)
|
||||
self.assertIsInstance(self.cl.original, Class)
|
||||
self.assertEqual(self.cl.name, "FooString")
|
||||
|
||||
def test_instantiate_ctors(self):
|
||||
"""Test instantiate_ctors method."""
|
||||
ctors = self.cl.instantiate_ctors(self.typenames)
|
||||
self.assertEqual(len(ctors), 1)
|
||||
self.assertEqual(ctors[0].name, "FooString")
|
||||
self.assertEqual(ctors[0].args.list()[0].ctype.get_typename(), "int")
|
||||
|
||||
def test_instantiate_static_methods(self):
|
||||
"""Test instantiate_static_methods method."""
|
||||
static_methods = self.cl.instantiate_static_methods(self.typenames)
|
||||
self.assertEqual(len(static_methods), 1)
|
||||
self.assertEqual(static_methods[0].name, "staticMethodChar")
|
||||
self.assertEqual(static_methods[0].args.list()[0].ctype.get_typename(),
|
||||
"char")
|
||||
self.assertEqual(static_methods[0].return_type.type1.get_typename(),
|
||||
"string")
|
||||
|
||||
def test_instantiate_methods(self):
|
||||
"""Test instantiate_methods method."""
|
||||
methods = self.cl.instantiate_methods(self.typenames)
|
||||
self.assertEqual(len(methods), 1)
|
||||
self.assertEqual(methods[0].name, "methodDouble")
|
||||
self.assertEqual(methods[0].args.list()[0].ctype.get_typename(),
|
||||
"double")
|
||||
self.assertEqual(methods[0].return_type.type1.get_typename(), "string")
|
||||
|
||||
def test_instantiate_operators(self):
|
||||
"""Test instantiate_operators method."""
|
||||
operators = self.cl.instantiate_operators(self.typenames)
|
||||
self.assertEqual(len(operators), 1)
|
||||
self.assertEqual(operators[0].operator, "*")
|
||||
self.assertEqual(operators[0].args.list()[0].ctype.get_typename(),
|
||||
"string")
|
||||
self.assertEqual(operators[0].return_type.type1.get_typename(),
|
||||
"string")
|
||||
|
||||
def test_instantiate_properties(self):
|
||||
"""Test instantiate_properties method."""
|
||||
properties = self.cl.instantiate_properties(self.typenames)
|
||||
self.assertEqual(len(properties), 1)
|
||||
self.assertEqual(properties[0].name, "prop")
|
||||
self.assertEqual(properties[0].ctype.get_typename(), "string")
|
||||
|
||||
def test_cpp_typename(self):
|
||||
"""Test cpp_typename method."""
|
||||
actual = self.cl.cpp_typename()
|
||||
self.assertEqual(actual.name, "Foo<string>")
|
||||
|
||||
def test_to_cpp(self):
|
||||
"""Test to_cpp method."""
|
||||
actual = self.cl.to_cpp()
|
||||
self.assertEqual(actual, "Foo<string>")
|
||||
|
||||
|
||||
class TestInstantiatedDeclaration(unittest.TestCase):
|
||||
"""Tests for the InstantiatedDeclaration class."""
|
||||
def setUp(self):
|
||||
#TODO(Varun) Need to support templated class forward declaration.
|
||||
forward_declaration = ForwardDeclaration.rule.parseString("""
|
||||
class FooBar;
|
||||
""")[0]
|
||||
instantiations = [Typename.rule.parseString("double")[0]]
|
||||
self.declaration = InstantiatedDeclaration(
|
||||
forward_declaration, instantiations=instantiations)
|
||||
|
||||
def test_constructor(self):
|
||||
"""Test constructor."""
|
||||
self.assertIsInstance(self.declaration, InstantiatedDeclaration)
|
||||
self.assertIsInstance(self.declaration.original, ForwardDeclaration)
|
||||
self.assertEqual(self.declaration.instantiations[0].name, "double")
|
||||
|
||||
def test_to_cpp(self):
|
||||
"""Test to_cpp method."""
|
||||
cpp = self.declaration.to_cpp()
|
||||
self.assertEqual(cpp, "FooBar<double>")
|
||||
|
||||
|
||||
class TestTemplateInstantiator(unittest.TestCase):
|
||||
"""
|
||||
Test overall template instantiation and the functions in the module.
|
||||
"""
|
||||
def test_scoped_template(self):
|
||||
"""Test is_scoped_template."""
|
||||
# Test if not scoped template.
|
||||
template_typenames = ['T']
|
||||
str_arg_typename = "double"
|
||||
scoped_template, scoped_idx = is_scoped_template(
|
||||
template_typenames, str_arg_typename)
|
||||
self.assertFalse(scoped_template)
|
||||
self.assertEqual(scoped_idx, -1)
|
||||
|
||||
# Check for correct template match.
|
||||
template_typenames = ['T']
|
||||
str_arg_typename = "gtsam::Matrix"
|
||||
scoped_template, scoped_idx = is_scoped_template(
|
||||
template_typenames, str_arg_typename)
|
||||
self.assertFalse(scoped_template)
|
||||
self.assertEqual(scoped_idx, -1)
|
||||
|
||||
# Test scoped templatte
|
||||
template_typenames = ['T']
|
||||
str_arg_typename = "T::Value"
|
||||
scoped_template, scoped_idx = is_scoped_template(
|
||||
template_typenames, str_arg_typename)
|
||||
self.assertEqual(scoped_template, "T")
|
||||
self.assertEqual(scoped_idx, 0)
|
||||
|
||||
template_typenames = ['U', 'T']
|
||||
str_arg_typename = "T::Value"
|
||||
scoped_template, scoped_idx = is_scoped_template(
|
||||
template_typenames, str_arg_typename)
|
||||
self.assertEqual(scoped_template, "T")
|
||||
self.assertEqual(scoped_idx, 1)
|
||||
|
||||
def test_instantiate_type(self):
|
||||
"""Test for instantiate_type."""
|
||||
arg = Argument.rule.parseString("const T x")[0]
|
||||
template_typenames = ["T"]
|
||||
instantiations = [Typename.rule.parseString("double")[0]]
|
||||
cpp_typename = "ExampleClass"
|
||||
new_type = instantiate_type(arg.ctype,
|
||||
template_typenames,
|
||||
instantiations=instantiations,
|
||||
cpp_typename=cpp_typename,
|
||||
instantiated_class=None)
|
||||
|
||||
new_typename = new_type.typename
|
||||
self.assertEqual(new_typename.name, "double")
|
||||
self.assertEqual(new_typename.instantiated_name(), "double")
|
||||
|
||||
def test_instantiate_args_list(self):
|
||||
"""Test for instantiate_args_list."""
|
||||
args = ArgumentList.rule.parseString("T x, double y, string z")[0]
|
||||
args_list = args.list()
|
||||
template_typenames = ['T']
|
||||
instantiations = [Typename.rule.parseString("double")[0]]
|
||||
instantiated_args_list = instantiate_args_list(
|
||||
args_list,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename="ExampleClass")
|
||||
|
||||
self.assertEqual(instantiated_args_list[0].ctype.get_typename(),
|
||||
"double")
|
||||
|
||||
args = ArgumentList.rule.parseString("T x, U y, string z")[0]
|
||||
args_list = args.list()
|
||||
template_typenames = ['T', 'U']
|
||||
instantiations = [
|
||||
Typename.rule.parseString("double")[0],
|
||||
Typename.rule.parseString("Matrix")[0]
|
||||
]
|
||||
instantiated_args_list = instantiate_args_list(
|
||||
args_list,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename="ExampleClass")
|
||||
self.assertEqual(instantiated_args_list[0].ctype.get_typename(),
|
||||
"double")
|
||||
self.assertEqual(instantiated_args_list[1].ctype.get_typename(),
|
||||
"Matrix")
|
||||
|
||||
args = ArgumentList.rule.parseString("T x, U y, T z")[0]
|
||||
args_list = args.list()
|
||||
template_typenames = ['T', 'U']
|
||||
instantiations = [
|
||||
Typename.rule.parseString("double")[0],
|
||||
Typename.rule.parseString("Matrix")[0]
|
||||
]
|
||||
instantiated_args_list = instantiate_args_list(
|
||||
args_list,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename="ExampleClass")
|
||||
self.assertEqual(instantiated_args_list[0].ctype.get_typename(),
|
||||
"double")
|
||||
self.assertEqual(instantiated_args_list[1].ctype.get_typename(),
|
||||
"Matrix")
|
||||
self.assertEqual(instantiated_args_list[2].ctype.get_typename(),
|
||||
"double")
|
||||
|
||||
def test_instantiate_return_type(self):
|
||||
"""Test for instantiate_return_type."""
|
||||
return_type = ReturnType.rule.parseString("T")[0]
|
||||
template_typenames = ['T']
|
||||
instantiations = [Typename.rule.parseString("double")[0]]
|
||||
instantiated_return_type = instantiate_return_type(
|
||||
return_type,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename="ExampleClass")
|
||||
|
||||
self.assertEqual(instantiated_return_type.type1.get_typename(),
|
||||
"double")
|
||||
|
||||
return_type = ReturnType.rule.parseString("pair<T, U>")[0]
|
||||
template_typenames = ['T', 'U']
|
||||
instantiations = [
|
||||
Typename.rule.parseString("double")[0],
|
||||
Typename.rule.parseString("char")[0],
|
||||
]
|
||||
instantiated_return_type = instantiate_return_type(
|
||||
return_type,
|
||||
template_typenames,
|
||||
instantiations,
|
||||
cpp_typename="ExampleClass")
|
||||
|
||||
self.assertEqual(instantiated_return_type.type1.get_typename(),
|
||||
"double")
|
||||
self.assertEqual(instantiated_return_type.type2.get_typename(), "char")
|
||||
|
||||
def test_instantiate_name(self):
|
||||
"""Test for instantiate_name."""
|
||||
instantiations = [Typename.rule.parseString("Man")[0]]
|
||||
instantiated_name = instantiate_name("Iron", instantiations)
|
||||
self.assertEqual(instantiated_name, "IronMan")
|
||||
|
||||
def test_instantiate_namespace(self):
|
||||
"""Test for instantiate_namespace."""
|
||||
namespace = Namespace.rule.parseString("""
|
||||
namespace gtsam {
|
||||
#include <gtsam/nonlinear/Values.h>
|
||||
template<T={gtsam::Basis}>
|
||||
class Values {
|
||||
Values(const T& other);
|
||||
|
||||
template<V={Vector, Matrix}>
|
||||
void insert(size_t j, V x);
|
||||
|
||||
template<S={double}>
|
||||
static S staticMethod(const S& s);
|
||||
};
|
||||
}
|
||||
""")[0]
|
||||
instantiated_namespace = instantiate_namespace(namespace)
|
||||
|
||||
self.assertEqual(instantiated_namespace.name, "gtsam")
|
||||
self.assertEqual(instantiated_namespace.parent, "")
|
||||
|
||||
self.assertEqual(instantiated_namespace.content[0].header,
|
||||
"gtsam/nonlinear/Values.h")
|
||||
self.assertIsInstance(instantiated_namespace.content[0], Include)
|
||||
|
||||
self.assertEqual(instantiated_namespace.content[1].name, "ValuesBasis")
|
||||
self.assertIsInstance(instantiated_namespace.content[1], Class)
|
||||
|
||||
self.assertIsInstance(instantiated_namespace.content[1].ctors[0],
|
||||
Constructor)
|
||||
self.assertEqual(instantiated_namespace.content[1].ctors[0].name,
|
||||
"ValuesBasis")
|
||||
|
||||
self.assertIsInstance(instantiated_namespace.content[1].methods[0],
|
||||
Method)
|
||||
self.assertIsInstance(instantiated_namespace.content[1].methods[1],
|
||||
Method)
|
||||
self.assertEqual(instantiated_namespace.content[1].methods[0].name,
|
||||
"insertVector")
|
||||
self.assertEqual(instantiated_namespace.content[1].methods[1].name,
|
||||
"insertMatrix")
|
||||
|
||||
self.assertIsInstance(
|
||||
instantiated_namespace.content[1].static_methods[0], StaticMethod)
|
||||
self.assertEqual(
|
||||
instantiated_namespace.content[1].static_methods[0].name,
|
||||
"staticMethodDouble")
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main()
|
Loading…
Reference in New Issue