lumiera_/src/gui/gtk-lumiera.hpp
Ichthyostega 670c670d55 style-adjustment: GUI indentation, naming and braces
over time, a specific Lumiera code writing style has emerged.
The GUI, as it stood, used somewhat different conventions,
which now have been aligned to the common standard.

Basically we use GNU style, with some adjustments for OO-programming,
we prefer CamelCase, and write TypeNames uppercase, variableNames lowercase
2015-05-29 04:44:58 +02:00

107 lines
3.4 KiB
C++

/*
GTK-LUMIERA.hpp - The Lumiera GUI Application Object
Copyright (C) Lumiera.org
2008, Joel Holdsworth <joel@airwebreathe.org.uk>
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of
the License, or (at your option) any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
/** @file gtk-lumiera.hpp
** The main application object.
** Invoking the GtkLumiera::main() function brings up the GUI; this
** function will block in the GTK event thread until the Application gets
** closed by user interaction or by triggering a shutdown via the GuiNotificationFacade.
** GtkLumiera is a singleton and owns the central WindowManager instance used for
** opening all windows and registering and loading icons and resources.
**
** \par configuration and resource search
** The GUI object retrieves the necessary configuration values from lumiera::Config,
** the config facade in the application core. Currently as of 2/2011 these values are
** loaded from setup.ini, because the full-blown config system is not yet implemented.
** Amongst others, this configuration defines a <i>search path</i> for icons and a
** separate search path for resources. These path specs may use the token \c $ORIGIN
** to refer to the installation directory of the currently executing program.
** This allows for a relocatable Lumiera installation bundle.
**
** @see guistart.cpp the plugin to pull up this GUI
** @see gui::GuiFacade access point for starting the GUI
** @see gui::GuiNotification interface for communication with the gui from the lower layers
** @see lumiera::Config
** @see lumiera::BasicSetup definition of the acceptable configuration values
** @see lumiera::AppState general Lumiera application main
**
*/
#ifndef GUI_GTK_LUMIERA_H
#define GUI_GTK_LUMIERA_H
#include "gui/gtk-base.hpp"
#include "gui/window-manager.hpp"
#include <boost/noncopyable.hpp>
#include <memory>
#include <vector>
namespace gui {
using std::shared_ptr;
/* ====== The Application Class ====== */
/**
* Top level entry point: The Lumiera GTK UI.
*/
class GtkLumiera
: boost::noncopyable
{
/** Central application window manager instance */
WindowManager windowManagerInstance_;
public:
/** access the the global application object */
static GtkLumiera& application();
/** start up the GUI and run the event thread */
void main(int argc, char *argv[]);
WindowManager& windowManager();
/** the name of the application */
static cuString getAppTitle();
static cuString getAppVersion();
static cuString getCopyright();
static cuString getLumieraWebsite();
/** alphabetical list of the application's authors */
static const std::vector<uString> getLumieraAuthors();
};
}// namespace gui
#endif