X3D importer: Fixed path handling
authorPatrick Dähne <pdaehne@gmail.com>
Tue, 11 Jul 2017 17:41:24 +0000 (19:41 +0200)
committerPatrick Dähne <pdaehne@gmail.com>
Tue, 11 Jul 2017 17:41:24 +0000 (19:41 +0200)
code/X3DImporter.cpp [changed mode: 0755->0644]
code/X3DImporter_Networking.cpp

old mode 100755 (executable)
new mode 100644 (file)
index c714532..feaa0ca
@@ -1610,8 +1610,10 @@ void X3DImporter::InternReadFile(const std::string& pFile, aiScene* pScene, IOSy
        mpIOHandler = pIOHandler;
 
        Clear();// delete old graph.
-       pIOHandler->PushDirectory(DefaultIOSystem::absolutePath(pFile));
+       std::string::size_type slashPos = pFile.find_last_of("\\/");
+       pIOHandler->PushDirectory(slashPos == std::string::npos ? std::string() : pFile.substr(0, slashPos + 1));
        ParseFile(pFile, pIOHandler);
+       pIOHandler->PopDirectory();
        //
        // Assimp use static arrays of objects for fast speed of rendering. That's good, but need some additional operations/
        // We know that geometry objects(meshes) are stored in <Shape>, also in <Shape>-><Appearance> materials(in Assimp logical view)
index 9d55900..744d805 100644 (file)
@@ -51,9 +51,13 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 // Header files, Assimp.
 #include <assimp/DefaultIOSystem.h>
 
+#include <regex>
+
 namespace Assimp
 {
 
+static std::regex pattern_parentDir(R"((^|/)[^/]+/../)");
+
 // <Inline
 // DEF=""              ID
 // USE=""              IDREF
@@ -91,9 +95,10 @@ void X3DImporter::ParseNode_Networking_Inline()
                {
                        std::string full_path;
 
-                       full_path = mpIOHandler->CurrentDirectory() + "/" + url.front();
+                       full_path = std::regex_replace(mpIOHandler->CurrentDirectory() + url.front(), pattern_parentDir, "$1");
                        // Attribute "url" can contain list of strings. But we need only one - first.
-                       mpIOHandler->PushDirectory(DefaultIOSystem::absolutePath(full_path));
+                       std::string::size_type slashPos = full_path.find_last_of("\\/");
+                       mpIOHandler->PushDirectory(slashPos == std::string::npos ? std::string() : full_path.substr(0, slashPos + 1));
                        ParseFile(full_path, mpIOHandler);
                        mpIOHandler->PopDirectory();
                }