2 Copyright 2004-2005 Chris Tallon
4 This file is part of VOMP.
6 VOMP is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 VOMP is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with VOMP; if not, write to the Free Software
18 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
25 #include <unistd.h> // for reboot
26 #include <linux/reboot.h>
27 #include <sys/reboot.h>
38 #include "messagequeue.h"
58 typedef vector<struct ASLPref> ASLPrefList;
60 class Command : public MessageQueue
65 static Command* getInstance();
67 int init(bool crashed = false, char* server = NULL);
72 void postMessage(Message* m); // override of MessageQueue::postMessage
73 void postMessageNoLock(Message* m); // override of MessageQueue::postMessage
74 bool postMessageIfNotBusy(Message* m); // for timers, when masterMutex might be locked
75 void postMessageFromOuterSpace(Message* m); // err, read the cc comments.
77 void connectionLost();
79 void setAdvMenues(bool adv) {advmenues=adv;};
80 bool advMenues() { return advmenues;};
81 int getLangPref(bool subtitle,const char* langcode);
82 void setSubDefault(int subon) {subdefault=subon;};
83 int getSubDefault() { return subdefault;};
84 ASLPrefList &getASLList(){return langcodes;};
87 void handleCommand(int);
91 void doJustConnected(VConnect* vconnect);
93 void doFromTheTop(bool which); // true - show vinfo,wait. false - del vinfo,restart
94 void buildCrashedBox();
96 static Command* instance;
99 pthread_mutex_t masterLock;
102 HANDLE mainPid; //Window
113 WJpeg* wallpaper_pict;
119 ASLPrefList langcodes;
124 void processMessage(Message* m);