summaryrefslogtreecommitdiff
path: root/client/info_gui.cc
blob: ac733ff789049a9cfb14650d57ccdc96785f9609 (plain)
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/***************************************************************************
 *            info_gui.cc
 *
 *  Tue May  3 09:34:59 CEST 2005
 *  Copyright  2005 Bent Bisballe
 *  deva@aasimon.org
 ****************************************************************************/

/*
 *    This file is part of MIaV.
 *
 *    MIaV 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.
 *
 *    MIaV 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 MIaV; if not, write to the Free Software
 *    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA.
 */
#include "info_gui.h"

#include <stdio.h>
#include <stdarg.h>

#include <time.h>

bool InfoEventHandler::eventFilter( QObject *o, QEvent *e )
{
  if ( e->type() == TYPE_SHOW_MESSAGEBOX ) {
    ShowMessageEvent *msgevt = (ShowMessageEvent*)e;
    MessageBox msgbox(NULL,
                      msgevt->title(),
                      msgevt->message(),
                      TYPE_OK,
                      msgevt->icon());
    msgbox.exec();
    return TRUE; // eat event
  } else {
    // standard event processing
    return FALSE;
  }
}

InfoGui::InfoGui(MiavConfig *c): Info()
{
  this->config = c;
  log_filename = *(this->config->readString("client_log_file"));

  InfoEventHandler *eventhandler = new InfoEventHandler();
  qApp->installEventFilter( eventhandler );

  //  pthread_mutex_init (&mutex, NULL);
}

InfoGui::~InfoGui()
{
  // pthread_mutex_destroy(&mutex);
}

void InfoGui::showmsg(char *msg, char *title, msg_icon icon)
{
  //  pthread_mutex_lock(&mutex);
  // Beginning of safezone

  ShowMessageEvent *event = new ShowMessageEvent(msg, title, icon);
  
  qApp->postEvent(qApp, event);

  // End of safezone
  //  pthread_mutex_unlock(&mutex);
}

void InfoGui::error(char *fmt, ...)
{
  char buf[1024];

	va_list argp;
	va_start(argp, fmt);
	vsprintf(buf, fmt, argp);
	va_end(argp);

  showmsg(buf, TXT_ERROR_TITLE, ICON_ERROR);

  log("Error: %s", buf);
}

void InfoGui::warn(char *fmt, ...)
{
  char buf[1024];

	va_list argp;
	va_start(argp, fmt);
	vsprintf(buf, fmt, argp);
	va_end(argp);

  showmsg(buf, TXT_WARNING_TITLE, ICON_WARNING);

  log("Warning: %s", buf);
}

void InfoGui::info(char *fmt, ...)
{
  char buf[1024];

	va_list argp;
	va_start(argp, fmt);
	vsprintf(buf, fmt, argp);
	va_end(argp);

  showmsg(buf, TXT_INFO_TITLE, ICON_INFO);

  log("Info: %s", buf);
}