mirror of
https://github.com/nasa/trick.git
synced 2024-12-20 21:53:10 +00:00
684f0e6bdc
Initial checkin of using udunits for measurement units conversions. Replaced our conversion code in ICG and swig code to use udunits. Also added code to convert unit symbols that we used in Trick that are different names in udunits. Added a sim_object that will eventually allow users to specify a custom set of files to read units information. refs #231
54 lines
1.3 KiB
C++
54 lines
1.3 KiB
C++
|
|
#include <iostream>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include "trick/UnitsMap.hh"
|
|
|
|
// Class static pointer initialization
|
|
Trick::UnitsMap * Trick::UnitsMap::pInstance = NULL ;
|
|
|
|
// Memeber Function
|
|
Trick::UnitsMap * Trick::UnitsMap::units_map() {
|
|
if ( pInstance == NULL ) {
|
|
pInstance = new Trick::UnitsMap() ;
|
|
}
|
|
|
|
return(pInstance) ;
|
|
} ;
|
|
|
|
// Destructor
|
|
Trick::UnitsMap::~UnitsMap() {
|
|
|
|
std::map<std::string, char * >::iterator pit ;
|
|
|
|
for ( pit = param_units.begin() ; pit != param_units.end() ; pit++ ) {
|
|
free((*pit).second) ;
|
|
}
|
|
param_units.clear() ;
|
|
|
|
}
|
|
|
|
// Member Function
|
|
int Trick::UnitsMap::add_param(std::string param , const char * units) {
|
|
/**
|
|
* @par Design Details:
|
|
* @li Adds a variable with specified units to the map. The key is the name of a variable and the value is the units of the variable.
|
|
*/
|
|
param_units[param] = strdup(units) ;
|
|
return(0) ;
|
|
}
|
|
|
|
// Memeber Function
|
|
std::string Trick::UnitsMap::get_units( std::string param ) {
|
|
/**
|
|
* @par Design Details:
|
|
* @li Finds the specified variable in the map and returns the units of the found variable.
|
|
* If the variable can not be found, returns "1" (unitless).
|
|
*/
|
|
if ( param_units.find(param) != param_units.end() ) {
|
|
return(std::string(param_units[param])) ;
|
|
} else {
|
|
return(std::string("1")) ;
|
|
}
|
|
}
|