Core.cc 48.1 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
/*===========================================================================*\
 *                                                                           *
 *                              OpenFlipper                                  *
 *      Copyright (C) 2001-2009 by Computer Graphics Group, RWTH Aachen      *
 *                           www.openflipper.org                             *
 *                                                                           *
 *---------------------------------------------------------------------------*
 *  This file is part of OpenFlipper.                                        *
 *                                                                           *
 *  OpenFlipper is free software: you can redistribute it and/or modify      *
 *  it under the terms of the GNU Lesser General Public License as           *
 *  published by the Free Software Foundation, either version 3 of           *
 *  the License, or (at your option) any later version with the              *
 *  following exceptions:                                                    *
 *                                                                           *
 *  If other files instantiate templates or use macros                       *
 *  or inline functions from this file, or you compile this file and         *
 *  link it with other files to produce an executable, this file does        *
 *  not by itself cause the resulting executable to be covered by the        *
 *  GNU Lesser General Public License. This exception does not however       *
 *  invalidate any other reasons why the executable file might be            *
 *  covered by the GNU Lesser General Public License.                        *
 *                                                                           *
 *  OpenFlipper is distributed in the hope that it will be useful,           *
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of           *
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the            *
 *  GNU Lesser General Public License for more details.                      *
 *                                                                           *
 *  You should have received a copy of the GNU LesserGeneral Public          *
 *  License along with OpenFlipper. If not,                                  *
 *  see <http://www.gnu.org/licenses/>.                                      *
 *                                                                           *
\*===========================================================================*/

/*===========================================================================*\
 *                                                                           *
 *   $Revision$                                                         *
 *   $Author$                                                      *
 *   $Date$                   *
 *                                                                           *
\*===========================================================================*/
Jan Möbius's avatar
 
Jan Möbius committed
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59





//=============================================================================
//
//  CLASS Core - IMPLEMENTATION
//
//=============================================================================


//== INCLUDES =================================================================

// -------------------- mview
#include "Core.hh"
// -------------------- ACG
#include <ACG/Scenegraph/DrawModes.hh>
60
#include <ACG/Scenegraph/SceneGraph.hh>
Jan Möbius's avatar
 
Jan Möbius committed
61
62
63
64
65
66
67
68
69
70
71
72

#include <ACG/QtWidgets/QtFileDialog.hh>
// -------------------- Qt

#include <QKeyEvent>
#include <QSplitter>
#include <QMenuBar>
#include <QToolBox>
#include <QApplication>
#include <QStatusBar>
#include <QMessageBox>
#include <QFile>
Jan Möbius's avatar
Dennis:    
Jan Möbius committed
73
#include <QSettings>
Jan Möbius's avatar
 
Jan Möbius committed
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97

#include <QPluginLoader>
#include "OpenFlipper/BasePlugin/BaseInterface.hh"
#include "OpenFlipper/BasePlugin/KeyInterface.hh"
#include "OpenFlipper/BasePlugin/MouseInterface.hh"
#include "OpenFlipper/BasePlugin/PickingInterface.hh"
#include "OpenFlipper/BasePlugin/ToolboxInterface.hh"
#include "OpenFlipper/BasePlugin/TextureInterface.hh"
#include "OpenFlipper/BasePlugin/MenuInterface.hh"
#include "OpenFlipper/BasePlugin/INIInterface.hh"
#include "OpenFlipper/BasePlugin/GlobalAccessInterface.hh"

#include "OpenFlipper/INIFile/INIFile.hh"

#include "OpenFlipper/common/GlobalOptions.hh"
#include <OpenFlipper/common/RecentFiles.hh>
#include <OpenFlipper/ACGHelper/DrawModeConverter.hh>

#include <QStringList>
#include <QtScript/QScriptValueIterator>

#include <ACG/Scenegraph/SeparatorNode.hh>

#include "OpenFlipper/BasePlugin/PluginFunctions.hh"
Jan Möbius's avatar
   
Jan Möbius committed
98
#include "OpenFlipper/BasePlugin/PluginFunctionsCore.hh"
Jan Möbius's avatar
 
Jan Möbius committed
99

Jan Möbius's avatar
Jan Möbius committed
100
101
#include "OpenFlipper/BasePlugin/RPCWrappers.hh"

Jan Möbius's avatar
 
Jan Möbius committed
102
103
104
105
106
#include <OpenMesh/Core/System/omstream.hh>

#define WIDGET_HEIGHT 800
#define WIDGET_WIDTH  800

107
//== IMPLEMENTATION ==========================================================
Jan Möbius's avatar
 
Jan Möbius committed
108
109

/** \brief Constuctor for the Core Widget ( This is stage 1 , call init for stage 2)
110
 *
Jan Möbius's avatar
 
Jan Möbius committed
111
112
113
114
115
116
117
118
119
 * Initialization is working the following way:\n
 * - Setup basic paths \n
 * - Get Options from Option files ( While skipping the OpenFiles Sections as Core is not running )\n
 * - Jump back ( Stage two is done by calling init from main ) so CALL init!!
 * - This Two stage system allows using commandline options which override Option Files
*/
Core::
Core() :
  QObject(),
120
  capture_(false),
Jan Möbius's avatar
 
Jan Möbius committed
121
122
123
  nextBackupId_(0),
  coreWidget_(0)
{
Dirk Wilden's avatar
Dirk Wilden committed
124
125
126
127
128
  //init logFile
  logStream_ = 0;
  logFile_ = 0;
  OpenFlipper::Options::logFileEnabled(true);

Dirk Wilden's avatar
Dirk Wilden committed
129
130
131
  //init nodes
  root_node_scenegraph_ = new ACG::SceneGraph::SeparatorNode(0, "SceneGraph Root Node");
  root_node_ = new ACG::SceneGraph::SeparatorNode(root_node_scenegraph_, "Data Root Node");
132
133
  coordsysMaterialNode_ = new ACG::SceneGraph::MaterialNode(root_node_scenegraph_,"Coordsys Material Node");
  coordsysNode_ = new ACG::SceneGraph::CoordsysNode(coordsysMaterialNode_,"Core Coordsys Node");
Jan Möbius's avatar
Dennis:    
Jan Möbius committed
134
  coordsysNode_->setTraverseMode (BaseNode::NodeFirst | BaseNode::SecondPass);
135
136
  gridNode_ = new ACG::SceneGraph::GridNode(root_node_scenegraph_,"Grid Node");
  gridNode_->hide();
Dirk Wilden's avatar
Dirk Wilden committed
137

Jan Möbius's avatar
 
Jan Möbius committed
138
139
140
141
142
   // Add ViewMode All
  ViewMode* vm = new ViewMode();
  vm->name = "All";
  vm->custom = false;
  vm->visibleWidgets = QStringList();
143

Jan Möbius's avatar
 
Jan Möbius committed
144
145
  viewModes_.push_front(vm);

Dirk Wilden's avatar
Dirk Wilden committed
146
147
148
  //init ViewerProperties (always for 4 Viewers!)
  std::vector< Viewer::ViewerProperties* > viewerProperties;

149
150
151
152
153
  for (int i=0; i < 4; i++) {
    Viewer::ViewerProperties* viewerProperty = new Viewer::ViewerProperties();
    viewerProperty->snapshotBaseFileName("snap-Viewer-" + QString::number(i) + ".png");
    viewerProperties.push_back( viewerProperty );
  }
Dirk Wilden's avatar
Dirk Wilden committed
154
155
156

  PluginFunctions::setViewerProperties(viewerProperties);

157
158
159
160
161
162
163
164
165
166
  //set viewer defaults
  OpenFlipper::Options::defaultProjectionMode( 1, 0 );
  OpenFlipper::Options::defaultProjectionMode( 0, 1 );
  OpenFlipper::Options::defaultProjectionMode( 0, 2 );
  OpenFlipper::Options::defaultProjectionMode( 0, 3 );
  OpenFlipper::Options::defaultViewingDirection( PluginFunctions::VIEW_FREE,  0 );
  OpenFlipper::Options::defaultViewingDirection( PluginFunctions::VIEW_TOP,   1 );
  OpenFlipper::Options::defaultViewingDirection( PluginFunctions::VIEW_LEFT,  2 );
  OpenFlipper::Options::defaultViewingDirection( PluginFunctions::VIEW_FRONT, 3 );

Jan Möbius's avatar
 
Jan Möbius committed
167
168
  // Get all relevant Paths and Options from option files
  setupOptions();
Jan Möbius's avatar
Jan Möbius committed
169

170
171
  // set discriptions for scriptable slots
  setDescriptions();
Jan Möbius's avatar
 
Jan Möbius committed
172
173
}

174
175
176
/** \brief Second initialization stage
 *
 * This Stage does the following :\n
Jan Möbius's avatar
 
Jan Möbius committed
177
178
179
180
181
182
 * - Create the Core GUI Elements (Examiner, Toolbox,...)\n
 * - Create the MenuBar \n
 * - load the Plugins \n
 * - connect the Mouse slots \n
 * - Load all ini files (This includes the Global Option files) \n
 */
183
184
185
void
Core::init() {

Jan Möbius's avatar
 
Jan Möbius committed
186
  // Make root_node available to the plugins ( defined in PluginFunctions.hh)
Jan Möbius's avatar
   
Jan Möbius committed
187
  PluginFunctions::setRootNode( root_node_ );
188

Jan Möbius's avatar
   
Jan Möbius committed
189
  PluginFunctions::setSceneGraphRootNode( root_node_scenegraph_ );
Dirk Wilden's avatar
Dirk Wilden committed
190

Jan Möbius's avatar
 
Jan Möbius committed
191
  // Initialize the first object as the root Object for the object tree
192
  objectRoot_ =  dynamic_cast< BaseObject* > ( new GroupObject("ObjectRoot") );
Jan Möbius's avatar
 
Jan Möbius committed
193
194
  PluginFunctions::setDataRoot( objectRoot_ );

195

Jan Möbius's avatar
 
Jan Möbius committed
196
  if ( OpenFlipper::Options::gui() ) {
197

Jan Möbius's avatar
Jan Möbius committed
198
    // Initialize redraw timer. Will be used to restrict the rendering framerate.
199
200
201
202
    redrawTimer_ = new QTimer();
    redrawTimer_->setSingleShot(true);
    connect(redrawTimer_, SIGNAL(timeout()), this, SLOT(updateView()),Qt::DirectConnection);

203
204
205
206
207
208
209
210
    // Initialice scenegraph check timer. Will be used to check for changes in the scenegraph
    scenegraphCheckTimer_ = new QTimer();
    scenegraphCheckTimer_->setSingleShot(false);
    connect(scenegraphCheckTimer_, SIGNAL(timeout()), this, SLOT(checkScenegraphDirty()),Qt::DirectConnection);

    // Will measure the time between redraws
    redrawTime_ = new QTime();
    redrawTime_->start ();
211

Jan Möbius's avatar
 
Jan Möbius committed
212
213
    if ( OpenFlipper::Options::splash() ) {
      QPixmap splashPixmap(OpenFlipper::Options::iconDirStr() + OpenFlipper::Options::dirSeparator() + "splash.png");
214

Jan Möbius's avatar
 
Jan Möbius committed
215
216
      splash_ = new QSplashScreen(splashPixmap);
      splash_->show();
217

218
      splash_->showMessage(tr("Initializing mainwindow") ,
Jan Möbius's avatar
 
Jan Möbius committed
219
220
221
                          Qt::AlignBottom | Qt::AlignLeft , Qt::white);
      QApplication::processEvents();
    }
222

Dirk Wilden's avatar
Dirk Wilden committed
223
    coreWidget_ = new CoreWidget(viewModes_ , plugins, coreSlots_);
224

Jan Möbius's avatar
 
Jan Möbius committed
225
    connect(coreWidget_, SIGNAL(clearAll())           , this, SLOT(clearAll()));
226
    connect(coreWidget_, SIGNAL(loadMenu())           , this, SLOT(loadObject()));
Jan Möbius's avatar
 
Jan Möbius committed
227
    connect(coreWidget_, SIGNAL(addEmptyObjectMenu()) , this, SLOT(slotAddEmptyObjectMenu()));
228
229
230
231
    connect(coreWidget_, SIGNAL(saveMenu())           , this, SLOT(saveAllObjects()));
    connect(coreWidget_, SIGNAL(saveToMenu())         , this, SLOT(saveAllObjectsTo()));
    connect(coreWidget_, SIGNAL(loadIniMenu())        , this, SLOT(loadSettings()));
    connect(coreWidget_, SIGNAL(saveIniMenu())        , this, SLOT(saveSettings()));
232
    connect(coreWidget_, SIGNAL(applyOptions())       , this, SLOT(applyOptions()));
Dirk Wilden's avatar
Dirk Wilden committed
233
    connect(coreWidget_, SIGNAL(saveOptions())        , this, SLOT(saveOptions()));
Jan Möbius's avatar
 
Jan Möbius committed
234
235
    connect(coreWidget_, SIGNAL(recentOpen(QAction*)) , this, SLOT(slotRecentOpen(QAction*)));
    connect(coreWidget_, SIGNAL(exit())               , this, SLOT(slotExit()));
236

237
238
239

    connect( coreWidget_, SIGNAL( resizeViewers(int,int) ), this, SLOT( resizeViewers(int,int) ) );
    connect( coreWidget_, SIGNAL( resizeApplication(int,int) ), this, SLOT( resizeApplication(int,int) ) );
Dirk Wilden's avatar
Dirk Wilden committed
240
241
    connect( coreWidget_, SIGNAL( stopVideoCapture() ), this, SLOT( stopVideoCapture() ) );
    connect( coreWidget_, SIGNAL( startVideoCapture(QString,int,bool) ), this, SLOT( startVideoCapture(QString,int,bool) ) );
242

Dirk Wilden's avatar
Dirk Wilden committed
243
    connect(coreWidget_, SIGNAL(showPlugins())       , this, SLOT(slotShowPlugins()));
244

Dirk Wilden's avatar
Dirk Wilden committed
245
246
    connect(coreWidget_, SIGNAL(call(QString,bool&)), this, SLOT(slotCall(QString,bool&)));

Jan Möbius's avatar
Jan Möbius committed
247
248
249
250
251
252
253
254
255
256
257
258
    QRect rect = QApplication::desktop()->screenGeometry();

    uint width = rect.width();
    if ( width > 1000 ) {
      width = 1000;
    }

    uint height = rect.height();
    if ( height > 1000 ) {
      height = 1000;
    }

Jan Möbius's avatar
Jan Möbius committed
259
260
261
#ifdef ARCH_DARWIN
    width = rect.width() - 300;
    height = rect.height() - 150;
Jan Möbius's avatar
Jan Möbius committed
262

Jan Möbius's avatar
Jan Möbius committed
263
//     coreWidget_->setMaximumSize( width, height  );
Jan Möbius's avatar
Jan Möbius committed
264
265
#endif

Jan Möbius's avatar
Jan Möbius committed
266
    coreWidget_->resize(width,height);
267
268
269

    coreWidget_->setWindowTitle( OpenFlipper::Options::windowTitle() );

Jan Möbius's avatar
 
Jan Möbius committed
270
  }
271

Jan Möbius's avatar
 
Jan Möbius committed
272
273
274
275
  // ======================================================================
  // Create intermediate logger class for Core which will mangle the output
  // ======================================================================
  PluginLogger* newlog = new PluginLogger("Core");
276

Jan Möbius's avatar
 
Jan Möbius committed
277
278
  loggers_.push_back(newlog);
  connect(this,SIGNAL(log(Logtype, QString )),newlog,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
279
280
  connect(this,SIGNAL(log(QString )),newlog,SLOT(slotLog(QString )),Qt::DirectConnection);

Jan Möbius's avatar
 
Jan Möbius committed
281
282
283
  // Connect it to the Master logger
  if ( OpenFlipper::Options::gui() )
    connect(newlog,SIGNAL(log(Logtype, QString )),coreWidget_,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
284

Jan Möbius's avatar
 
Jan Möbius committed
285
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
Dirk Wilden's avatar
Dirk Wilden committed
286

Dirk Wilden's avatar
Dirk Wilden committed
287
288
  // connection to file logger
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLogToFile(Logtype, QString )),Qt::DirectConnection);
Dirk Wilden's avatar
Dirk Wilden committed
289
290
291
292
293
294
295

  // ======================================================================
  // Create a logger class for CoreWidget
  // ======================================================================

  if ( OpenFlipper::Options::gui() ){
    PluginLogger* widgetlog = new PluginLogger("CoreWidget");
296

Dirk Wilden's avatar
Dirk Wilden committed
297
298
    loggers_.push_back(widgetlog);
    connect(coreWidget_,SIGNAL(log(Logtype, QString )),widgetlog,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
299
300
    connect(coreWidget_,SIGNAL(log(QString )),widgetlog,SLOT(slotLog(QString )),Qt::DirectConnection);

Dirk Wilden's avatar
Dirk Wilden committed
301
302
303
    // Connect it to the Master logger
    connect(widgetlog,SIGNAL(log(Logtype, QString )),coreWidget_,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
    connect(widgetlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
Dirk Wilden's avatar
Dirk Wilden committed
304
305
    // connection to file logger
    connect(widgetlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLogToFile(Logtype, QString )),Qt::DirectConnection);
Dirk Wilden's avatar
Dirk Wilden committed
306
  }
307

Jan Möbius's avatar
 
Jan Möbius committed
308
309
310
311
312
313
  // ======================================================================
  // Catch OpenMesh Error logs with an own Logger
  // ======================================================================
  newlog = new PluginLogger("Core ( OpenMesh )",LOGERR);
  omerr().connect(*newlog);
  omerr().disconnect(std::cerr);
314

Jan Möbius's avatar
 
Jan Möbius committed
315
  loggers_.push_back(newlog);
316

Jan Möbius's avatar
 
Jan Möbius committed
317
318
319
  // Connect it to the Master logger
  if ( OpenFlipper::Options::gui() )
    connect(newlog,SIGNAL(log(Logtype, QString )),coreWidget_,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
320

Jan Möbius's avatar
 
Jan Möbius committed
321
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
Dirk Wilden's avatar
Dirk Wilden committed
322
323
  // connection to file logger
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLogToFile(Logtype, QString )),Qt::DirectConnection);
324

Jan Möbius's avatar
 
Jan Möbius committed
325
326
327
328
329
330
  // ======================================================================
  // Catch OpenMesh omout logs with an own Logger
  // ======================================================================
  newlog = new PluginLogger("Core ( OpenMesh )",LOGINFO);
  omout().connect(*newlog);
  omout().disconnect(std::cout);
331

Jan Möbius's avatar
 
Jan Möbius committed
332
  loggers_.push_back(newlog);
333

Jan Möbius's avatar
 
Jan Möbius committed
334
335
336
  // Connect it to the Master logger
  if ( OpenFlipper::Options::gui() )
    connect(newlog,SIGNAL(log(Logtype, QString )),coreWidget_,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
337

Jan Möbius's avatar
 
Jan Möbius committed
338
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
Dirk Wilden's avatar
Dirk Wilden committed
339
340
  // connection to file logger
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLogToFile(Logtype, QString )),Qt::DirectConnection);
341

Jan Möbius's avatar
 
Jan Möbius committed
342
343
344
345
346
  // ======================================================================
  // Catch OpenMesh omlog logs with an own Logger
  // ======================================================================
  newlog = new PluginLogger("Core ( OpenMesh )",LOGOUT);
  omlog().connect(*newlog);
347

Jan Möbius's avatar
 
Jan Möbius committed
348
  loggers_.push_back(newlog);
349

Jan Möbius's avatar
 
Jan Möbius committed
350
351
352
  // Connect it to the Master logger
  if ( OpenFlipper::Options::gui() )
    connect(newlog,SIGNAL(log(Logtype, QString )),coreWidget_,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
353

Jan Möbius's avatar
 
Jan Möbius committed
354
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
Dirk Wilden's avatar
Dirk Wilden committed
355
356
  // connection to file logger
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLogToFile(Logtype, QString )),Qt::DirectConnection);
357

Jan Möbius's avatar
 
Jan Möbius committed
358
359
360
361
  // ======================================================================
  // Log Scripting stuff through a separate logger
  // ======================================================================
  newlog = new PluginLogger("Scripting",LOGOUT);
362

Jan Möbius's avatar
 
Jan Möbius committed
363
  loggers_.push_back(newlog);
364

Jan Möbius's avatar
 
Jan Möbius committed
365
366
367
  // Connect it to the Master logger
  if ( OpenFlipper::Options::gui() )
    connect(newlog,SIGNAL(log(Logtype, QString )),coreWidget_,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
368

Jan Möbius's avatar
 
Jan Möbius committed
369
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLog(Logtype, QString )),Qt::DirectConnection);
Dirk Wilden's avatar
Dirk Wilden committed
370
  // connection to file logger
371
  connect(newlog,SIGNAL(log(Logtype, QString )),this,SLOT(slotLogToFile(Logtype, QString )),Qt::DirectConnection);
Dirk Wilden's avatar
Dirk Wilden committed
372

Jan Möbius's avatar
 
Jan Möbius committed
373
  // connect signal to logger
374
375
  connect(this,SIGNAL(scriptLog(QString )),newlog,SLOT(slotLog(QString )),Qt::DirectConnection);

Jan Möbius's avatar
 
Jan Möbius committed
376
377
378
379
380
  // ======================================================================
  // This connection will tell the plugins, when their Toolbox is active
  // ======================================================================
  ///@todo reimplement
//   connect(module_list,SIGNAL(currentChanged(int)),this,SLOT(slotToolboxSwitched(int)));
381

Jan Möbius's avatar
Jan Möbius committed
382
383
384
  // Set a reference to the scriptengine for simple rpc calls
  RPC::setScriptEngine(&scriptEngine_);

Jan Möbius's avatar
 
Jan Möbius committed
385
386
  // process Events every 500 msecs during script execution
  scriptEngine_.setProcessEventsInterval( 500 );
387

Jan Möbius's avatar
 
Jan Möbius committed
388
389
390
391
  // Register own print function :
  QScriptValue printFunction = scriptEngine_.newFunction(myPrintFunction);
  printFunction.setProperty("textedit",scriptEngine_.newQObject(this));
  scriptEngine_.globalObject().setProperty("print", printFunction);
392

Jan Möbius's avatar
 
Jan Möbius committed
393
  // Register Vector Type to ScriptEngine ( is Vec3d )
394
395
  qScriptRegisterMetaType(&scriptEngine_,
                          toScriptValueVector,
Jan Möbius's avatar
 
Jan Möbius committed
396
397
                          fromScriptValueVector,
                          scriptEngine_.newQObject(&vec3dPrototype_));
398

Jan Möbius's avatar
 
Jan Möbius committed
399
400
401
  // set a constructor to allow creation via Vector(x,y,z)
  QScriptValue ctor = scriptEngine_.newFunction(createVector);
  scriptEngine_.globalObject().setProperty("Vector", ctor);
402
403


Jan Möbius's avatar
 
Jan Möbius committed
404
//    // Register ObjectId Type to ScriptEngine ( is int )
405
406
//   qScriptRegisterMetaType(&scriptEngine_,
//                           toScriptValueObjectId,
Jan Möbius's avatar
 
Jan Möbius committed
407
//                           fromScriptValueObjectId);
408
//
Jan Möbius's avatar
 
Jan Möbius committed
409
410
411
//   // set a constructor to allow creation via Vector(x,y,z)
//   ctor = scriptEngine_.newFunction(createObjectId);
//   scriptEngine_.globalObject().setProperty("ObjectId", ctor);
412
413


Jan Möbius's avatar
 
Jan Möbius committed
414
415
416
417
  // Register idList Type to scripting Engine
  qScriptRegisterSequenceMetaType< idList >(&scriptEngine_);

  qScriptRegisterSequenceMetaType< QVector< int > >(&scriptEngine_);
418
419


Jan Möbius's avatar
 
Jan Möbius committed
420
  // Register Matrix Type to scripting Engine ( is ACG::Matrix4x4d )
421
422
  qScriptRegisterMetaType(&scriptEngine_,
                          toScriptValueMatrix4x4 ,
Jan Möbius's avatar
 
Jan Möbius committed
423
424
                          fromScriptValueMatrix4x4,
                          scriptEngine_.newQObject(&matrix4x4Prototype_));
425

Jan Möbius's avatar
 
Jan Möbius committed
426
427
428
  // set a constructor to allow creation via Matrix(x,y,z)
  QScriptValue matrix4x4ctor = scriptEngine_.newFunction(createMatrix4x4);
  scriptEngine_.globalObject().setProperty("Matrix4x4", matrix4x4ctor);
429

Jan Möbius's avatar
 
Jan Möbius committed
430
431
432
433
434
435
436
  // Collect Core scripting information
  QScriptValue scriptInstance = scriptEngine_.newQObject(this,
                                                         QScriptEngine::QtOwnership,
                                                         QScriptEngine::ExcludeChildObjects |
                                                         QScriptEngine::ExcludeSuperClassMethods |
                                                         QScriptEngine::ExcludeSuperClassProperties
                                                         );
437

Jan Möbius's avatar
 
Jan Möbius committed
438
  scriptEngine_.globalObject().setProperty("core", scriptInstance);
439
  emit log(LOGOUT,tr("Core Scripting initialized with Name : core  "));
440

441
  emit log(LOGOUT,tr("Available scripting functions :"));
442

Jan Möbius's avatar
 
Jan Möbius committed
443
444
445
  QScriptValueIterator it(scriptInstance);
  while (it.hasNext()) {
    it.next();
446

Jan Möbius's avatar
 
Jan Möbius committed
447
448
449
    /// Skip all signals for function calls
    if ( checkSignal( this, it.name().toAscii() ) )
      continue;
450

Jan Möbius's avatar
 
Jan Möbius committed
451
    scriptingFunctions_.push_back( "core." + it.name() );
452

Jan Möbius's avatar
 
Jan Möbius committed
453
454
    emit log(LOGOUT,"\t" + it.name());
  }
455

Jan Möbius's avatar
 
Jan Möbius committed
456
  emit log(LOGOUT,"=============================================================================================");
457

Jan Möbius's avatar
 
Jan Möbius committed
458
  loadPlugins();
459

Jan Möbius's avatar
 
Jan Möbius committed
460
  if ( OpenFlipper::Options::gui() ) {
461

Dirk Wilden's avatar
Dirk Wilden committed
462
463
464
    //register keyBinding for all scripting slots
    coreWidget_->slotRegisterSlotKeyBindings();

465
466
467
    //get keyAssignments from config files
    restoreKeyBindings();

468
    if ( OpenFlipper::Options::defaultToolboxMode( ) != "" )
Jan Möbius's avatar
 
Jan Möbius committed
469
470
471
      coreWidget_->setViewMode( OpenFlipper::Options::defaultToolboxMode() );
    else
      coreWidget_->setViewMode("All");
472

Jan Möbius's avatar
Jan Möbius committed
473
474
475
476
477
478
479
    for ( uint i = 0 ; i < OpenFlipper::Options::examinerWidgets(); ++i ) {
      connect( coreWidget_->examiner_widgets_[i], SIGNAL(signalMouseEvent(QMouseEvent*)),
              this                              , SLOT(slotMouseEvent(QMouseEvent*)));
      connect( coreWidget_->examiner_widgets_[i], SIGNAL(signalMouseEventIdentify(QMouseEvent*)),
              this                              , SLOT(slotMouseEventIdentify(QMouseEvent*)));
      connect( coreWidget_->examiner_widgets_[i], SIGNAL(signalWheelEvent(QWheelEvent *, const std::string &)),
              this                              , SLOT(slotWheelEvent(QWheelEvent *, const std::string &)));
Jan Möbius's avatar
Jan Möbius committed
480
481

      connect( coreWidget_->examiner_widgets_[i], SIGNAL( viewUpdated() ),
482
               this, SLOT( viewUpdated()) ,Qt::DirectConnection);
Jan Möbius's avatar
Jan Möbius committed
483
    }
484

Jan Möbius's avatar
 
Jan Möbius committed
485
  }
486

Jan Möbius's avatar
Jan Möbius committed
487
488
489
490
  // ===============================================================================================
  // Load Settings from configuration files
  // ===============================================================================================

Jan Möbius's avatar
 
Jan Möbius committed
491
492
  QStringList optionFiles = OpenFlipper::Options::optionFiles();
  for ( int i = 0 ; i < (int)optionFiles.size(); ++i) {
493

Jan Möbius's avatar
 
Jan Möbius committed
494
    if ( OpenFlipper::Options::gui() && OpenFlipper::Options::splash() ) {
495
      splash_->showMessage(tr("Loading Configuration File ") + QString::number(i) + "/"  + QString::number(optionFiles.size()) ,
Jan Möbius's avatar
 
Jan Möbius committed
496
497
498
                           Qt::AlignBottom | Qt::AlignLeft , Qt::white);
      QApplication::processEvents();
    }
499

Jan Möbius's avatar
Jan Möbius committed
500
501
    // Load global ini files. Use only plugin global options from these files as the
    // rest has been loaded at the beginning.
502
503
504
505
    readRecentFiles( optionFiles[i] );
    if ( OpenFlipper::Options::gui() )
      coreWidget_->updateRecent();

Jan Möbius's avatar
Jan Möbius committed
506
    openIniFile( optionFiles[i] ,false,true,false);
Jan Möbius's avatar
 
Jan Möbius committed
507
508
  }

Jan Möbius's avatar
Jan Möbius committed
509
510
511
  // ===============================================================================================
  // Load Settings from configuration files
  // ===============================================================================================
512

Jan Möbius's avatar
 
Jan Möbius committed
513
  if ( OpenFlipper::Options::lang().contains("UTF") || OpenFlipper::Options::lang().contains("utf") ) {
514
    emit log(LOGWARN,tr("UTF8-Locale used!"));
Jan Möbius's avatar
Jan Möbius committed
515
516
517
518
//     emit log(LOGWARN,"Only OFF files are fully supported with UTF8. Others might fail.");
//     emit log(LOGWARN,"You can change your locale by :");
//     emit log(LOGWARN,"export LANG=C");
//     emit log(LOGWARN,"Work is in progress to resolve this issue.");
519
  }
Jan Möbius's avatar
 
Jan Möbius committed
520
521

  if ( OpenFlipper::Options::gui() ) {
Dirk Wilden's avatar
Dirk Wilden committed
522

Jan Möbius's avatar
Dennis:    
Jan Möbius committed
523
524
    QSettings windowStates(QDir::home().absolutePath() + OpenFlipper::Options::dirSeparator() + ".OpenFlipper" +
                           OpenFlipper::Options::dirSeparator() +  "WindowStates.dat", QSettings::IniFormat);
Dirk Wilden's avatar
Dirk Wilden committed
525

Jan Möbius's avatar
Dennis:    
Jan Möbius committed
526
527
    //try to restore the windowState
    coreWidget_->restoreState (windowStates.value("Core/Window/State").toByteArray ());
Dirk Wilden's avatar
Dirk Wilden committed
528
    //try to restore the geometry
Jan Möbius's avatar
Dennis:    
Jan Möbius committed
529
    coreWidget_->restoreGeometry (windowStates.value("Core/Window/Geometry").toByteArray ());
530

Jan Möbius's avatar
Dennis:    
Jan Möbius committed
531
532
    coreWidget_->toolSplitter_->restoreState (windowStates.value("Core/ToolSplitter").toByteArray ());
    coreWidget_->splitter_->restoreState (windowStates.value("Core/LogSplitter").toByteArray ());
Dirk Wilden's avatar
Dirk Wilden committed
533

Jan Möbius's avatar
 
Jan Möbius committed
534
    coreWidget_->show();
535

536
537
    applyOptions();

Jan Möbius's avatar
Dennis:    
Jan Möbius committed
538
539
540
541
542
543
544
    windowStates.beginGroup ("Core");
    windowStates.beginGroup ("LogSlider");
    coreWidget_->slidingLogger_->restoreState (windowStates);
    windowStates.endGroup ();
    coreWidget_->toolBox_->restoreState (windowStates);
    windowStates.endGroup ();

Jan Möbius's avatar
 
Jan Möbius committed
545
546
547
    if ( OpenFlipper::Options::splash() ) {
      splash_->finish(coreWidget_);
    }
548

549
550
551
    // start checking for scenegraph changes
    scenegraphCheckTimer_->setInterval (1000 / OpenFlipper::Options::maxFrameRate());
    scenegraphCheckTimer_->start ();
Jan Möbius's avatar
 
Jan Möbius committed
552
  }
553

Jan Möbius's avatar
Jan Möbius committed
554
555

  QTimer::singleShot(100, this, SLOT(slotExecuteAfterStartup()));
Jan Möbius's avatar
 
Jan Möbius committed
556
557
}

558

Jan Möbius's avatar
 
Jan Möbius committed
559
560
561
562
563
564
//-----------------------------------------------------------------------------

Core::~Core()
{
   for ( uint i = 0 ; i < plugins.size() ; ++i ){
     BaseInterface* basePlugin = qobject_cast< BaseInterface * >(plugins[i].plugin);
565

Jan Möbius's avatar
 
Jan Möbius committed
566
567
568
569
570
     // Dont call exit if we cannot get the Plugin
     if ( basePlugin )
       if ( checkSlot( plugins[i].plugin , "exit()" ) )
          QMetaObject::invokeMethod(plugins[i].plugin, "exit",  Qt::DirectConnection);
  }
571

Jan Möbius's avatar
 
Jan Möbius committed
572
573
  objectRoot_->deleteSubtree();
  delete objectRoot_;
574

Jan Möbius's avatar
 
Jan Möbius committed
575
  // Clean up loggers
576
577
578
  for ( uint i = 0 ; i < loggers_.size(); ++i )
    delete loggers_[i];

Jan Möbius's avatar
 
Jan Möbius committed
579
580
581
582
583
584
585
}

//-----------------------------------------------------------------------------

void
Core::slotMouseEventIdentify( QMouseEvent* _event )
{
Dirk Wilden's avatar
Dirk Wilden committed
586
587
588
//   // Dont do anything as a context Menu will popup on right button click
//   if ( _event->button() == Qt::RightButton )
//     return;
589

Jan Möbius's avatar
Jan Möbius committed
590
591
592
593
594
595
596
597
598
  const QObject* senderPointer = sender();
  unsigned int examinerId = 0;

  if ( senderPointer == 0 ) {
    std::cerr << "Error : slotMouseEventIdentify directly called! This should only be called by an examiner" << std::endl;
  } else {
    for ( unsigned int i = 0 ; i < OpenFlipper::Options::examinerWidgets(); ++i ) {
      if ( senderPointer == coreWidget_->examiner_widgets_[i] ) {
        examinerId = i;
599
        if ( OpenFlipper::Options::doSlotDebugging() )
600
              emit log(LOGINFO,tr("slotMouseEventIdentify from examiner ") + QString::number(i) );
Jan Möbius's avatar
Jan Möbius committed
601
602
603
604
605
606
607
608
        break;
      }
    }

  }

  PluginFunctions::setActiveExaminer( examinerId );

Jan Möbius's avatar
 
Jan Möbius committed
609
  emit PluginMouseEventIdentify( _event );
Jan Möbius's avatar
Jan Möbius committed
610
611


Jan Möbius's avatar
 
Jan Möbius committed
612
613
614
615
616
617
618
619
}

//-----------------------------------------------------------------------------


void
Core::slotMouseEvent( QMouseEvent* _event )
{
Dirk Wilden's avatar
Dirk Wilden committed
620
621
622
//   // Dont do anything as a context Menu will popup on right button click
//   if ( _event->button() == Qt::RightButton )
//     return;
623

Jan Möbius's avatar
Jan Möbius committed
624
625
626
627
628
629
630
631
632
  const QObject* senderPointer = sender();
  unsigned int examinerId = 0;

  if ( senderPointer == 0 ) {
    std::cerr << "Error : slotMouseEvent directly called! This should only be called by an examiner" << std::endl;
  } else {
    for ( unsigned int i = 0 ; i < OpenFlipper::Options::examinerWidgets(); ++i ) {
      if ( senderPointer == coreWidget_->examiner_widgets_[i] ) {
        examinerId = i;
633
        if ( OpenFlipper::Options::doSlotDebugging() ) {
634
          QString message = tr("slotMouseEvent from examiner ") + QString::number(i) + " with ";
635
636
637
638
639
640
641
642
643
644

          if ( _event->type() == QEvent::MouseButtonRelease )
            message += " MouseButtonRelease";
          else if ( _event->type() == QEvent::MouseButtonPress )
            message += " MouseButtonRelease";
          else if ( _event->type() == QEvent::MouseButtonDblClick )
            message += " MouseButtonDblClick";
          else if ( _event->type() == QEvent::MouseMove )
            message += " MouseMove";
          else
645
            message += tr("unknown event type");
646
647
648
649

          emit log(LOGINFO,message );
        }

Jan Möbius's avatar
Jan Möbius committed
650
        break;
651

Jan Möbius's avatar
Jan Möbius committed
652
653
654
655
656
657
658
      }
    }

  }

  PluginFunctions::setActiveExaminer( examinerId );

Jan Möbius's avatar
 
Jan Möbius committed
659
660
661
662
663
664
665
666
  emit PluginMouseEvent(_event );
}

//-----------------------------------------------------------------------------

void
Core::slotWheelEvent( QWheelEvent * _event, const std::string & _mode)
{
Jan Möbius's avatar
Jan Möbius committed
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
  const QObject* senderPointer = sender();
  unsigned int examinerId = 0;

  if ( senderPointer == 0 ) {
    std::cerr << "Error : slotWheelEvent directly called! This should only be called by an examiner" << std::endl;
  } else {
    for ( unsigned int i = 0 ; i < OpenFlipper::Options::examinerWidgets(); ++i ) {
      if ( senderPointer == coreWidget_->examiner_widgets_[i] ) {
        examinerId = i;
        break;
      }
    }

  }

  PluginFunctions::setActiveExaminer( examinerId );

Jan Möbius's avatar
 
Jan Möbius committed
684
685
686
687
688
689
690
691
  emit PluginWheelEvent(_event , _mode );
}

//-----------------------------------------------------------------------------

void
Core::slotAddPickMode( const std::string _mode ) {
  if ( OpenFlipper::Options::gui() )
692
    coreWidget_->addPickMode(_mode);
Jan Möbius's avatar
Jan Möbius committed
693

Jan Möbius's avatar
 
Jan Möbius committed
694
695
696
697
698
699
}

//-----------------------------------------------------------------------------

void
Core::slotAddHiddenPickMode( const std::string _mode ) {
Jan Möbius's avatar
Jan Möbius committed
700

Jan Möbius's avatar
 
Jan Möbius committed
701
  if ( OpenFlipper::Options::gui() )
702
    coreWidget_->addPickMode(_mode,false,1000,false);
Jan Möbius's avatar
Jan Möbius committed
703

Jan Möbius's avatar
 
Jan Möbius committed
704
705
706
707
708
709
710
}

//-----------------------------------------------------------------------------

 /** Update the view in the examiner widget
  */
void Core::updateView() {
Jan Möbius's avatar
Jan Möbius committed
711
712
713
714

  if ( OpenFlipper::Options::doSlotDebugging() ) {
    if ( sender() != 0 ) {
      if ( sender()->metaObject() != 0 ) {
715
        emit log(LOGINFO,tr("updateView() called by ") + QString( sender()->metaObject()->className() ) );
Jan Möbius's avatar
Jan Möbius committed
716
717
718
719
      }
    }
  }

Dirk Wilden's avatar
Dirk Wilden committed
720
721
722
  if ( !OpenFlipper::Options::gui() )
    return;

723
  if ( OpenFlipper::Options::restrictFrameRate() ) {
724

725
    int elapsed = redrawTime_->elapsed ();
726

727
728
    if ( elapsed < 1000 / OpenFlipper::Options::maxFrameRate() )
    {
Jan Möbius's avatar
Jan Möbius committed
729
730
731
      // redraw time not reached ... waiting for timer event for next redraw
      if ( redrawTimer_->isActive() ) {
        if ( OpenFlipper::Options::doSlotDebugging() )
732
          emit log(LOGINFO,tr("Too early for redraw! Delaying request from ") +
Jan Möbius's avatar
Jan Möbius committed
733
734
735
736
737
738
739
                           QString( sender()->metaObject()->className() ) );
        return;
      }

      // Start the timer
      redrawTimer_->start( (1000 / OpenFlipper::Options::maxFrameRate()) - elapsed);
      return;
Jan Möbius's avatar
Jan Möbius committed
740
    }
741
742
    else if ( redrawTimer_->isActive() )
	redrawTimer_->stop ();
743
744
745

  }

746
  redrawTime_->restart ();
747

Dirk Wilden's avatar
Dirk Wilden committed
748
  if ( !OpenFlipper::Options::loadingSettings() && !OpenFlipper::Options::redrawDisabled() ) {
Jan Möbius's avatar
Jan Möbius committed
749

750
    for ( unsigned int i = 0 ; i < OpenFlipper::Options::examinerWidgets() ; ++i )
Jan Möbius's avatar
Jan Möbius committed
751
      coreWidget_->examiner_widgets_[i]->updateGL();
Jan Möbius's avatar
 
Jan Möbius committed
752
753
754
  }
}

Jan Möbius's avatar
Jan Möbius committed
755
756


757
758
759
760
761
762
763
764
765
766
767
768
769
770
//-----------------------------------------------------------------------------

 /** Check if scenegraph is dirty and initiate redraw
  */
void Core::checkScenegraphDirty() {
  if ( true )
  {
    ACG::SceneGraph::CheckDirtyAction action;
    ACG::SceneGraph::traverse( root_node_scenegraph_, action );
    if ( action.isDirty () )
      emit updateView ();
  }
}

Jan Möbius's avatar
 
Jan Möbius committed
771
772
//-----------------------------------------------------------------------------

773
774
775
776
777
778
779
780
781
void Core::restrictFrameRate( bool _enable ) {
  OpenFlipper::Options::restrictFrameRate( _enable );
}

//-----------------------------------------------------------------------------

void Core::setMaxFrameRate( int _rate ) {
  OpenFlipper::Options::maxFrameRate( _rate );
  OpenFlipper::Options::restrictFrameRate( true );
782
783
784

  // update Timer to new framerate
  scenegraphCheckTimer_->setInterval (1000 / OpenFlipper::Options::maxFrameRate());
785
786
787
788
}

//-----------------------------------------------------------------------------

789
790
void
Core::clearAll()
Jan Möbius's avatar
 
Jan Möbius committed
791
{
792
793
794

  slotDeleteAllObjects();

Jan Möbius's avatar
Jan Möbius committed
795
  emit allCleared();
796

Jan Möbius's avatar
 
Jan Möbius committed
797
798
799
800
801
  slotScriptInfo( "core" , "clearAll()"  );
}

//-----------------------------------------------------------------------------

802
803
void
Core::exitApplication()
Jan Möbius's avatar
 
Jan Möbius committed
804
805
806
807
{
  QTimer* timer = new QTimer();
  connect(timer, SIGNAL(timeout()), this, SLOT(slotExit()));
  timer->start(100);
808

Jan Möbius's avatar
 
Jan Möbius committed
809
810
811
812
813
  QApplication::quit();
}

//-----------------------------------------------------------------------------

814
815
816
817
818
819
820
void Core::fullscreen( bool _state ) {
  if ( OpenFlipper::Options::gui() )
    coreWidget_->setFullscreen(_state);
}

//-----------------------------------------------------------------------------

Jan Möbius's avatar
Jan Möbius committed
821
822
void Core::loggerState(int _state) {
  OpenFlipper::Options::LoggerState state = static_cast<OpenFlipper::Options::LoggerState> (_state);
823
  if ( OpenFlipper::Options::gui() &&
Jan Möbius's avatar
Jan Möbius committed
824
825
826
827
       (state == OpenFlipper::Options::Hidden ||
        state == OpenFlipper::Options::InScene ||
        state == OpenFlipper::Options::Normal))
    coreWidget_->showLogger(state);
Jan Möbius's avatar
 
Jan Möbius committed
828
829
830
831
}

//-----------------------------------------------------------------------------

832
void Core::showToolbox( bool _state ) {
833
  if ( OpenFlipper::Options::gui() )
834
    coreWidget_->showToolbox(_state);
Jan Möbius's avatar
 
Jan Möbius committed
835
}
836

837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
void Core::multiViewMode( int _mode ) {
  if ( !OpenFlipper::Options::gui() || !OpenFlipper::Options::multiView() )
    return;

  switch (_mode)
  {
    case 0:
      coreWidget_->baseLayout_->setMode (QtMultiViewLayout::SingleView);
      PluginFunctions::setActiveExaminer(0);
      break;
    case 1:
      coreWidget_->baseLayout_->setMode (QtMultiViewLayout::Grid);
      break;
    case 2:
      coreWidget_->baseLayout_->setMode (QtMultiViewLayout::HSplit);
      break;

    default:
855
      emit log(LOGERR,tr("Requested illegal multiview mode!"));
856
857
858
859
860
861
  }

}



Jan Möbius's avatar
 
Jan Möbius committed
862
863
864

//-----------------------------------------------------------------------------

865
866
void
Core::slotRecentOpen(QAction* _action)
Jan Möbius's avatar
 
Jan Möbius committed
867
868
869
870
{
  QVector< OpenFlipper::Options::RecentFile > recentFiles = OpenFlipper::Options::recentFiles();
  for (int i = 0 ; i < recentFiles.size() ; ++i )
    if ( recentFiles[i].filename == _action->text() ){
Dirk Wilden's avatar
Dirk Wilden committed
871
872
      if (recentFiles[i].type == DATA_NONE)
        loadSettings( recentFiles[i].filename );
Dirk Wilden's avatar
Dirk Wilden committed
873
874
      else{
        OpenFlipper::Options::loadingRecentFile(true);
Dirk Wilden's avatar
Dirk Wilden committed
875
        loadObject(recentFiles[i].type, recentFiles[i].filename);
Dirk Wilden's avatar
Dirk Wilden committed
876
877
        OpenFlipper::Options::loadingRecentFile(false);
      }
Jan Möbius's avatar
 
Jan Möbius committed
878
879
880
881
882
      break;
    }
}


883
void
Jan Möbius's avatar
 
Jan Möbius committed
884
Core::writeOnExit() {
885
  QString inifile = QDir::home().absolutePath() + OpenFlipper::Options::dirSeparator() + ".OpenFlipper" +
Jan Möbius's avatar
 
Jan Möbius committed
886
887
888
889
                                                  OpenFlipper::Options::dirSeparator() +  "OpenFlipper.ini";

  INIFile ini;
  if ( ! ini.connect( inifile ,false) ) {
890
    emit log(LOGERR,tr("Failed to connect to users ini file"));
891

Jan Möbius's avatar
 
Jan Möbius committed
892
    if ( ! ini.connect( inifile,true) ) {
893
      emit log(LOGERR,tr("Can not create user ini file"));
Jan Möbius's avatar
 
Jan Möbius committed
894
    } else {
Dirk Wilden's avatar
Dirk Wilden committed
895
      writeApplicationOptions(ini);
Jan Möbius's avatar
 
Jan Möbius committed
896
897
898
      ini.disconnect();
    }
  } else {
Dirk Wilden's avatar
Dirk Wilden committed
899
    writeApplicationOptions(ini);
Jan Möbius's avatar
 
Jan Möbius committed
900
    ini.disconnect();
901
902
  }

Dirk Wilden's avatar
Dirk Wilden committed
903
904
  //store the windowState
  if ( OpenFlipper::Options::gui() ) {
Jan Möbius's avatar
Dennis:    
Jan Möbius committed
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920

    QSettings windowStates(QDir::home().absolutePath() + OpenFlipper::Options::dirSeparator() + ".OpenFlipper" +
                           OpenFlipper::Options::dirSeparator() +  "WindowStates.dat", QSettings::IniFormat);

    windowStates.setValue("Core/Window/State", coreWidget_->saveState ());
    windowStates.setValue("Core/Window/Geometry", coreWidget_->saveGeometry ());

    windowStates.setValue ("Core/ToolSplitter", coreWidget_->toolSplitter_->saveState ());
    windowStates.setValue ("Core/LogSplitter", coreWidget_->splitter_->saveState ());

    windowStates.beginGroup ("Core");
    windowStates.beginGroup ("LogSlider");
    coreWidget_->slidingLogger_->saveState (windowStates);
    windowStates.endGroup ();
    coreWidget_->toolBox_->saveState (windowStates);
    windowStates.endGroup ();
Dirk Wilden's avatar
Dirk Wilden committed
921
922
  }

Jan Möbius's avatar
 
Jan Möbius committed
923
924
925
926
927
928
929
930
931
932
933
  // Call exit for all plugins
   for (uint i = 0 ; i < plugins.size() ; ++i) {
      BaseInterface* basePlugin = qobject_cast< BaseInterface * >(plugins[i].plugin);
      if ( basePlugin )
          if ( checkSlot( plugins[i].plugin , "exit()" ) )
            QMetaObject::invokeMethod(plugins[i].plugin, "exit",  Qt::DirectConnection);
   }
}

void Core::slotExit() {
  writeOnExit();
Dirk Wilden's avatar
Dirk Wilden committed
934
935
936
937

  if (logFile_)
    logFile_->close();

Jan Möbius's avatar
 
Jan Möbius committed
938
  qApp->quit();
939
}
Jan Möbius's avatar
 
Jan Möbius committed
940

Dirk Wilden's avatar
Dirk Wilden committed
941
942
943
944
945
946
947
/// log to file
void Core::slotLogToFile(Logtype _type, QString _message){

  if (!OpenFlipper::Options::logFileEnabled())
    return;

  if (logStream_ == 0){
948
949
950
951
952
    //check if a logfile has been specified and if the path is valid

    QFileInfo fi( OpenFlipper::Options::logFile() );

    if (OpenFlipper::Options::logFile() == "" || !fi.dir().exists() )
953
        OpenFlipper::Options::logFile(QDir::home().absolutePath() + OpenFlipper::Options::dirSeparator() + ".OpenFlipper" +
Dirk Wilden's avatar
Dirk Wilden committed
954
955
956
957
958
959
                                                  OpenFlipper::Options::dirSeparator() +  "OpenFlipper.log");

    logFile_ = new QFile( OpenFlipper::Options::logFile() );
    if ( logFile_->open(QFile::WriteOnly) ) {
        logStream_ = new QTextStream (logFile_);
    }else{
960
      emit log(LOGERR, tr("Unable to open logfile!"));
Dirk Wilden's avatar
Dirk Wilden committed
961
962
963
      return;
    }
  }
Jan Möbius's avatar
 
Jan Möbius committed
964

Dirk Wilden's avatar
Dirk Wilden committed
965
966
967
968
969
970
971
972
973
974
975
976
  switch (_type) {
    case LOGINFO:
      (*logStream_) << "INFO:"; break;
    case LOGOUT:
      (*logStream_) << "OUT :"; break;
    case LOGWARN:
      (*logStream_) << "WARN:"; break;
    case LOGERR:
      (*logStream_) << "ERR :"; break;
  }

  (*logStream_) << _message << "\n" << flush;
977

Dirk Wilden's avatar
Dirk Wilden committed
978
}
Jan Möbius's avatar
 
Jan Möbius committed
979

980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
/// set descriptions for a scriptable slot
void Core::slotSetSlotDescription(QString      _slotName,   QString _slotDescription,
                              QStringList _parameters, QStringList _descriptions)
{
  //handle core slots
  if (sender() == this){
    SlotInfo info;
    info.slotName = _slotName;
    info.slotDescription = _slotDescription;
    info.parameters = _parameters;
    info.descriptions = _descriptions;

    coreSlots_.push_back( info );
    return;
  }

  //handle plugin slots

  //find plugin
 PluginInfo* pluginInfo = 0;