opencv/modules/matlab/generator/templates/template_class_base.cpp

99 lines
2.7 KiB
C++
Raw Normal View History

{% import 'functional.cpp' as functional %}
2013-03-18 10:35:43 +10:00
/*
2013-03-18 14:48:10 +10:00
* file: {{clss.name}}Bridge.cpp
2013-03-18 10:35:43 +10:00
* author: A trusty code generator
2013-03-18 12:37:42 +10:00
* date: {{time.strftime("%a, %d %b %Y %H:%M:%S", time.localtime())}}
*
2013-03-18 10:35:43 +10:00
* This file was autogenerated, do not modify.
2013-08-30 01:09:29 +10:00
* See LICENSE for full modification and redistribution details.
2013-03-18 12:37:42 +10:00
* Copyright {{time.strftime("%Y", time.localtime())}} The OpenCV Foundation
2013-03-18 10:35:43 +10:00
*/
#include <mex.h>
2013-03-18 10:35:43 +10:00
#include <vector>
#include <string>
#include <opencv2/matlab/map.hpp>
#include <opencv2/matlab/bridge.hpp>
#include <opencv2/core.hpp>
using namespace cv;
using namespace matlab;
using namespace bridge;
2013-03-18 10:35:43 +10:00
namespace {
2013-03-18 14:48:10 +10:00
typedef std::vector<Bridge> (*)({{clss.name}}&, const std::vector<Bridge>&) MethodSignature;
2013-03-18 10:35:43 +10:00
{% for function in clss.methods %}
{% if function.constructor %}
// wrapper for {{function.name}}() constructor
{{ function.clss }} {{function.name}}(const std::vector<Bridge>& inputs) {
{{ functional.handleInputs(function) }}
{{ functional.compose(function) }}
return obj;
}
{% else %}
2013-03-18 10:35:43 +10:00
// wrapper for {{function.name}}() method
std::vector<Bridge> {{function.name}}({{clss.name}}& inst, const std::vector<Bridge>& inputs) {
std::vector<Bridge> outputs{% if function|noutputs %}({{function|noutputs}}){% endif %};
{{ functional.handleInputs(function) }}
{{ functional.composeWithExceptionHandler(function) }}
{{ functional.handleOutputs(function) }}
return outputs;
2013-03-18 10:35:43 +10:00
}
{% endif %}
2013-03-18 10:35:43 +10:00
{% endfor %}
Map<std::string, MethodSignature> createMethodMap() {
2013-03-18 10:35:43 +10:00
Map<std::string, MethodSignature> m;
{% for function in clss.methods %}
2013-03-18 10:35:43 +10:00
m["{{function.name}}"] = &{{function.name}};
{% endfor %}
2013-03-18 14:48:10 +10:00
2013-03-18 10:35:43 +10:00
return m;
}
static const Map<std::string, MethodSignature> methods = createMethodMap();
2013-03-18 14:48:10 +10:00
// map of created {{clss.name}} instances. Don't trust the user to keep them safe...
static Map<void *, {{clss.name}}> instances;
2013-03-18 10:35:43 +10:00
/*
2013-03-18 14:48:10 +10:00
* {{ clss.name }}
2013-03-18 10:35:43 +10:00
* Gateway routine
* nlhs - number of return arguments
* plhs - pointers to return arguments
* nrhs - number of input arguments
* prhs - pointers to input arguments
*/
void mexFunction(int nlhs, mxArray* plhs[],
int nrhs, const mxArray* prhs[]) {
// parse the inputs
Bridge method_name(prhs[0]);
Bridge handle(prhs[1]);
std::vector<Bridge> brhs(prhs+2, prhs+nrhs);
// retrieve the instance of interest
try {
2013-03-18 14:48:10 +10:00
{{clss.name}}& inst = instances.at(handle.address());
2013-03-18 10:35:43 +10:00
} catch (const std::out_of_range& e) {
mexErrMsgTxt("Invalid object instance provided");
}
// invoke the correct method on the data
try {
std::vector<Bridge> blhs = (*methods.at(method_name))(inst, brhs);
} catch (const std::out_of_range& e) {
mexErrMsgTxt("Unknown method specified");
}
{% block postfun %}
{% endblock %}
{% block cleanup %}
{% endblock %}
2013-03-18 14:48:10 +10:00
2013-03-18 10:35:43 +10:00
}
} // end namespace