/////////////////////////////////////////////////////////////////////////////
// Name: eviacamapp.cpp
// Purpose:
// Author: Cesar Mauri Loba (cesar at crea-si dot com)
// Modified by:
// Created: 09/01/2008 21:40:06
// Copyright: (C) 2008-11 Cesar Mauri Loba - CREA Software Systems
//
// 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 3 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, see .
/////////////////////////////////////////////////////////////////////////////
// For compilers that support precompilation, includes "wx/wx.h".
#include "wx/wxprec.h"
#ifdef __BORLANDC__
#pragma hdrstop
#endif
#ifndef WX_PRECOMP
#include "wx/wx.h"
#endif
////@begin includes
////@end includes
#include
#include
#include
#include
#include "eviacamapp.h"
#include "paths.h"
#include "viacamcontroller.h"
#include "simplelog.h"
////@begin XPM images
////@end XPM images
#if !wxUSE_THREADS
#error "This program requires thread support."
#endif // wxUSE_THREADS
/*!
* Application instance implementation
*/
/*
////@begin implement app
IMPLEMENT_APP( EViacamApp )
////@end implement app
*/
// Under X11 it's necessary enable threading support (for XTestFakeRelativeMotionEvent call)
#if defined(__WXGTK__) || defined(__WXMOTIF__) || defined(__WXX11__)
IMPLEMENT_APP_NO_MAIN(EViacamApp)
#include
#ifndef NDEBUG
#include
#endif
int main(int argc, char *argv[]) {
//printf( "XInitThreads - calling\n" );
#ifndef NDEBUG
//mtrace();
#endif
if ( XInitThreads() == 0 ) {
fprintf( stderr, "%s: Unable to initialize multithreaded X11 code (XInitThreads failed).\n", argv[0] );
exit( EXIT_FAILURE );
}
return wxEntry(argc, argv);
}
#else
IMPLEMENT_APP(EViacamApp)
#endif
/*!
* EViacamApp type definition
*/
IMPLEMENT_CLASS( EViacamApp, wxApp )
/*!
* EViacamApp event table definition
*/
BEGIN_EVENT_TABLE( EViacamApp, wxApp )
////@begin EViacamApp event table entries
////@end EViacamApp event table entries
EVT_QUERY_END_SESSION(EViacamApp::OnEndSession)
END_EVENT_TABLE()
/*!
* Constructor for EViacamApp
*/
EViacamApp::EViacamApp()
{
Init();
}
/*!
* Member initialisation
*/
void EViacamApp::Init()
{
m_pController= NULL;
////@begin EViacamApp member initialisation
////@end EViacamApp member initialisation
}
/*!
* Initialisation for EViacamApp
*/
bool EViacamApp::OnInit()
{
// These functions are useful to pin down memory leaks on WIN32
//_CrtSetDbgFlag(_CRTDBG_ALLOC_MEM_DF | _CRTDBG_LEAK_CHECK_DF);
//_CrtSetBreakAlloc(489103);
// Call default behaviour
if (!wxApp::OnInit()) return false;
/* ////@begin EViacamApp initialisation */
// Remove the comment markers above and below this block
// to make permanent changes to the code.
#if wxUSE_XPM
wxImage::AddHandler(new wxXPMHandler);
#endif
#if wxUSE_LIBPNG
wxImage::AddHandler(new wxPNGHandler);
#endif
#if wxUSE_LIBJPEG
wxImage::AddHandler(new wxJPEGHandler);
#endif
#if wxUSE_GIF
wxImage::AddHandler(new wxGIFHandler);
#endif
/* ////@end EViacamApp initialisation */
// Set up globals
#ifndef NDEBUG
// Assume project runs from src/
eviacam::SetDataDir(wxGetCwd() + _T("/../doc/"));
#else
eviacam::SetDataDir(wxStandardPaths::Get().GetDataDir());
#endif
// Initialize sockets support
// Note: (Workaround for implementation limitation for wxWidgets up to 2.5.x)
// If you want to use sockets or derived classes such as wxFTP in a secondary
// thread, call wxSocketBase::Initialize() (undocumented) from the main thread
// before creating any sockets - in wxApp::OnInit for example.
// See http://wiki.wxwidgets.org/wiki.pl?WxSocket or
// http://www.litwindow.com/knowhow/knowhow.html for more details.
wxSocketBase::Initialize();
m_pController= new CViacamController();
assert (m_pController);
if (!m_pController->Initialize())
{
OnExit();
return false;
}
else return true;
}
static const wxCmdLineEntryDesc g_cmdLineDesc [] =
{
{ wxCMD_LINE_SWITCH, wxT_2("h"), wxT_2("help"), wxT_2("displays help on the command line parameters."),
wxCMD_LINE_VAL_NONE, wxCMD_LINE_OPTION_HELP },
{ wxCMD_LINE_SWITCH, wxT_2("d"), wxT_2("debug"), wxT_2("debug mode. Print debug messages to the console."),
wxCMD_LINE_VAL_NONE, wxCMD_LINE_PARAM_OPTIONAL },
{ wxCMD_LINE_NONE }
};
void EViacamApp::OnInitCmdLine(wxCmdLineParser& parser)
{
parser.SetDesc (g_cmdLineDesc);
// must refuse '/' as parameter starter or cannot use "/path" style paths
parser.SetSwitchChars (wxT("-"));
}
bool EViacamApp::OnCmdLineParsed(wxCmdLineParser& parser)
{
bool debug_mode= parser.Found(wxT("d"));
#ifndef NDEBUG
debug_mode = true;
#endif
if (debug_mode) {
// Set log priority level
slog_set_priority (SLOG_PRIO_DEBUG);
#if defined(WIN32)
AllocConsole();
freopen("CONOUT$", "wb", stdout);
freopen("CONOUT$", "wb", stderr);
slog_write (SLOG_PRIO_INFO, "debug mode enabled");
#endif
}
return true;
}
/*!
* Cleanup for EViacamApp
*/
int EViacamApp::OnExit()
{
m_pController->Finalize();
delete m_pController;
m_pController= NULL;
wxSocketBase::Shutdown();
////@begin EViacamApp cleanup
return wxApp::OnExit();
////@end EViacamApp cleanup
}
//
// This handler terminates eViacam gracefully when the OS session is closed
//
void EViacamApp::OnEndSession( wxCloseEvent& event )
{
if (m_pController) m_pController->Finalize();
event.Skip(false);
}