Salome HOME
Issue #1861: Find empty loop body
[modules/shaper.git] / src / Model / Model_Application.cpp
1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
2
3 // File:        Model_Application.cxx
4 // Created:     Fri Sep 2 2011
5 // Author:      Mikhail PONIKAROV
6
7 #include <Model_Application.h>
8 #include <Model_Document.h>
9
10 #include <ModelAPI_Events.h>
11
12 #ifdef OCAFBROWSER
13 #include <DFBrowserAPI_PluginMgr.h>
14 #include <DFBrowserAPI_Communicator.h>
15
16 static bool FirstCall = true;
17 #endif
18
19 IMPLEMENT_STANDARD_HANDLE(Model_Application, TDocStd_Application)
20 IMPLEMENT_STANDARD_RTTIEXT(Model_Application, TDocStd_Application)
21
22 using namespace std;
23
24 static Handle_Model_Application TheApplication = new Model_Application;
25
26 //=======================================================================
27 Handle(Model_Application) Model_Application::getApplication()
28 {
29 #ifdef OCAFBROWSER
30     if (FirstCall) {
31       DFBrowserAPI_PluginMgr::activateBrowser("OCAFBrowser.dll", TheApplication);
32       FirstCall = false;
33     }
34 #endif
35   return TheApplication;
36 }
37
38 //=======================================================================
39 std::shared_ptr<Model_Document> Model_Application::document(const int theDocID)
40 {
41   if (myDocs.find(theDocID) != myDocs.end())
42     return myDocs[theDocID];
43   return std::shared_ptr<Model_Document>(); // not loaded, so return null
44 }
45
46 //=======================================================================
47 void Model_Application::createDocument(const int theDocID)
48 {
49   static const std::string thePartSetKind("PartSet");
50   static const std::string thePartKind("Part");
51   std::shared_ptr<Model_Document> aNew(
52     new Model_Document(theDocID, theDocID == 0 ? thePartSetKind : thePartKind));
53   myDocs[theDocID] = aNew;
54
55   aNew->setThis(aNew);
56   static Events_ID anId = ModelAPI_DocumentCreatedMessage::eventId();
57   std::shared_ptr<ModelAPI_DocumentCreatedMessage> aMessage = std::shared_ptr
58     <ModelAPI_DocumentCreatedMessage>(new ModelAPI_DocumentCreatedMessage(anId, this));
59   aMessage->setDocument(aNew);
60   Events_Loop::loop()->send(aMessage);
61 }
62
63 //=======================================================================
64 bool Model_Application::loadDocument(const std::string theDocName, const int theDocID)
65 {
66   static const std::string thePartKind("Part"); // root document is never loaded here
67   std::shared_ptr<Model_Document> aNew(new Model_Document(theDocID, thePartKind));
68   myDocs[theDocID] = aNew;
69
70   bool aRes = true;
71   // load it if it must be loaded by demand
72   if (myLoadedByDemand.find(theDocName) != myLoadedByDemand.end() && !myPath.empty()) {
73     aRes = aNew->load(myPath.c_str(), theDocName.c_str(), aNew);
74     myLoadedByDemand.erase(theDocName);  // done, don't do it anymore
75   } else { // error
76     aRes = false;
77   }
78
79   return aRes;
80 }
81
82 //=======================================================================
83 void Model_Application::deleteDocument(const int theDocID)
84 {
85   if (myDocs.find(theDocID) != myDocs.end()) {
86     myDocs[theDocID]->close(true);
87     myDocs.erase(theDocID);
88   }
89   myLoadedByDemand.clear();
90 }
91
92 //=======================================================================
93 void Model_Application::deleteAllDocuments()
94 {
95   std::map<int, std::shared_ptr<Model_Document> >::iterator aDoc = myDocs.begin();
96   for(; aDoc != myDocs.end(); aDoc++) {
97     if (aDoc->second->isOpened()) // here is main document was closed before subs and closed subs
98       aDoc->second->close(true);
99   }
100   myDocs.clear();
101   myLoadedByDemand.clear();
102 }
103
104 //=======================================================================
105 bool Model_Application::hasDocument(const int theDocID)
106 {
107   return myDocs.find(theDocID) != myDocs.end();
108 }
109
110 //=======================================================================
111 bool Model_Application::hasRoot()
112 {
113   return !myDocs.empty();
114 }
115
116 //=======================================================================
117 std::shared_ptr<Model_Document> Model_Application::rootDocument()
118 {
119   return myDocs[0];
120 }
121
122 //=======================================================================
123 void Model_Application::setLoadPath(std::string thePath)
124 {
125   myPath = thePath;
126 }
127
128 //=======================================================================
129 const std::string& Model_Application::loadPath() const
130 {
131   return myPath;
132 }
133
134 //=======================================================================
135 void Model_Application::setLoadByDemand(std::string theID)
136 {
137   myLoadedByDemand.insert(theID);
138 }
139
140 //=======================================================================
141 bool Model_Application::isLoadByDemand(std::string theID)
142 {
143   return myLoadedByDemand.find(theID) != myLoadedByDemand.end();
144 }
145
146 //=======================================================================
147 void Model_Application::removeUselessDocuments(
148   std::list<std::shared_ptr<ModelAPI_Document> > theUsedDocs)
149 {
150   std::map<int, std::shared_ptr<Model_Document> >::iterator aDoc = myDocs.begin();
151   while(aDoc != myDocs.end()) {
152     bool aFound = false;
153     std::list<std::shared_ptr<ModelAPI_Document> >::iterator aUsed = theUsedDocs.begin();
154     for(; !aFound && aUsed != theUsedDocs.end(); aUsed++) {
155       aFound = aDoc->second == *aUsed;
156     }
157     if (!aFound) { // remove the useless
158       aDoc->second->close();
159       myDocs.erase(aDoc);
160       aDoc = myDocs.begin();
161     } else {
162       aDoc++;
163     }
164   }
165 }
166
167 int Model_Application::generateDocumentId()
168 {
169   int aResult = int(myDocs.size());
170   for(; myDocs.find(aResult) != myDocs.end(); aResult++) {} // count until the result id is unique
171   return aResult;
172 }
173
174 //=======================================================================
175 Model_Application::Model_Application()
176 {
177   // store handle to the application to avoid nullification
178   static Handle(Model_Application) TheKeepHandle;
179   TheKeepHandle = this;
180 }
181
182 //=======================================================================
183 void Model_Application::Formats(TColStd_SequenceOfExtendedString& theFormats)
184 {
185   theFormats.Append(TCollection_ExtendedString("BinOcaf"));  // standard binary schema
186 }
187
188 //=======================================================================
189 Standard_CString Model_Application::ResourcesName()
190 {
191   return Standard_CString("Standard");
192 }