mirror of
https://github.com/bulletphysics/bullet3
synced 2025-01-18 21:10:05 +00:00
123 lines
2.7 KiB
C++
123 lines
2.7 KiB
C++
|
|
#ifndef URDF_FIND_MESH_FILE_H
|
|
#define URDF_FIND_MESH_FILE_H
|
|
|
|
#include "../../CommonInterfaces/CommonFileIOInterface.h"
|
|
#include "Bullet3Common/b3Logging.h"
|
|
|
|
#include <string>
|
|
#include <list>
|
|
|
|
#include "UrdfParser.h"
|
|
|
|
static bool UrdfFindMeshFile(
|
|
CommonFileIOInterface* fileIO,
|
|
const std::string& urdf_path, std::string fn,
|
|
const std::string& error_message_prefix,
|
|
std::string* out_found_filename, int* out_type)
|
|
{
|
|
if (fn.size() <= 4)
|
|
{
|
|
b3Warning("%s: invalid mesh filename '%s'\n", error_message_prefix.c_str(), fn.c_str());
|
|
return false;
|
|
}
|
|
|
|
std::string ext;
|
|
std::string ext_ = fn.substr(fn.size() - 4);
|
|
for (std::string::iterator i = ext_.begin(); i != ext_.end(); ++i)
|
|
{
|
|
ext += char(tolower(*i));
|
|
}
|
|
|
|
if (ext == ".dae")
|
|
{
|
|
*out_type = UrdfGeometry::FILE_COLLADA;
|
|
}
|
|
else if (ext == ".stl")
|
|
{
|
|
*out_type = UrdfGeometry::FILE_STL;
|
|
}
|
|
else if (ext == ".obj")
|
|
{
|
|
*out_type = UrdfGeometry::FILE_OBJ;
|
|
}
|
|
else if (ext == ".cdf")
|
|
{
|
|
*out_type = UrdfGeometry::FILE_CDF;
|
|
}
|
|
else if (ext == ".vtk")
|
|
{
|
|
*out_type = UrdfGeometry::FILE_VTK;
|
|
}
|
|
else
|
|
{
|
|
b3Warning("%s: invalid mesh filename extension '%s'\n", error_message_prefix.c_str(), ext.c_str());
|
|
return false;
|
|
}
|
|
|
|
std::string drop_it_pack = "package://";
|
|
std::string drop_it_model = "model://";
|
|
if (fn.substr(0, drop_it_pack.length()) == drop_it_pack)
|
|
fn = fn.substr(drop_it_pack.length());
|
|
else if (fn.substr(0, drop_it_model.length()) == drop_it_model)
|
|
fn = fn.substr(drop_it_model.length());
|
|
|
|
std::list<std::string> shorter;
|
|
shorter.push_back("../..");
|
|
shorter.push_back("..");
|
|
shorter.push_back(".");
|
|
int cnt = urdf_path.size();
|
|
for (int i = 0; i < cnt; ++i)
|
|
{
|
|
if (urdf_path[i] == '/' || urdf_path[i] == '\\')
|
|
{
|
|
shorter.push_back(urdf_path.substr(0, i));
|
|
}
|
|
}
|
|
shorter.reverse();
|
|
|
|
std::string existing_file;
|
|
|
|
|
|
|
|
{
|
|
for (std::list<std::string>::iterator x = shorter.begin(); x != shorter.end(); ++x)
|
|
{
|
|
std::string attempt = *x + "/" + fn;
|
|
int f = fileIO->fileOpen(attempt.c_str(), "rb");
|
|
if (f<0)
|
|
{
|
|
//b3Printf("%s: tried '%s'", error_message_prefix.c_str(), attempt.c_str());
|
|
continue;
|
|
}
|
|
fileIO->fileClose(f);
|
|
existing_file = attempt;
|
|
//b3Printf("%s: found '%s'", error_message_prefix.c_str(), attempt.c_str());
|
|
break;
|
|
}
|
|
}
|
|
if (existing_file.empty())
|
|
{
|
|
std::string attempt = fn;
|
|
int f = fileIO->fileOpen(attempt.c_str(), "rb");
|
|
if (f>=0)
|
|
{
|
|
existing_file = attempt;
|
|
fileIO->fileClose(f);
|
|
}
|
|
}
|
|
|
|
if (existing_file.empty())
|
|
{
|
|
b3Warning("%s: cannot find '%s' in any directory in urdf path\n", error_message_prefix.c_str(), fn.c_str());
|
|
return false;
|
|
}
|
|
else
|
|
{
|
|
*out_found_filename = existing_file;
|
|
return true;
|
|
}
|
|
}
|
|
|
|
#endif //URDF_FIND_MESH_FILE_H
|