#include "HYDROGUI_DataModel.h"
-#include "HYDROGUI_Module.h"
#include "HYDROGUI_DataObject.h"
+#include "HYDROGUI_Module.h"
+#include "HYDROGUI_Tool.h"
#include <HYDROData_Document.h>
#include <HYDROData_Image.h>
#include <HYDROData_Iterator.h>
+#include <HYDROData_Polyline.h>
#include <CAM_Application.h>
#include <CAM_DataObject.h>
#include <HYDROData_Document.h>
+#include <TDF_Delta.hxx>
+#include <TDF_ListIteratorOfDeltaList.hxx>
+
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;
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 )
if( !anImageObj.IsNull() )
createObject( anImageRootObj, anImageObj );
}
+
+ LightApp_DataObject* aPolylineRootObj = createObject( aRootObj, "POLYLINES" );
+
+ HYDROData_Iterator aPolyIterator( aDocument, KIND_POLYLINE );
+ for( ; aPolyIterator.More(); aPolyIterator.Next() )
+ {
+ Handle(HYDROData_Polyline) aPolylineObj =
+ Handle(HYDROData_Polyline)::DownCast( aPolyIterator.Current() );
+ if( !aPolylineObj.IsNull() )
+ createObject( aPolylineRootObj, aPolylineObj );
+ }
+
+ if( SUIT_DataBrowser* anObjectBrowser = anApp->objectBrowser() )
+ {
+ anObjectBrowser->setAutoOpenLevel( 3 );
+ anObjectBrowser->openLevels();
+ }
}
HYDROGUI_DataObject* HYDROGUI_DataModel::getDataObject( const Handle(HYDROData_Object)& theModelObject )
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 )
+{
+ 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 anEntry = HYDROGUI_DataObject::dataObjectEntry( anObject );
+ if( anEntry == theEntry )
+ 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 )
{