+
#include <creaImageIOGimmick.h>
#include <creaImageIOSystem.h>
# define PATH_MAX 2048
#endif
+#ifdef _DEBUG
+#define new DEBUG_NEW
+#endif
+
namespace creaImageIO
{
-
-
//==============================================================
Gimmick::Gimmick()
: mImageAdder(0)
{
- RegisterGimmickMessageTypes();
+ RegisterGimmickMessageTypes();
mSettings=0;
mSynchronizer=0;
}
//==============================================================
-
//==============================================================
Gimmick::~Gimmick()
{
if(mSettings!=0)
{
- mSettings->writeSettingsFile();
- delete mSettings;
+ mSettings->writeSettingsFile();
+ delete mSettings;
}
- if(mSynchronizer!=0)
+ if(mSynchronizer!=0)
{
- delete mSynchronizer;
+ delete mSynchronizer;
}
}
//==============================================================
CreateUserSettingsDirectory();
// Sets the current directory to the home dir
mCurrentDirectory = GetHomeDirectory();
- mSynchronizer= new Synchronizer(GetUserSettingsDirectory()+"Shared/gimmick/");
+ mSynchronizer= new Synchronizer(GetUserSettingsDirectory()+"Shared/gimmick/");
- mSettings = new Settings(mCurrentDirectory);
+ mSettings = new Settings(mCurrentDirectory);
-
- std::string dbpath = GetLocalDatabasePath();
+ std::string dbpath = GetLocalDatabasePath();
// Create or open local database
- std::string dpath= mCurrentDirectory + "/.gimmick/Shared/gimmick/localdatabase_Descriptor.dscp";
- boost::algorithm::replace_all( dpath,
- INVALID_FILE_SEPARATOR ,
- VALID_FILE_SEPARATOR);
- mLocalDatabase = createDB(i_nameDB, dpath, dbpath);
+ std::string dpath= mCurrentDirectory + "/.gimmick/Shared/gimmick/localdatabase_Descriptor.dscp";
+ boost::algorithm::replace_all( dpath,
+ INVALID_FILE_SEPARATOR ,
+ VALID_FILE_SEPARATOR);
+ mLocalDatabase = createDB(i_nameDB, dpath, dbpath);
// Add it to the TreeHandlerMap
mTreeHandlerMap[i_nameDB] = mLocalDatabase;
- //Add additional DB from user Settings
- addDBSettings();
-
-
+ //Add additional DB from user Settings
+ addDBSettings();
}
///////////////////////////////////////////////////////////////////////
- // add DB to TreeHandler Map //
- // @param i_name : DB name //
- // @param i_location : DB location //
- // return : - //
- ///////////////////////////////////////////////////////////////////////
- void Gimmick::addDB(const std::string &i_name,
- const std::string &i_location)
+ // add DB to TreeHandler Map //
+ // @param i_name : DB name //
+ // @param i_location : DB location //
+ // return : - //
+ ////////////////////////////////////////////////////////////////////////
+ void Gimmick::addDB(const std::string &i_name,
+ const std::string &i_location)
{
if(mTreeHandlerMap.find(i_name) == mTreeHandlerMap.end())
{
// @param i_locDB : location of DB //
// return : the SQLiteTreeHandler object on DB //
/////////////////////////////////////////////////////////////////////////
- SQLiteTreeHandler *Gimmick::createDB(const std::string &i_name,
+ SQLiteTreeHandler* Gimmick::createDB(const std::string &i_name,
const std::string &i_locDesc,
const std::string &i_locDB)
{
- SQLiteTreeHandler *sqlTreeH = new SQLiteTreeHandler(i_locDB);
+ SQLiteTreeHandler* sqlTreeH( new SQLiteTreeHandler(i_locDB) );
// Create or open local database
if (! boost::filesystem::exists(i_locDB) )
{
// CREATING DB STRUCTURE
sqlTreeH->GetTree().GetDescriptor().createDescriptorfromFile(i_locDesc);
if ( ! sqlTreeH->Create(true) )
- {
- GimmickError("ERROR CREATING '"<<i_locDB<<"'");
+ {
+ GimmickError("ERROR CREATING '"<<i_locDB<<"'");
}
sqlTreeH->SetAttribute(0,"Name",i_name);
}
{
/// Open and test it
GimmickMessage(1,"Opening local database '" <<i_locDB<< "' " << std::endl);
- if ( !sqlTreeH->Open(true) )
+ if ( !sqlTreeH->Open(true) )
{
GimmickError("ERROR OPENING '"<<i_locDB<<"'");
}
- }
- return sqlTreeH;
+ }
+ return sqlTreeH;
}
-
//==============================================================
void Gimmick::Finalize()
{
-
- // delete SQLiteTreeHandler Object
- for( TreeHandlerMapType::const_iterator it = mTreeHandlerMap.begin();
- it!= mTreeHandlerMap.end(); ++it)
- {
- delete it->second;
- }
+ if(mTreeHandlerMap.size() >0)
+ {
+ // delete SQLiteTreeHandler Object
+ for( TreeHandlerMapType::const_iterator it = mTreeHandlerMap.begin();
+ it!= mTreeHandlerMap.end();
+ ++it)
+ {
+ delete it->second;
+ }
+ }
}
//==============================================================
return mLocalDatabasePath;
}
-
//========================================================================
//========================================================================
void Gimmick::CreateUserSettingsDirectory()
{
- if (! boost::filesystem::is_directory( GetUserSettingsDirectory() ) )
+ //JCP settings dir 02/10/2009
+ const std::string settingsdirectory = GetUserSettingsDirectory();
+ bool isdir = boost::filesystem::is_directory( settingsdirectory );
+ if (! isdir )
{
GimmickMessage(1,"Directory '"<<GetUserSettingsDirectory()<<"' "
<< "does not exist : creating it"<<std::endl);
path=path.substr(0,path.size()-1);
path=path.substr(0,path.find_last_of("/"));
//Creating directories
+
+// The following stuff works on Linux, NOT CHECKED on Windows // JPR
+
+#if defined(_WIN32)
path+="/bin/Shared/gimmick/localdatabase_Descriptor.dscp";
- std::cout<<"From: "<<path<<std::endl;
- std::cout<<"To: "<<setDir<<std::endl;
- boost::algorithm::replace_all( path,
+#else
+ path+="/Shared/gimmick/localdatabase_Descriptor.dscp";
+#endif
+ std::cout <<"From: " << path <<std::endl;
+ std::cout <<"To: " << setDir <<std::endl;
+ boost::algorithm::replace_all( path,
INVALID_FILE_SEPARATOR ,
VALID_FILE_SEPARATOR);
boost::filesystem::copy_file(path,setDir);
return i->second;
}
-
-
//========================================================================
/// Add the files to the tree handler
void Gimmick::AddFiles(const std::string& d,
GimmickMessage(2,"Adding files to '"<<d<<"'"<<std::endl);
mImageAdder.SetCurrentDatabase(d);
- mImageAdder.SetTreeHandler(GetTreeHandler(d));
+ mImageAdder.SetTreeHandler(GetTreeHandler(d));
mImageAdder.SetSynchronizer(mSynchronizer);
- mImageAdder.AddFiles(filenames);
-
+ mImageAdder.AddFiles(filenames);
}
//========================================================================
void Gimmick::AddDir(const std::string& d, const std::string& f,
bool recurse)
{
- GimmickMessage(2,"Adding dir '"<<f<<"' to '"<<d<<"' recurse:"
- <<recurse<<std::endl);
+ GimmickMessage(2,"Adding dir '"<<f<<"' to '"<<d<<"' recurse:"
+ <<recurse<<std::endl);
TreeHandler * handler=GetTreeHandler(d);
mImageAdder.SetCurrentDatabase(d);
- mImageAdder.SetTreeHandler(handler);
+ mImageAdder.SetTreeHandler(handler);
mImageAdder.SetSynchronizer(mSynchronizer);
- mImageAdder.AddDirectory(f,recurse);
+ mImageAdder.AddDirectory(f,recurse);
}
//========================================================================
void Gimmick::GetSetting(const std::string& name, std::string& value)
{
- value = mSettings->getValue(name);
+ value = mSettings->getValue(name);
}
//========================================================================
//========================================================================
void Gimmick::GetAttributes(const std::string& d,
- const std::string& filename,
- const std::vector<std::string>& params,
- std::vector<std::string>& results)
+ const std::string& filename,
+ const std::vector<std::string>& params,
+ std::vector<std::string>& results)
{
TreeHandler * handler=GetTreeHandler(d);
mImageAdder.SetCurrentDatabase(d);
void Gimmick::DeleteDrive(const std::string& drive)
{
- for( TreeHandlerMapType::const_iterator it = mTreeHandlerMap.begin();
- it!= mTreeHandlerMap.end(); ++it)
+ for( TreeHandlerMapType::const_iterator it = mTreeHandlerMap.begin();
+ it!= mTreeHandlerMap.end();
+ ++it)
{
mImageAdder.SetTreeHandler(it->second);
mImageAdder.DeleteDriveFromMainDB(drive);
}
- mImageAdder.SetSynchronizer(mSynchronizer);
- mImageAdder.DeleteDriveFromOtherDB(drive);
+ mImageAdder.SetSynchronizer(mSynchronizer);
+ mImageAdder.DeleteDriveFromOtherDB(drive);
}
//========================================================================
void Gimmick::EditField(tree::Node* node, const std::string& d, const std::string& name, const std::string& key, const std::string& val)
{
- TreeHandler * handler=GetTreeHandler(d);
- mImageAdder.SetCurrentDatabase(d);
- mImageAdder.SetTreeHandler(handler);
- mImageAdder.EditField(node,name,key,val);
+ TreeHandler * handler=GetTreeHandler(d);
+ mImageAdder.SetCurrentDatabase(d);
+ mImageAdder.SetTreeHandler(handler);
+ mImageAdder.EditField(node,name,key,val);
}
//========================================================================
-
- /////////////////////////////////////////////////////////////////////////
- // add DB from Settings file //
- // @param : - //
- // return : - //
- /////////////////////////////////////////////////////////////////////////
+ ////////////////////////////////////////////////////////////////////////
+ // add DB from Settings file //
+ // @param : - //
+ // return : - //
+ ////////////////////////////////////////////////////////////////////////
void Gimmick::addDBSettings()
{
std::string name = it_path->substr(pos +1, last_pos -pos-1 );
addDB(name, it_path->c_str());
}
-
- }
-
+ }
}