|
|
@ -26,10 +26,8 @@
|
|
|
|
// std
|
|
|
|
// std
|
|
|
|
#include <string>
|
|
|
|
#include <string>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
using namespace NLMISC;
|
|
|
|
using namespace NLMISC;
|
|
|
|
using namespace std;
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
|
|
|
@ -42,18 +40,24 @@ using namespace std;
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
union TFormId
|
|
|
|
union TFormId
|
|
|
|
{
|
|
|
|
{
|
|
|
|
uint32 Id;
|
|
|
|
uint32 Id;
|
|
|
|
|
|
|
|
|
|
|
|
struct
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
{
|
|
|
|
uint32 Type : 8;
|
|
|
|
uint32 Type : 8;
|
|
|
|
uint32 Id : 24;
|
|
|
|
uint32 Id : 24;
|
|
|
|
} FormIDInfos;
|
|
|
|
} FormIDInfos;
|
|
|
|
|
|
|
|
|
|
|
|
void serial(NLMISC::IStream &f) { f.serial(Id); }
|
|
|
|
void serial(NLMISC::IStream &f)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
f.serial(Id);
|
|
|
|
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
bool operator<(const TFormId& fid1, const TFormId& fid2) { return fid1.Id<fid2.Id; }
|
|
|
|
bool operator<(const TFormId& fid1, const TFormId& fid2)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return fid1.Id<fid2.Id;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
map<string,TFormId> FormToId;
|
|
|
|
map<string,TFormId> FormToId;
|
|
|
@ -86,15 +90,15 @@ bool getFileType( string& fileName, string& fileType );
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
sint16 getFirstFreeFileTypeId()
|
|
|
|
sint16 getFirstFreeFileTypeId()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
for( sint16 id=0; id<256; ++id )
|
|
|
|
for( sint16 id=0; id<256; ++id )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if( IdToFileType.find((uint8)id) == IdToFileType.end() )
|
|
|
|
if( IdToFileType.find((uint8)id) == IdToFileType.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return id;
|
|
|
|
return id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
|
|
|
|
} // getFirstFreeFileTypeId //
|
|
|
|
} // getFirstFreeFileTypeId //
|
|
|
|
|
|
|
|
|
|
|
@ -105,238 +109,232 @@ sint16 getFirstFreeFileTypeId()
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
void readFormId( string& outputFileName )
|
|
|
|
void readFormId( string& outputFileName )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CIFile f;
|
|
|
|
CIFile f;
|
|
|
|
if( f.open( outputFileName ) )
|
|
|
|
if( f.open( outputFileName ) )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
f.serialCont( IdToForm );
|
|
|
|
f.serialCont( IdToForm );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// insert an unknown entry
|
|
|
|
// insert an unknown entry
|
|
|
|
TFormId formId;
|
|
|
|
TFormId formId;
|
|
|
|
formId.Id = 0;
|
|
|
|
formId.Id = 0;
|
|
|
|
IdToForm.insert( make_pair( formId, string("unknown.unknown") ) );
|
|
|
|
IdToForm.insert( make_pair( formId, string("unknown.unknown") ) );
|
|
|
|
|
|
|
|
|
|
|
|
// remove integer file extensions (created by CVS) and init FileTypeToId (associates the form type to the form type id)
|
|
|
|
// remove integer file extensions (created by CVS) and init FileTypeToId (associates the form type to the form type id)
|
|
|
|
map<TFormId,string>::iterator itIF;
|
|
|
|
map<TFormId,string>::iterator itIF;
|
|
|
|
for( itIF = IdToForm.begin(); itIF != IdToForm.end(); )
|
|
|
|
for( itIF = IdToForm.begin(); itIF != IdToForm.end(); )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// get the file type from form name
|
|
|
|
// get the file type from form name
|
|
|
|
TFormId fid = (*itIF).first;
|
|
|
|
TFormId fid = (*itIF).first;
|
|
|
|
string fileType;
|
|
|
|
string fileType;
|
|
|
|
|
|
|
|
|
|
|
|
if((*itIF).second.empty() || (*itIF).second=="." || (*itIF).second==".." || (*itIF).second[0]=='_' || (*itIF).second.find(".#")==0)
|
|
|
|
if((*itIF).second.empty() || (*itIF).second=="." || (*itIF).second==".." || (*itIF).second[0]=='_' || (*itIF).second.find(".#")==0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
map<TFormId,string>::iterator itErase = itIF;
|
|
|
|
map<TFormId,string>::iterator itErase = itIF;
|
|
|
|
++itIF;
|
|
|
|
++itIF;
|
|
|
|
IdToForm.erase(itErase);
|
|
|
|
IdToForm.erase(itErase);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if( getFileType( (*itIF).second, fileType ) )
|
|
|
|
if( getFileType( (*itIF).second, fileType ) )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// insert the association (file type/file type id)
|
|
|
|
// insert the association (file type/file type id)
|
|
|
|
map<string,uint8>::iterator itFT = FileTypeToId.find(fileType);
|
|
|
|
map<string,uint8>::iterator itFT = FileTypeToId.find(fileType);
|
|
|
|
if( itFT == FileTypeToId.end() )
|
|
|
|
if( itFT == FileTypeToId.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FileTypeToId.insert( make_pair(fileType,fid.FormIDInfos.Type) );
|
|
|
|
FileTypeToId.insert( make_pair(fileType,fid.FormIDInfos.Type) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
nlwarning("Unknown file type for the file : %s",(*itIF).second.c_str());
|
|
|
|
nlwarning("Unknown file type for the file : %s",(*itIF).second.c_str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
++itIF;
|
|
|
|
++itIF;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// init FormToId (associates the form name to its id )
|
|
|
|
// init FormToId (associates the form name to its id )
|
|
|
|
for( itIF = IdToForm.begin(); itIF != IdToForm.end(); ++itIF )
|
|
|
|
for( itIF = IdToForm.begin(); itIF != IdToForm.end(); ++itIF )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FormToId.insert( make_pair((*itIF).second,(*itIF).first) );
|
|
|
|
FormToId.insert( make_pair((*itIF).second,(*itIF).first) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// init IdToFileType (associates the form type id to the form type name)
|
|
|
|
// init IdToFileType (associates the form type id to the form type name)
|
|
|
|
map<string,uint8>::iterator itIFT;
|
|
|
|
map<string,uint8>::iterator itIFT;
|
|
|
|
for( itIFT = FileTypeToId.begin(); itIFT != FileTypeToId.end(); ++itIFT )
|
|
|
|
for( itIFT = FileTypeToId.begin(); itIFT != FileTypeToId.end(); ++itIFT )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
IdToFileType.insert( make_pair((*itIFT).second,(*itIFT).first) );
|
|
|
|
IdToFileType.insert( make_pair((*itIFT).second,(*itIFT).first) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// init TypeToLastId (associates the type id to the last index used for this type)
|
|
|
|
// init TypeToLastId (associates the type id to the last index used for this type)
|
|
|
|
for( itIF = IdToForm.begin(); itIF != IdToForm.end(); ++itIF )
|
|
|
|
for( itIF = IdToForm.begin(); itIF != IdToForm.end(); ++itIF )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
uint8 type = (*itIF).first.FormIDInfos.Type;
|
|
|
|
uint8 type = (*itIF).first.FormIDInfos.Type;
|
|
|
|
uint32 id = (*itIF).first.FormIDInfos.Id;
|
|
|
|
uint32 id = (*itIF).first.FormIDInfos.Id;
|
|
|
|
map<uint8,uint32>::iterator itTLI = TypeToLastId.find( type );
|
|
|
|
map<uint8,uint32>::iterator itTLI = TypeToLastId.find( type );
|
|
|
|
if( itTLI != TypeToLastId.end() )
|
|
|
|
if( itTLI != TypeToLastId.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if( (*itTLI).second < id )
|
|
|
|
if( (*itTLI).second < id )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
(*itTLI).second = id;
|
|
|
|
(*itTLI).second = id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
TypeToLastId.insert( make_pair(type,id) );
|
|
|
|
TypeToLastId.insert( make_pair(type,id) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // readFormId //
|
|
|
|
} // readFormId //
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
// makeId
|
|
|
|
// makeId
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
void makeId( list<string>& dirs )
|
|
|
|
void makeId( list<string>& dirs )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
list<string>::const_iterator itDir;
|
|
|
|
list<string>::const_iterator itDir;
|
|
|
|
for( itDir = dirs.begin(); itDir != dirs.end(); ++itDir )
|
|
|
|
for( itDir = dirs.begin(); itDir != dirs.end(); ++itDir )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
nlinfo ("Searching files in directory '%s'...", (*itDir).c_str());
|
|
|
|
nlinfo ("Searching files in directory '%s'...", (*itDir).c_str());
|
|
|
|
vector<string> files;
|
|
|
|
vector<string> files;
|
|
|
|
CPath::getPathContent(*itDir,true,false,true,files);
|
|
|
|
CPath::getPathContent(*itDir,true,false,true,files);
|
|
|
|
|
|
|
|
|
|
|
|
nlinfo ("Found %d files in directory '%s'", files.size(), (*itDir).c_str());
|
|
|
|
nlinfo ("Found %d files in directory '%s'", files.size(), (*itDir).c_str());
|
|
|
|
for(uint i = 0; i < files.size(); i++)
|
|
|
|
for(uint i = 0; i < files.size(); i++)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
addId(CFile::getFilename(files[i]));
|
|
|
|
addId(CFile::getFilename(files[i]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // makeId //
|
|
|
|
} // makeId //
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
// addId
|
|
|
|
// addId
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
void addId( string fileName )
|
|
|
|
void addId( string fileName )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(fileName.empty() || fileName=="." || fileName==".." || fileName[0]=='_' || fileName.find(".#")==0)
|
|
|
|
if(fileName.empty() || fileName=="." || fileName==".." || fileName[0]=='_' || fileName.find(".#")==0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
//nlinfo("Discarding file '%s'", fileName.c_str());
|
|
|
|
//nlinfo("Discarding file '%s'", fileName.c_str());
|
|
|
|
NbFilesDiscarded++;
|
|
|
|
NbFilesDiscarded++;
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if( !ExtensionsAllowed.empty() )
|
|
|
|
if( !ExtensionsAllowed.empty() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
string extStr = CFile::getExtension( fileName );
|
|
|
|
string extStr = CFile::getExtension( fileName );
|
|
|
|
if( ExtensionsAllowed.find(extStr) == ExtensionsAllowed.end() )
|
|
|
|
if( ExtensionsAllowed.find(extStr) == ExtensionsAllowed.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
NbFilesDiscarded++;
|
|
|
|
NbFilesDiscarded++;
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// if the file is new
|
|
|
|
// if the file is new
|
|
|
|
map<string,TFormId>::iterator itFI = FormToId.find( fileName );
|
|
|
|
map<string,TFormId>::iterator itFI = FormToId.find( fileName );
|
|
|
|
if( itFI == FormToId.end() )
|
|
|
|
if( itFI == FormToId.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// double check : if file not found we check with lower case version of filename
|
|
|
|
// double check : if file not found we check with lower case version of filename
|
|
|
|
map<string,TFormId>::iterator itFILwr = FormToId.find( toLower(fileName) );
|
|
|
|
map<string,TFormId>::iterator itFILwr = FormToId.find( toLower(fileName) );
|
|
|
|
if( itFILwr != FormToId.end() )
|
|
|
|
if( itFILwr != FormToId.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
nlwarning("Trying to add %s but the file %s is already known ! becareful with lower case and upper case.", fileName.c_str(), toLower(fileName).c_str());
|
|
|
|
nlwarning("Trying to add %s but the file %s is already known ! becareful with lower case and upper case.", fileName.c_str(), toLower(fileName).c_str());
|
|
|
|
NbFilesDiscarded++;
|
|
|
|
NbFilesDiscarded++;
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
string fileType;
|
|
|
|
string fileType;
|
|
|
|
if( getFileType( fileName, fileType ) )
|
|
|
|
if( getFileType( fileName, fileType ) )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
map<string,uint8>::iterator itFTI = FileTypeToId.find( fileType );
|
|
|
|
map<string,uint8>::iterator itFTI = FileTypeToId.find( fileType );
|
|
|
|
TFormId fid;
|
|
|
|
TFormId fid;
|
|
|
|
|
|
|
|
|
|
|
|
// if the type of this file is a new type
|
|
|
|
// if the type of this file is a new type
|
|
|
|
if( itFTI == FileTypeToId.end() )
|
|
|
|
if( itFTI == FileTypeToId.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
sint16 firstFreeFileTypeId = getFirstFreeFileTypeId();
|
|
|
|
sint16 firstFreeFileTypeId = getFirstFreeFileTypeId();
|
|
|
|
if( firstFreeFileTypeId == -1 )
|
|
|
|
if( firstFreeFileTypeId == -1 )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
nlwarning("MORE THAN 256 FILE TYPES!!!!");
|
|
|
|
nlwarning("MORE THAN 256 FILE TYPES!!!!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FileTypeToId.insert( make_pair(fileType,(uint8)firstFreeFileTypeId) );
|
|
|
|
FileTypeToId.insert( make_pair(fileType,(uint8)firstFreeFileTypeId) );
|
|
|
|
IdToFileType.insert( make_pair((uint8)firstFreeFileTypeId,fileType) );
|
|
|
|
IdToFileType.insert( make_pair((uint8)firstFreeFileTypeId,fileType) );
|
|
|
|
TypeToLastId.insert( make_pair((uint8)firstFreeFileTypeId,0) );
|
|
|
|
TypeToLastId.insert( make_pair((uint8)firstFreeFileTypeId,0) );
|
|
|
|
|
|
|
|
|
|
|
|
fid.FormIDInfos.Type = (uint8)firstFreeFileTypeId;
|
|
|
|
fid.FormIDInfos.Type = (uint8)firstFreeFileTypeId;
|
|
|
|
fid.FormIDInfos.Id = 0;
|
|
|
|
fid.FormIDInfos.Id = 0;
|
|
|
|
|
|
|
|
|
|
|
|
nlinfo("Adding file type '%s' with id %d", fileType.c_str(), firstFreeFileTypeId);
|
|
|
|
nlinfo("Adding file type '%s' with id %d", fileType.c_str(), firstFreeFileTypeId);
|
|
|
|
NbTypesAdded++;
|
|
|
|
NbTypesAdded++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// else the file type already exist
|
|
|
|
// else the file type already exist
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// id of the file type
|
|
|
|
// id of the file type
|
|
|
|
uint8 fileTypeId = (*itFTI).second;
|
|
|
|
uint8 fileTypeId = (*itFTI).second;
|
|
|
|
|
|
|
|
|
|
|
|
// last id used for this file type
|
|
|
|
// last id used for this file type
|
|
|
|
map<uint8,uint32>::iterator itTLI = TypeToLastId.find(fileTypeId);
|
|
|
|
map<uint8,uint32>::iterator itTLI = TypeToLastId.find(fileTypeId);
|
|
|
|
nlassert(itTLI != TypeToLastId.end());
|
|
|
|
nlassert(itTLI != TypeToLastId.end());
|
|
|
|
(*itTLI).second++;
|
|
|
|
(*itTLI).second++;
|
|
|
|
|
|
|
|
|
|
|
|
// add the new association
|
|
|
|
// add the new association
|
|
|
|
fid.FormIDInfos.Type = fileTypeId;
|
|
|
|
fid.FormIDInfos.Type = fileTypeId;
|
|
|
|
fid.FormIDInfos.Id = (*itTLI).second;
|
|
|
|
fid.FormIDInfos.Id = (*itTLI).second;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
FormToId.insert( make_pair(fileName,fid) );
|
|
|
|
FormToId.insert( make_pair(fileName,fid) );
|
|
|
|
IdToForm.insert( make_pair(fid,fileName) );
|
|
|
|
IdToForm.insert( make_pair(fid,fileName) );
|
|
|
|
nlinfo("Adding file '%s' id %d with type '%s' id %d", fileName.c_str(), fid.FormIDInfos.Id, fileType.c_str(), fid.FormIDInfos.Type);
|
|
|
|
nlinfo("Adding file '%s' id %d with type '%s' id %d", fileName.c_str(), fid.FormIDInfos.Id, fileType.c_str(), fid.FormIDInfos.Type);
|
|
|
|
NbFilesAdded++;
|
|
|
|
NbFilesAdded++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
//nlinfo("Unknown file type for the file : '%s' --> not added",fileName.c_str());
|
|
|
|
//nlinfo("Unknown file type for the file : '%s' --> not added",fileName.c_str());
|
|
|
|
NbFilesUnknownType++;
|
|
|
|
NbFilesUnknownType++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
//nlinfo("Skipping file '%s', already in the file", fileName.c_str());
|
|
|
|
//nlinfo("Skipping file '%s', already in the file", fileName.c_str());
|
|
|
|
NbFilesAlreadyAdded++;
|
|
|
|
NbFilesAlreadyAdded++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} // addId //
|
|
|
|
} // addId //
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
// getFileType
|
|
|
|
// getFileType
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
bool getFileType( string& fileName, string& fileType )
|
|
|
|
bool getFileType( string& fileName, string& fileType )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fileType = CFile::getExtension(CFile::getFilename(fileName));
|
|
|
|
fileType = CFile::getExtension(CFile::getFilename(fileName));
|
|
|
|
return !fileType.empty();
|
|
|
|
return !fileType.empty();
|
|
|
|
|
|
|
|
|
|
|
|
} // getFileType //
|
|
|
|
} // getFileType //
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
// display
|
|
|
|
// display
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//-----------------------------------------------
|
|
|
|
//-----------------------------------------------
|
|
|
|
void display()
|
|
|
|
void display()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
nldebug ("Output :");
|
|
|
|
nldebug ("Output :");
|
|
|
|
map<TFormId,string>::iterator it1;
|
|
|
|
map<TFormId,string>::iterator it1;
|
|
|
|
for( it1 = IdToForm.begin(); it1 != IdToForm.end(); ++it1 )
|
|
|
|
for( it1 = IdToForm.begin(); it1 != IdToForm.end(); ++it1 )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
nldebug("type: %d id: %d file: %s", (*it1).first.FormIDInfos.Type, (*it1).first.FormIDInfos.Id, (*it1).second.c_str());
|
|
|
|
nldebug("type: %d id: %d file: %s", (*it1).first.FormIDInfos.Type, (*it1).first.FormIDInfos.Id, (*it1).second.c_str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // display //
|
|
|
|
} // display //
|
|
|
|
|
|
|
|
|
|
|
|