2013-06-21 17:33:24 -07:00
|
|
|
{% import 'functional.cpp' as functional %}
|
2013-03-13 21:52:13 +10:00
|
|
|
/*
|
|
|
|
* file: {{fun.name}}.cpp
|
|
|
|
* 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-09-03 00:16:46 +10:00
|
|
|
*
|
2013-03-13 21:52:13 +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-13 21:52:13 +10:00
|
|
|
*/
|
2013-06-19 11:54:14 +10:00
|
|
|
#include <string>
|
2013-03-13 21:52:13 +10:00
|
|
|
#include <vector>
|
2013-06-24 12:42:28 -07:00
|
|
|
#include <cassert>
|
2013-06-19 16:37:57 +10:00
|
|
|
#include <exception>
|
2013-08-28 17:06:19 +10:00
|
|
|
#include <opencv2/matlab/bridge.hpp>
|
2013-06-21 22:55:48 -07:00
|
|
|
#include <opencv2/{{includes}}.hpp>
|
2013-06-22 12:38:40 -07:00
|
|
|
using namespace cv;
|
2013-08-30 12:39:01 +10:00
|
|
|
using namespace matlab;
|
|
|
|
using namespace bridge;
|
2013-03-13 21:52:13 +10:00
|
|
|
|
2013-09-03 00:16:46 +10:00
|
|
|
/*
|
2013-03-13 21:52:13 +10:00
|
|
|
* {{ fun.name }}
|
2013-06-21 22:55:48 -07:00
|
|
|
* {{ fun }}
|
2013-03-18 10:35:43 +10:00
|
|
|
* Gateway routine
|
2013-03-13 21:52:13 +10:00
|
|
|
* nlhs - number of return arguments
|
|
|
|
* plhs - pointers to return arguments
|
|
|
|
* nrhs - number of input arguments
|
|
|
|
* prhs - pointers to input arguments
|
|
|
|
*/
|
2013-06-29 14:24:53 -07:00
|
|
|
void mexFunction(int nlhs, mxArray*{% if fun|noutputs %} plhs[]{% else %}*{% endif %},
|
|
|
|
int nrhs, const mxArray*{% if fun|ninputs %} prhs[]{% else %}*{% endif %}) {
|
2013-03-13 21:52:13 +10:00
|
|
|
|
2013-08-30 15:06:57 +10:00
|
|
|
{% if fun|ninputs %}
|
|
|
|
// parse the inputs
|
|
|
|
ArgumentParser parser("{{fun.name}}");
|
|
|
|
parser.{{ functional.composeVariant(fun) }};
|
|
|
|
MxArrayVector sorted = parser.parse(MxArrayVector(prhs, prhs+nrhs));
|
2013-08-30 16:10:32 +10:00
|
|
|
{% endif %}
|
2013-03-13 21:52:13 +10:00
|
|
|
|
2013-06-29 14:24:53 -07:00
|
|
|
{% if fun|ninputs or fun|noutputs %}
|
2013-06-21 17:33:24 -07:00
|
|
|
// setup
|
2013-06-29 14:24:53 -07:00
|
|
|
{% if fun|ninputs %}
|
2013-08-30 15:06:57 +10:00
|
|
|
BridgeVector inputs(sorted.begin(), sorted.end());
|
2013-06-29 14:24:53 -07:00
|
|
|
{% endif -%}
|
|
|
|
{%- if fun|noutputs %}
|
2013-08-30 15:06:57 +10:00
|
|
|
BridgeVector outputs({{fun|noutputs}});
|
2013-06-29 14:24:53 -07:00
|
|
|
{% endif %}
|
2013-06-21 23:39:28 -07:00
|
|
|
{% endif %}
|
2013-03-13 21:52:13 +10:00
|
|
|
|
2013-07-02 16:42:37 -07:00
|
|
|
{{ functional.handleInputs(fun) }}
|
|
|
|
{{ functional.composeWithExceptionHandler(fun) }}
|
|
|
|
{{ functional.handleOutputs(fun) }}
|
2013-03-13 21:52:13 +10:00
|
|
|
|
2013-07-02 16:42:37 -07:00
|
|
|
{% if fun|noutputs %}
|
2013-06-21 23:39:28 -07:00
|
|
|
// push the outputs back to matlab
|
2013-08-07 00:14:13 +10:00
|
|
|
for (size_t n = 0; n < static_cast<size_t>(std::max(nlhs,1)); ++n) {
|
2013-06-28 19:48:42 -07:00
|
|
|
plhs[n] = outputs[n].toMxArray().releaseOwnership();
|
2013-06-21 23:39:28 -07:00
|
|
|
}
|
2013-06-22 23:26:27 -07:00
|
|
|
{% endif %}
|
2013-03-13 21:52:13 +10:00
|
|
|
}
|