gtsam/wrap/wrap.cpp

78 lines
2.3 KiB
C++

/* ----------------------------------------------------------------------------
* 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;
/**
* 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
*/
void generate_matlab_toolbox(
const string& interfacePath,
const string& moduleName,
const string& toolboxPath,
const string& headerPath)
{
// Parse interface file into class object
// This recursively creates Class objects, Method objects, etc...
wrap::Module module(interfacePath, moduleName, false);
// Then emit MATLAB code
module.matlab_code(toolboxPath,headerPath);
}
/** Displays usage information */
void usage() {
cerr << "wrap parses an interface file and produces a MATLAB toolbox" << endl;
cerr << "usage: wrap 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;
}
/**
* main parses arguments and calls generate_matlab_toolbox above
* Typically called from "make all" using appropriate arguments
*/
int main(int argc, const char* argv[]) {
if (argc != 5) {
cerr << "Invalid arguments:\n";
for (int i=0; i<argc; ++i)
cerr << argv[i] << endl;
cerr << endl;
usage();
}
else {
try {
generate_matlab_toolbox(argv[1],argv[2],argv[3],argv[4]);
} catch(std::exception& e) {
cerr << e.what() << endl;
return 1;
}
}
return 0;
}