Fixed reading loose mpd files referenced by another file.

This commit is contained in:
Leonardo Zide 2016-09-25 17:15:30 -07:00
parent cde1334e0b
commit 5d86d5ac98
6 changed files with 101 additions and 13 deletions

View file

@ -921,10 +921,8 @@ bool lcPiecesLibrary::LoadPiece(PieceInfo* Info)
if (!Loaded && !mCurrentModelPath.isEmpty()) if (!Loaded && !mCurrentModelPath.isEmpty())
{ {
QFileInfo FileInfo(QDir(mCurrentModelPath), Info->m_strName); lcMemFile PieceFile;
if (LoadAndInlineFile(Info->m_strName, PieceFile))
lcDiskFile PieceFile;
if (PieceFile.Open(FileInfo.absoluteFilePath().toLatin1().constData(), "rt")) // todo: qstring
{ {
const char* OldLocale = setlocale(LC_NUMERIC, "C"); const char* OldLocale = setlocale(LC_NUMERIC, "C");
Loaded = ReadMeshData(PieceFile, lcMatrix44Identity(), 16, TextureStack, MeshData, LC_MESHDATA_SHARED, false); Loaded = ReadMeshData(PieceFile, lcMatrix44Identity(), 16, TextureStack, MeshData, LC_MESHDATA_SHARED, false);
@ -1408,6 +1406,32 @@ bool lcPiecesLibrary::LoadPrimitive(int PrimitiveIndex)
return true; return true;
} }
bool lcPiecesLibrary::LoadAndInlineFile(const char* FileName, lcMemFile& File)
{
QFileInfo FileInfo(QDir(mCurrentModelPath), FileName);
if (!FileInfo.isFile())
return false;
Project TempProject;
if (!TempProject.Load(FileInfo.absoluteFilePath()))
return false;
TempProject.InlineAllModels();
QByteArray Data;
QTextStream Stream(&Data);
TempProject.Save(Stream);
Stream.flush();
File.Seek(0, SEEK_SET);
File.WriteBuffer(Data.constData(), Data.size());
File.Seek(0, SEEK_SET);
return true;
}
bool lcPiecesLibrary::ReadMeshData(lcFile& File, const lcMatrix44& CurrentTransform, lcuint32 CurrentColorCode, lcArray<lcLibraryTextureMap>& TextureStack, lcLibraryMeshData& MeshData, lcMeshDataType MeshDataType, bool Optimize) bool lcPiecesLibrary::ReadMeshData(lcFile& File, const lcMatrix44& CurrentTransform, lcuint32 CurrentColorCode, lcArray<lcLibraryTextureMap>& TextureStack, lcLibraryMeshData& MeshData, lcMeshDataType MeshDataType, bool Optimize)
{ {
char Buffer[1024]; char Buffer[1024];
@ -1667,7 +1691,7 @@ bool lcPiecesLibrary::ReadMeshData(lcFile& File, const lcMatrix44& CurrentTransf
if (strcmp(Info->m_strName, FileName)) if (strcmp(Info->m_strName, FileName))
continue; continue;
if (mZipFiles[LC_ZIPFILE_OFFICIAL]) if (mZipFiles[LC_ZIPFILE_OFFICIAL] && Info->mZipFileType != LC_NUM_ZIPFILES)
{ {
lcMemFile IncludeFile; lcMemFile IncludeFile;
@ -1693,13 +1717,11 @@ bool lcPiecesLibrary::ReadMeshData(lcFile& File, const lcMatrix44& CurrentTransf
if (!Loaded && !mCurrentModelPath.isEmpty()) if (!Loaded && !mCurrentModelPath.isEmpty())
{ {
QFileInfo FileInfo(QDir(mCurrentModelPath), OriginalFileName); lcMemFile IncludeFile;
if (LoadAndInlineFile(OriginalFileName, IncludeFile))
lcDiskFile IncludeFile;
if (IncludeFile.Open(FileInfo.absoluteFilePath().toLatin1().constData(), "rt")) // todo: qstring
{ {
const char* OldLocale = setlocale(LC_NUMERIC, "C"); const char* OldLocale = setlocale(LC_NUMERIC, "C");
Loaded = ReadMeshData(IncludeFile, IncludeTransform, ColorCode, TextureStack, MeshData, MeshDataType, Optimize); Loaded = ReadMeshData(File, IncludeTransform, ColorCode, TextureStack, MeshData, MeshDataType, Optimize);
setlocale(LC_NUMERIC, OldLocale); setlocale(LC_NUMERIC, OldLocale);
} }
} }

View file

@ -186,6 +186,7 @@ protected:
int FindPrimitiveIndex(const char* Name) const; int FindPrimitiveIndex(const char* Name) const;
bool LoadPrimitive(int PrimitiveIndex); bool LoadPrimitive(int PrimitiveIndex);
bool LoadAndInlineFile(const char* FileName, lcMemFile& File);
QString mCachePath; QString mCachePath;
QString mCurrentModelPath; QString mCurrentModelPath;

View file

@ -2180,6 +2180,50 @@ void lcModel::MoveSelectionToModel(lcModel* Model)
ClearSelectionAndSetFocus(ModelPiece, LC_PIECE_SECTION_POSITION); ClearSelectionAndSetFocus(ModelPiece, LC_PIECE_SECTION_POSITION);
} }
void lcModel::InlineAllModels()
{
for (;;)
{
bool Inlined = false;
for (int PieceIdx = 0; PieceIdx < mPieces.GetSize(); )
{
lcPiece* Piece = mPieces[PieceIdx];
if (!Piece->mPieceInfo->IsModel())
{
PieceIdx++;
continue;
}
mPieces.RemoveIndex(PieceIdx);
lcArray<lcModelPartsEntry> ModelParts;
Piece->mPieceInfo->GetModelParts(Piece->mModelWorld, Piece->mColorIndex, ModelParts);
for (int InsertIdx = 0; InsertIdx < ModelParts.GetSize(); InsertIdx++)
{
lcModelPartsEntry& Entry = ModelParts[InsertIdx];
lcPiece* NewPiece = new lcPiece(Entry.Info);
NewPiece->Initialize(Entry.WorldMatrix, Piece->GetStepShow());
NewPiece->SetColorIndex(Entry.ColorIndex);
NewPiece->UpdatePosition(mCurrentStep);
InsertPiece(NewPiece, PieceIdx);
PieceIdx++;
}
delete Piece;
Inlined = true;
}
if (!Inlined)
break;
}
}
void lcModel::InlineSelectedModels() void lcModel::InlineSelectedModels()
{ {
lcArray<lcObject*> NewPieces; lcArray<lcObject*> NewPieces;

View file

@ -188,6 +188,7 @@ public:
void SetPieceSteps(const QList<QPair<lcPiece*, lcStep>>& PieceSteps); void SetPieceSteps(const QList<QPair<lcPiece*, lcStep>>& PieceSteps);
void MoveSelectionToModel(lcModel* Model); void MoveSelectionToModel(lcModel* Model);
void InlineAllModels();
void InlineSelectedModels(); void InlineSelectedModels();
lcGroup* AddGroup(const QString& Prefix, lcGroup* Parent); lcGroup* AddGroup(const QString& Prefix, lcGroup* Parent);

View file

@ -326,6 +326,16 @@ bool Project::Save(const QString& FileName)
lcGetPiecesLibrary()->SetCurrentModelPath(QFileInfo(FileName).absolutePath()); lcGetPiecesLibrary()->SetCurrentModelPath(QFileInfo(FileName).absolutePath());
QTextStream Stream(&File); QTextStream Stream(&File);
bool Success = Save(Stream);
mFileName = FileName;
mModified = false;
return Success;
}
bool Project::Save(QTextStream& Stream)
{
bool MPD = mModels.GetSize() > 1; bool MPD = mModels.GetSize() > 1;
for (int ModelIdx = 0; ModelIdx < mModels.GetSize(); ModelIdx++) for (int ModelIdx = 0; ModelIdx < mModels.GetSize(); ModelIdx++)
@ -342,9 +352,6 @@ bool Project::Save(const QString& FileName)
Stream << QLatin1String("0 NOFILE\r\n"); Stream << QLatin1String("0 NOFILE\r\n");
} }
mFileName = FileName;
mModified = false;
return true; return true;
} }
@ -381,6 +388,16 @@ void Project::Merge(Project* Other)
mModified = true; mModified = true;
} }
void Project::InlineAllModels()
{
mModels[0]->InlineAllModels();
for (int ModelIdx = 1; ModelIdx < mModels.GetSize(); ModelIdx++)
delete mModels[ModelIdx];
mModels.SetSize(1);
}
void Project::GetModelParts(lcArray<lcModelPartsEntry>& ModelParts) void Project::GetModelParts(lcArray<lcModelPartsEntry>& ModelParts)
{ {
if (mModels.IsEmpty()) if (mModels.IsEmpty())

View file

@ -55,8 +55,11 @@ public:
lcModel* CreateNewModel(bool ShowModel); lcModel* CreateNewModel(bool ShowModel);
QString GetNewModelName(QWidget* ParentWidget, const QString& DialogTitle, const QString& CurrentName, const QStringList& ExistingModels) const; QString GetNewModelName(QWidget* ParentWidget, const QString& DialogTitle, const QString& CurrentName, const QStringList& ExistingModels) const;
void ShowModelListDialog(); void ShowModelListDialog();
void InlineAllModels();
bool Load(const QString& FileName); bool Load(const QString& FileName);
bool Save(const QString& FileName); bool Save(const QString& FileName);
bool Save(QTextStream& Stream);
void Merge(Project* Other); void Merge(Project* Other);
void SaveImage(); void SaveImage();