1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-16 18:29:55 +00:00

Adding files to directory map

This commit is contained in:
Jason Hooks 2011-06-05 23:46:18 -04:00
parent 2aaa0f4578
commit f2a0fa8af2
3 changed files with 57 additions and 4 deletions

View file

@ -118,7 +118,7 @@ namespace MWClass
Ogre::Vector3 pos2 = Ogre::Vector3( 0, .5, 75); Ogre::Vector3 pos2 = Ogre::Vector3( 0, .5, 75);
if (groin){ if (groin){
cellRender.insertMesh("Meshes\\bald_MJ_hat.NIF"); //w/W_6th_Hammer.NIF cellRender.insertMesh("Meshes\\joker\\bald_MJ_hat.nif"); //w/W_6th_Hammer.NIF
//bald_MJ_hat.NIF //bald_MJ_hat.NIF
cellRender.insertMesh("meshes\\" + groin->model, pos2, axis, kOgrePi, npcName + "groin", addresses, numbers); cellRender.insertMesh("meshes\\" + groin->model, pos2, axis, kOgrePi, npcName + "groin", addresses, numbers);
addresses2[numbers] = npcName + "groin"; addresses2[numbers] = npcName + "groin";

View file

@ -36,12 +36,42 @@ using namespace Mangle::Stream;
/// An OGRE Archive wrapping a BSAFile archive /// An OGRE Archive wrapping a BSAFile archive
class DirArchive: public Ogre::FileSystemArchive class DirArchive: public Ogre::FileSystemArchive
{ {
//FileSystemArchive* arc;
boost::filesystem::path currentdir;
std::map<std::string, std::vector<std::string> > m;
public: public:
DirArchive(const String& name) DirArchive(const String& name)
: FileSystemArchive(name, "Dir") : FileSystemArchive(name, "Dir")
{ mType = "Dir";} { mType = "Dir";
currentdir = name;
populateMap(currentdir);
}
void populateMap(boost::filesystem::path d){
//need to cut off first
boost::filesystem::directory_iterator dir_iter(d), dir_end;
std::vector<std::string> filesind;
boost::filesystem::path f;
for(;dir_iter != dir_end; dir_iter++)
{
if(boost::filesystem::is_directory(*dir_iter))
populateMap(*dir_iter);
else
{
f = *dir_iter;
std::string s = f.string();
filesind.push_back(s);
//std::cout << "File: " << s << "\n";
}
}
m[d.string()] = filesind;
std::cout << "Directory: " << d.string() << filesind.size() << "\n";
}
bool isCaseSensitive() const { return false; } bool isCaseSensitive() const { return false; }
@ -50,6 +80,11 @@ class DirArchive: public Ogre::FileSystemArchive
void unload() {} void unload() {}
bool exists(const String& filename) { bool exists(const String& filename) {
//String s = filename;
//FileSystemArchive::findFiles(s, true, false, filenames.getPointer(), f.getPointer());
// std::cout << "Filenames" << filenames.useCount() << "\n";
std::string copy = filename; std::string copy = filename;
if(OGRE_PLATFORM != OGRE_PLATFORM_WIN32) if(OGRE_PLATFORM != OGRE_PLATFORM_WIN32)
{ {
@ -61,6 +96,23 @@ class DirArchive: public Ogre::FileSystemArchive
} }
} }
} }
boost::filesystem::path p = copy;
int last = copy.size() - 1;
int i = last;
for (;last >= 0; i--)
{
if(copy.at(i) == '/' || copy.at(i) == '\\')
break;
}
std::string folder;
folder = copy.substr(0, i);
boost::filesystem::path folderpath = folder;
std::cout << "\nFull:" << p.string() << "\n"<< "Part:" << folderpath.string();
return FileSystemArchive::exists(copy); return FileSystemArchive::exists(copy);
} }
@ -227,7 +279,7 @@ static void insertDirFactory()
if(!init2) if(!init2)
{ {
ArchiveManager::getSingleton().addArchiveFactory( new DirArchiveFactory ); ArchiveManager::getSingleton().addArchiveFactory( new DirArchiveFactory );
init = true; init2 = true;
} }
} }

View file

@ -22,6 +22,7 @@
*/ */
#include <string> #include <string>
#include <boost/filesystem.hpp>
#ifndef _BSA_ARCHIVE_H_ #ifndef _BSA_ARCHIVE_H_
#define _BSA_ARCHIVE_H_ #define _BSA_ARCHIVE_H_