gtsam/wrap/wrap.cpp

88 lines
2.6 KiB
C++
Raw Normal View History

/* ----------------------------------------------------------------------------
* GTSAM Copyright 2010, Georgia Tech Research Corporation,
* Atlanta, Georgia 30332-0415
* All Rights Reserved
* Authors: Frank Dellaert, et al. (see THANKS for the full author list)
* See LICENSE for the license information
* -------------------------------------------------------------------------- */
/**
* @file wrap.cpp
* @brief wraps functions
* @author Frank Dellaert
**/
#include <stdio.h>
#include <iostream>
#include "Module.h"
using namespace std;
2016-09-09 01:33:32 +08:00
/** Displays usage information */
void usage() {
cerr << "wrap parses an interface file and produces a MATLAB toolbox" << endl;
cerr << "usage: wrap [--matlab|--cython] interfacePath moduleName toolboxPath headerPath" << endl;
cerr << " interfacePath : *absolute* path to directory of module interface file" << endl;
cerr << " moduleName : the name of the module, interface file must be called moduleName.h" << endl;
cerr << " toolboxPath : the directory in which to generate the wrappers" << endl;
cerr << " headerPath : path to matlab.h" << endl;
}
/**
2011-10-14 12:43:06 +08:00
* Top-level function to wrap a module
* @param interfacePath path to where interface file lives, e.g., borg/gtsam
* @param moduleName name of the module to be generated e.g. gtsam
* @param toolboxPath path where the toolbox should be generated, e.g. borg/gtsam/build
* @param headerPath is the path to matlab.h
*/
2016-09-09 01:33:32 +08:00
void generate_toolbox(
const string& language,
const string& interfacePath,
const string& moduleName,
const string& toolboxPath,
const string& headerPath)
{
2011-10-14 12:43:06 +08:00
// Parse interface file into class object
// This recursively creates Class objects, Method objects, etc...
wrap::Module module(interfacePath, moduleName, false);
2016-09-09 01:33:32 +08:00
if (language == "--matlab")
2011-10-14 12:43:06 +08:00
// Then emit MATLAB code
2016-09-09 01:33:32 +08:00
module.matlab_code(toolboxPath);
else if (language == "--cython") {
module.cython_code(toolboxPath);
}
else {
cerr << "First argument invalid" << endl;
cerr << endl;
usage();
}
}
2011-10-14 12:43:06 +08:00
/**
* main parses arguments and calls generate_matlab_toolbox above
* Typically called from "make all" using appropriate arguments
2011-10-14 12:43:06 +08:00
*/
int main(int argc, const char* argv[]) {
2016-09-09 01:33:32 +08:00
if (argc != 6) {
cerr << "Invalid arguments:\n";
for (int i=0; i<argc; ++i)
cerr << argv[i] << endl;
cerr << endl;
usage();
}
else {
try {
2016-09-09 01:33:32 +08:00
generate_toolbox(argv[1], argv[2],argv[3],argv[4],argv[5]);
} catch(std::exception& e) {
cerr << e.what() << endl;
return 1;
}
}
2011-10-14 12:43:06 +08:00
return 0;
}