summaryrefslogtreecommitdiffstats
path: root/src/Applet/CCApplet.cpp
diff options
context:
space:
mode:
authorJiri Moskovcak <jmoskovc@redhat.com>2009-02-12 16:02:29 +0100
committerJiri Moskovcak <jmoskovc@redhat.com>2009-02-12 16:02:29 +0100
commit164c692385ddf3b17fbc9417b748f198ff19b096 (patch)
treeeca3c81d10577f37386209b66e1a4f3c55f31844 /src/Applet/CCApplet.cpp
parent53821dddf0b6ee66dc5f0684b17c541c157656ec (diff)
downloadabrt-164c692385ddf3b17fbc9417b748f198ff19b096.tar.gz
abrt-164c692385ddf3b17fbc9417b748f198ff19b096.tar.xz
abrt-164c692385ddf3b17fbc9417b748f198ff19b096.zip
Rewritten dbus to dbus-c++
Added possibility to call daemon methods via dbus
Diffstat (limited to 'src/Applet/CCApplet.cpp')
-rw-r--r--src/Applet/CCApplet.cpp53
1 files changed, 48 insertions, 5 deletions
diff --git a/src/Applet/CCApplet.cpp b/src/Applet/CCApplet.cpp
index fd9741ae..17ff6f92 100644
--- a/src/Applet/CCApplet.cpp
+++ b/src/Applet/CCApplet.cpp
@@ -19,33 +19,66 @@
#include "CCApplet.h"
#include <iostream>
+#include <cstdarg>
+#include <sstream>
CApplet::CApplet()
{
-
m_nStatusIcon = Gtk::StatusIcon::create(Gtk::Stock::DIALOG_WARNING);
m_nStatusIcon->set_visible(false);
- // LTM click
+ // LMB click
m_nStatusIcon->signal_activate().connect(sigc::mem_fun(*this, &CApplet::OnAppletActivate_CB));
- SetIconToolip("Pending events:");
+ m_nStatusIcon->signal_popup_menu().connect(sigc::mem_fun(*this, &CApplet::OnMenuPopup_cb));
+ SetIconTooltip("Pending events: %i",m_mapEvents.size());
+
}
CApplet::~CApplet()
{
}
-void CApplet::SetIconToolip(const Glib::ustring& tip)
+void CApplet::SetIconTooltip(const char *format, ...)
{
- m_nStatusIcon->set_tooltip(tip);
+ va_list args;
+ // change to smth sane like MAX_TOOLTIP length or rewrite this whole sh*t
+ size_t n,size = 10;
+ char *buf = new char[size];
+ va_start (args, format);
+ while((n = vsnprintf (buf, size, format, args)) > size)
+ {
+ // string was larger than our buffer
+ // alloc larger buffer
+ size = n+1;
+ delete[] buf;
+ buf = new char[size];
+ }
+ va_end (args);
+ if (n != -1)
+ {
+ m_nStatusIcon->set_tooltip(Glib::ustring((const char*)buf));
+ }
+ else
+ {
+ m_nStatusIcon->set_tooltip("Error while setting tooltip!");
+ }
+ delete[] buf;
}
void CApplet::OnAppletActivate_CB()
{
m_nStatusIcon->set_visible(false);
//std::cout << "Activate" << std::endl;
+ //if(m_pMenuPopup)
+ //m_pMenuPopup->show();
}
+void CApplet::OnMenuPopup_cb(guint button, guint32 activate_time)
+{
+ /* for now just hide the icon on RMB */
+ m_nStatusIcon->set_blinking(false);
+}
+
void CApplet::ShowIcon()
{
m_nStatusIcon->set_visible(true);
@@ -56,6 +89,16 @@ void CApplet::HideIcon()
m_nStatusIcon->set_visible(false);
}
+int CApplet::AddEvent(int pUUID, const std::string& pProgname)
+{
+ m_mapEvents[pUUID] = "pProgname";
+ SetIconTooltip("Pending events: %i",m_mapEvents.size());
+}
+
+int CApplet::RemoveEvent(int pUUID)
+{
+ m_mapEvents.erase(pUUID);
+}
void CApplet::BlinkIcon(bool pBlink)
{
m_nStatusIcon->set_blinking(pBlink);