#include "HYDROGUI_DataModel.h"
-#include "HYDROGUI_Module.h"
#include "HYDROGUI_DataObject.h"
+#include "HYDROGUI_Module.h"
+#include "HYDROGUI_Tool.h"
+#include <HYDROData_Bathymetry.h>
#include <HYDROData_Document.h>
#include <HYDROData_Image.h>
#include <HYDROData_Iterator.h>
+#include <HYDROData_Polyline.h>
+#include <HYDROData_VisualState.h>
#include <CAM_Application.h>
#include <CAM_DataObject.h>
#include <HYDROData_Document.h>
+#include <TDF_Delta.hxx>
+#include <TDF_ListIteratorOfDeltaList.hxx>
+
+#include <QApplication>
+#include <QDir>
+
HYDROGUI_DataModel::HYDROGUI_DataModel( CAM_Module* theModule )
: LightApp_DataModel( theModule )
{
LightApp_DataModel::open( theURL, theStudy, theFileList );
const int aStudyId = theStudy->id();
- bool res = false;
+ Data_DocError res = DocError_UnknownProblem;
if( theFileList.count() == 2 )
{
QString aTmpDir = theFileList[0];
}
catch(...)
{
- res = false;
+ res = DocError_UnknownProblem;
}
- if (!res)
+ if( res != DocError_OK )
{
module()->application()->putInfo( tr( "LOAD_ERROR" ) );
return false;
// if the document open was successful, the data model update happens
// in the set mode of the module
- if( !res )
+ if( res == DocError_OK )
update( aStudyId );
return true;
bool HYDROGUI_DataModel::save( QStringList& theFileList )
{
- if (!module()->application()->activeStudy())
+ if( !module()->application()->activeStudy() )
return false;
- const int aStudyId = module()->application()->activeStudy()->id();
-
LightApp_DataModel::save( theFileList );
QString aTmpDir;
// save data to temporary files
LightApp_Study* aStudy = dynamic_cast<LightApp_Study*>( module()->application()->activeStudy() );
aTmpDir = aStudy->GetTmpDir( myStudyURL.toLatin1().constData(), isMultiFile ).c_str();
- aFileName = SUIT_Tools::file (myStudyURL, false ) + "_HYDRO.cbf";
+ aFileName = SUIT_Tools::file( myStudyURL, false ) + "_HYDRO.cbf";
QString aFullPath = aTmpDir + aFileName;
- bool res = HYDROData_Document::Document( aStudyId )->Save( (char*)aFullPath.toLatin1().constData() );
- if( !res )
+ Data_DocError res = getDocument()->Save( (char*)aFullPath.toLatin1().constData() );
+ if( res != DocError_OK )
{
module()->application()->putInfo( tr( "SAVE_ERROR" ) );
return false;
return true;
}
+bool HYDROGUI_DataModel::dumpPython( const QString& theURL,
+ CAM_Study* theStudy,
+ bool isMultiFile,
+ QStringList& theListOfFiles )
+{
+ LightApp_DataModel::dumpPython( theURL, theStudy, isMultiFile, theListOfFiles );
+
+ int aStudyId = theStudy->id();
+
+ LightApp_Study* aStudy = ::qobject_cast<LightApp_Study*>( theStudy );
+ Handle(HYDROData_Document) aDocument = HYDROData_Document::Document( aStudyId );
+ if ( aDocument.IsNull() || !aStudy )
+ return false;
+
+ QString aFileToExport = aStudy->GetTmpDir( theURL.toLatin1().constData(), isMultiFile ).c_str();
+ aFileToExport += QString( QDir::separator() ) + "HYDRO.py";
+
+ bool aRes = aDocument->DumpToPython( aFileToExport );
+
+ if ( aRes )
+ {
+ theListOfFiles.append( aFileToExport );
+ }
+
+ return aRes;
+}
+
bool HYDROGUI_DataModel::isModified() const
{
- int aStudyID = module()->application()->activeStudy()->id();
- return HYDROData_Document::Document( aStudyID )->IsModified();
+ return getDocument()->IsModified();
}
bool HYDROGUI_DataModel::isSaved() const
if( !aStudyRoot )
return;
- if( SUIT_DataBrowser* anObjectBrowser = anApp->objectBrowser() )
- anObjectBrowser->setAutoOpenLevel( 3 );
-
// create root object if not exist
CAM_DataObject* aRootObj = root();
if( !aRootObj )
Handle(HYDROData_Image) anImageObj =
Handle(HYDROData_Image)::DownCast( anIterator.Current() );
if( !anImageObj.IsNull() )
- createObject( anImageRootObj, anImageObj );
+ {
+ if( LightApp_DataObject* anImageDataObj = createObject( anImageRootObj, anImageObj ) )
+ {
+ for( int anIndex = 0, aNbRef = anImageObj->NbReferences(); anIndex < aNbRef; anIndex++ )
+ {
+ Handle(HYDROData_Image) aRefImageObj = anImageObj->Reference( anIndex );
+ if( !aRefImageObj.IsNull() && !aRefImageObj->IsRemoved() )
+ createObject( anImageDataObj, aRefImageObj, anImageDataObj->entry() );
+ }
+ }
+ }
+ }
+
+ LightApp_DataObject* aBathymetryRootObj = createObject( aRootObj, "BATHYMETRIES" );
+
+ anIterator = HYDROData_Iterator( aDocument, KIND_BATHYMETRY );
+ for( ; anIterator.More(); anIterator.Next() )
+ {
+ Handle(HYDROData_Bathymetry) aBathymetryObj =
+ Handle(HYDROData_Bathymetry)::DownCast( anIterator.Current() );
+ if( !aBathymetryObj.IsNull() )
+ createObject( aBathymetryRootObj, aBathymetryObj );
+ }
+
+ LightApp_DataObject* aPolylineRootObj = createObject( aRootObj, "POLYLINES" );
+
+ anIterator = HYDROData_Iterator( aDocument, KIND_POLYLINE );
+ for( ; anIterator.More(); anIterator.Next() )
+ {
+ Handle(HYDROData_Polyline) aPolylineObj =
+ Handle(HYDROData_Polyline)::DownCast( anIterator.Current() );
+ if( !aPolylineObj.IsNull() )
+ createObject( aPolylineRootObj, aPolylineObj );
+ }
+
+ LightApp_DataObject* aVisualStateRootObj = createObject( aRootObj, "VISUAL_STATES" );
+
+ anIterator = HYDROData_Iterator( aDocument, KIND_VISUAL_STATE );
+ for( ; anIterator.More(); anIterator.Next() )
+ {
+ Handle(HYDROData_VisualState) aVisualStateObj =
+ Handle(HYDROData_VisualState)::DownCast( anIterator.Current() );
+ if( !aVisualStateObj.IsNull() )
+ createObject( aVisualStateRootObj, aVisualStateObj );
+ }
+
+ if( SUIT_DataBrowser* anObjectBrowser = anApp->objectBrowser() )
+ {
+ anObjectBrowser->setAutoOpenLevel( 3 );
+ anObjectBrowser->openLevels();
}
}
SUIT_DataObject* HYDROGUI_DataModel::findObject( const QString& theEntry ) const
{
- SUIT_DataObject* anObject = HYDROGUI_DataObject::objectByEntry( theEntry );
- if( !anObject )
- {
- LightApp_Application* anApp = dynamic_cast<LightApp_Application*>( module()->application() );
- anObject = anApp ? anApp->findObject( theEntry ) : 0;
- }
- return anObject;
+ LightApp_Application* anApp = dynamic_cast<LightApp_Application*>( module()->application() );
+ return anApp ? anApp->findObject( theEntry ) : 0;
}
void HYDROGUI_DataModel::update( LightApp_DataObject* theObject,
update( aModule->getStudyId() );
}
+Handle(HYDROData_Object) HYDROGUI_DataModel::objectByEntry( const QString& theEntry,
+ const ObjectKind theObjectKind )
+{
+ QString anEntry = theEntry;
+ if( anEntry.indexOf( "_" ) != -1 ) // reference object
+ anEntry = anEntry.section( "_", -1 );
+
+ Handle(HYDROData_Document) aDocument = getDocument();
+ if( !aDocument.IsNull() )
+ {
+ HYDROData_Iterator anIterator( aDocument, theObjectKind );
+ for( ; anIterator.More(); anIterator.Next() )
+ {
+ Handle(HYDROData_Object) anObject = anIterator.Current();
+ if( !anObject.IsNull() )
+ {
+ QString anEntryRef = HYDROGUI_DataObject::dataObjectEntry( anObject );
+ if( anEntryRef == anEntry )
+ return anObject;
+ }
+ }
+ }
+ return NULL;
+}
+
+bool HYDROGUI_DataModel::canUndo() const
+{
+ return getDocument()->CanUndo();
+}
+
+bool HYDROGUI_DataModel::canRedo() const
+{
+ return getDocument()->CanRedo();
+}
+
+QStringList HYDROGUI_DataModel::undoNames() const
+{
+ QStringList aNames;
+ for( TDF_ListIteratorOfDeltaList anIter( getDocument()->GetUndos() ); anIter.More(); anIter.Next() )
+ aNames.prepend( HYDROGUI_Tool::ToQString( anIter.Value()->Name() ) );
+ return aNames;
+}
+
+QStringList HYDROGUI_DataModel::redoNames() const
+{
+ QStringList aNames;
+ for( TDF_ListIteratorOfDeltaList anIter( getDocument()->GetRedos() ); anIter.More(); anIter.Next() )
+ aNames.append( HYDROGUI_Tool::ToQString( anIter.Value()->Name() ) );
+ return aNames;
+}
+
+void HYDROGUI_DataModel::clearUndos()
+{
+ getDocument()->ClearUndos();
+}
+
+void HYDROGUI_DataModel::clearRedos()
+{
+ getDocument()->ClearRedos();
+}
+
+bool HYDROGUI_DataModel::undo()
+{
+ try
+ {
+ getDocument()->Undo();
+ }
+ catch ( Standard_Failure )
+ {
+ return false;
+ }
+ return true;
+}
+
+bool HYDROGUI_DataModel::redo()
+{
+ try
+ {
+ getDocument()->Redo();
+ }
+ catch ( Standard_Failure )
+ {
+ return false;
+ }
+ return true;
+}
+
+Handle(HYDROData_Document) HYDROGUI_DataModel::getDocument() const
+{
+ int aStudyId = module()->application()->activeStudy()->id();
+ return HYDROData_Document::Document( aStudyId );
+}
+
LightApp_DataObject* HYDROGUI_DataModel::createObject( SUIT_DataObject* theParent,
- Handle(HYDROData_Object) theModelObject )
+ Handle(HYDROData_Object) theModelObject,
+ const QString& theParentEntry )
{
- return new HYDROGUI_DataObject( theParent, theModelObject );
+ return new HYDROGUI_DataObject( theParent, theModelObject, theParentEntry );
}
LightApp_DataObject* HYDROGUI_DataModel::createObject( SUIT_DataObject* theParent,