1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

Merge branch 'tray_icon' into HEAD

Let's thanks Aline <linuxine@gmail.com> for the icons.

Enjoy!
This commit is contained in:
David 2016-03-12 17:37:46 +01:00
commit 098d84ef73
9 changed files with 240 additions and 7 deletions

View File

@ -46,7 +46,8 @@ core_sources = \
src/plugins/api.h src/plugins/api.c \ src/plugins/api.h src/plugins/api.c \
src/plugins/callbacks.h src/plugins/callbacks.c \ src/plugins/callbacks.h src/plugins/callbacks.c \
src/plugins/autocompleters.c src/plugins/autocompleters.h \ src/plugins/autocompleters.c src/plugins/autocompleters.h \
src/plugins/themes.c src/plugins/themes.h src/plugins/themes.c src/plugins/themes.h \
src/tray.h src/tray.c
unittest_sources = \ unittest_sources = \
src/contact.c src/contact.h src/common.c \ src/contact.c src/contact.h src/common.c \
@ -167,6 +168,8 @@ otr_unittest_sources = \
themes_sources = themes/* themes_sources = themes/*
icons_sources = icons/*
script_sources = bootstrap.sh configure-debug install-all.sh script_sources = bootstrap.sh configure-debug install-all.sh
man_sources = docs/profanity.1 man_sources = docs/profanity.1
@ -195,6 +198,8 @@ endif
if INCLUDE_GIT_VERSION if INCLUDE_GIT_VERSION
BUILT_SOURCES = $(git_include) BUILT_SOURCES = $(git_include)
endif endif
profanity_iconsdir = @ICONS_PATH@
profanity_icons_DATA = $(icons_sources)
if BUILD_C_API if BUILD_C_API
lib_LTLIBRARIES = libprofanity.la lib_LTLIBRARIES = libprofanity.la
@ -223,7 +228,7 @@ endif
man_MANS = $(man_sources) man_MANS = $(man_sources)
EXTRA_DIST = $(man_sources) $(themes_sources) $(script_sources) profrc.example LICENSE.txt EXTRA_DIST = $(man_sources) $(icons_sources) $(themes_sources) $(script_sources) profrc.example LICENSE.txt
if INCLUDE_GIT_VERSION if INCLUDE_GIT_VERSION
EXTRA_DIST += .git/HEAD .git/index EXTRA_DIST += .git/HEAD .git/index

View File

@ -152,6 +152,10 @@ PKG_CHECK_MODULES([glib], [glib-2.0 >= 2.26], [],
PKG_CHECK_MODULES([curl], [libcurl], [], PKG_CHECK_MODULES([curl], [libcurl], [],
[AC_MSG_ERROR([libcurl is required for profanity])]) [AC_MSG_ERROR([libcurl is required for profanity])])
# Checks GTK+ 2.0
PKG_CHECK_MODULES([GTK], [gtk+-2.0 >= 2.24.10], [],
[AC_MSG_ERROR([gtk+-2.0 or higher is required for profanity])])
AS_IF([test "x$PLATFORM" != xosx], AS_IF([test "x$PLATFORM" != xosx],
[AC_CHECK_LIB([readline], [main], [], [AC_CHECK_LIB([readline], [main], [],
[AC_MSG_ERROR([libreadline is required for profanity])])], [AC_MSG_ERROR([libreadline is required for profanity])])],
@ -244,6 +248,9 @@ AS_IF([test "x$with_themes" = xno -o "x$with_themes" = xyes -o "x$with_themes" =
AC_SUBST(THEMES_PATH) AC_SUBST(THEMES_PATH)
AM_CONDITIONAL([THEMES_INSTALL], "$THEMES_INSTALL") AM_CONDITIONAL([THEMES_INSTALL], "$THEMES_INSTALL")
ICONS_PATH='${pkgdatadir}/icons'
AC_SUBST(ICONS_PATH)
### cmocka is required only for tests, profanity shouldn't be linked with it ### cmocka is required only for tests, profanity shouldn't be linked with it
### TODO: pass cmocka_CFLAGS and cmocka_LIBS to Makefile.am ### TODO: pass cmocka_CFLAGS and cmocka_LIBS to Makefile.am
PKG_CHECK_MODULES([cmocka], [cmocka], [], PKG_CHECK_MODULES([cmocka], [cmocka], [],
@ -265,9 +272,9 @@ AM_CFLAGS="-Wall -Wno-deprecated-declarations"
AS_IF([test "x$PACKAGE_STATUS" = xdevelopment], AS_IF([test "x$PACKAGE_STATUS" = xdevelopment],
[AM_CFLAGS="$AM_CFLAGS -Wunused -Werror"]) [AM_CFLAGS="$AM_CFLAGS -Wunused -Werror"])
AM_LDFLAGS="$AM_LDFLAGS -export-dynamic" AM_LDFLAGS="$AM_LDFLAGS -export-dynamic"
AM_CPPFLAGS="$AM_CPPFLAGS $glib_CFLAGS $curl_CFLAGS $libnotify_CFLAGS $PYTHON_CPPFLAGS" AM_CPPFLAGS="$AM_CPPFLAGS $glib_CFLAGS $curl_CFLAGS $libnotify_CFLAGS $PYTHON_CPPFLAGS ${GTK_CFLAGS}"
AM_CPPFLAGS="$AM_CPPFLAGS -DTHEMES_PATH=\"\\\"$THEMES_PATH\\\"\"" AM_CPPFLAGS="$AM_CPPFLAGS -DTHEMES_PATH=\"\\\"$THEMES_PATH\\\"\" -DICONS_PATH=\"\\\"$ICONS_PATH\\\"\""
LIBS="$glib_LIBS $curl_LIBS $libnotify_LIBS $PYTHON_LIBS $PYTHON_LDFLAGS $LIBS" LIBS="$glib_LIBS $curl_LIBS $libnotify_LIBS $PYTHON_LIBS $PYTHON_LDFLAGS ${GTK_LIBS} $LIBS"
AC_SUBST(AM_LDFLAGS) AC_SUBST(AM_LDFLAGS)
AC_SUBST(AM_CFLAGS) AC_SUBST(AM_CFLAGS)
@ -289,5 +296,6 @@ echo "LIBS : $LIBS"
echo "XML Parser : $PARSER" echo "XML Parser : $PARSER"
echo "Install themes : $THEMES_INSTALL" echo "Install themes : $THEMES_INSTALL"
echo "Themes path : $THEMES_PATH" echo "Themes path : $THEMES_PATH"
echo "Icons path : $ICONS_PATH"
echo "" echo ""
echo "Now you can run \`make' to build profanity" echo "Now you can run \`make' to build profanity"

BIN
icons/proIcon.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 662 B

BIN
icons/proIconMsg.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

View File

@ -24,7 +24,7 @@ debian_prepare()
echo echo
echo Profanity installer... installing dependencies echo Profanity installer... installing dependencies
echo echo
sudo apt-get -y install git automake autoconf libssl-dev libexpat1-dev libncursesw5-dev libglib2.0-dev libnotify-dev libcurl3-dev libxss-dev libotr5-dev libreadline-dev libtool libgpgme11-dev sudo apt-get -y install git automake autoconf libssl-dev libexpat1-dev libncursesw5-dev libglib2.0-dev libnotify-dev libcurl3-dev libxss-dev libotr5-dev libreadline-dev libtool libgpgme11-dev libgtk2.0-dev
} }
@ -34,7 +34,7 @@ fedora_prepare()
echo Profanity installer... installing dependencies echo Profanity installer... installing dependencies
echo echo
sudo dnf -y install gcc git autoconf automake openssl-devel expat-devel ncurses-devel glib2-devel libnotify-devel libcurl-devel libXScrnSaver-devel libotr3-devel readline-devel libtool gpgme-devel sudo dnf -y install gcc git autoconf automake openssl-devel expat-devel ncurses-devel glib2-devel libnotify-devel libcurl-devel libXScrnSaver-devel libotr3-devel readline-devel libtool gpgme-devel gtk2-devel
} }
opensuse_prepare() opensuse_prepare()

View File

@ -34,8 +34,10 @@
#include "prof_config.h" #include "prof_config.h"
#include <gtk/gtk.h>
#include <string.h> #include <string.h>
#include <glib.h> #include <glib.h>
#include <assert.h>
#ifdef PROF_HAVE_GIT_VERSION #ifdef PROF_HAVE_GIT_VERSION
#include "gitversion.h" #include "gitversion.h"
@ -139,6 +141,8 @@ main(int argc, char **argv)
return 0; return 0;
} }
assert (gtk_init_check(&argc, &argv) == true);
gtk_init(&argc, &argv);
prof_run(log, account_name); prof_run(log, account_name);
return 0; return 0;

View File

@ -37,6 +37,7 @@
#include "gitversion.h" #include "gitversion.h"
#endif #endif
#include <gtk/gtk.h>
#include <locale.h> #include <locale.h>
#include <signal.h> #include <signal.h>
#include <stdlib.h> #include <stdlib.h>
@ -72,6 +73,7 @@
#include "window_list.h" #include "window_list.h"
#include "event/client_events.h" #include "event/client_events.h"
#include "config/tlscerts.h" #include "config/tlscerts.h"
#include "tray.h"
static void _check_autoaway(void); static void _check_autoaway(void);
static void _init(char *log_level); static void _init(char *log_level);
@ -98,6 +100,7 @@ prof_run(char *log_level, char *account_name)
{ {
_init(log_level); _init(log_level);
plugins_on_start(); plugins_on_start();
gtk_main_iteration_do(false);
_connect_default(account_name); _connect_default(account_name);
ui_update(); ui_update();
@ -130,6 +133,7 @@ prof_run(char *log_level, char *account_name)
jabber_process_events(10); jabber_process_events(10);
iq_autoping_check(); iq_autoping_check();
ui_update(); ui_update();
gtk_main_iteration_do(false);
} }
} }
@ -352,6 +356,7 @@ _init(char *log_level)
#endif #endif
atexit(_shutdown); atexit(_shutdown);
plugins_init(); plugins_init();
create_tray();
inp_nonblocking(TRUE); inp_nonblocking(TRUE);
} }
@ -371,6 +376,7 @@ _shutdown(void)
cl_ev_disconnect(); cl_ev_disconnect();
} }
destroy_tray();
jabber_shutdown(); jabber_shutdown();
plugins_on_shutdown(); plugins_on_shutdown();
muc_close(); muc_close();
@ -404,6 +410,8 @@ _create_directories(void)
GString *themes_dir = g_string_new(xdg_config); GString *themes_dir = g_string_new(xdg_config);
g_string_append(themes_dir, "/profanity/themes"); g_string_append(themes_dir, "/profanity/themes");
GString *icons_dir = g_string_new(xdg_config);
g_string_append(icons_dir, "/profanity/icons");
GString *chatlogs_dir = g_string_new(xdg_data); GString *chatlogs_dir = g_string_new(xdg_data);
g_string_append(chatlogs_dir, "/profanity/chatlogs"); g_string_append(chatlogs_dir, "/profanity/chatlogs");
GString *logs_dir = g_string_new(xdg_data); GString *logs_dir = g_string_new(xdg_data);
@ -414,6 +422,9 @@ _create_directories(void)
if (!mkdir_recursive(themes_dir->str)) { if (!mkdir_recursive(themes_dir->str)) {
log_error("Error while creating directory %s", themes_dir->str); log_error("Error while creating directory %s", themes_dir->str);
} }
if (!mkdir_recursive(icons_dir->str)) {
log_error("Error while creating directory %s", icons_dir->str);
}
if (!mkdir_recursive(chatlogs_dir->str)) { if (!mkdir_recursive(chatlogs_dir->str)) {
log_error("Error while creating directory %s", chatlogs_dir->str); log_error("Error while creating directory %s", chatlogs_dir->str);
} }
@ -425,6 +436,7 @@ _create_directories(void)
} }
g_string_free(themes_dir, TRUE); g_string_free(themes_dir, TRUE);
g_string_free(icons_dir, TRUE);
g_string_free(chatlogs_dir, TRUE); g_string_free(chatlogs_dir, TRUE);
g_string_free(logs_dir, TRUE); g_string_free(logs_dir, TRUE);
g_string_free(plugins_dir, TRUE); g_string_free(plugins_dir, TRUE);

154
src/tray.c Normal file
View File

@ -0,0 +1,154 @@
/*
* tray.c
*
* Copyright (C) 2012 - 2016 David Petroni <petrodavi@gmail.com>
*
* This file is part of Profanity.
*
* Profanity 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.
*
* Profanity 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 Profanity. If not, see <http://www.gnu.org/licenses/>.
*
* In addition, as a special exception, the copyright holders give permission to
* link the code of portions of this program with the OpenSSL library under
* certain conditions as described in each individual source file, and
* distribute linked combinations including the two.
*
* You must obey the GNU General Public License in all respects for all of the
* code used other than OpenSSL. If you modify file(s) with this exception, you
* may extend this exception to your version of the file(s), but you are not
* obligated to do so. If you do not wish to do so, delete this exception
* statement from your version. If you delete this exception statement from all
* source files in the program, then also delete it here.
*
*/
#include <gtk/gtk.h>
#include <glib.h>
#include <glib/gstdio.h>
#include "tray.h"
#include "window_list.h"
static GtkStatusIcon *prof_tray = NULL;
static GString *icon_filename = NULL;
static GString *icon_msg_filename = NULL;
static gint unread_messages;
static gboolean shutting_down;
static guint timer;
/* {{{ Privates */
/*
* Get icons from installation share folder or (if defined) .locale user's folder
*
* As implementation, looking through all the entries in the .locale folder is chosen.
* While useless as now, it might be useful in case an association name-icon is created.
* As now, with 2 icons only, this is pretty useless, but it is not harming ;)
*
*/
static void _get_icons(void)
{
GString *icons_dir = NULL;
#ifdef ICONS_PATH
icons_dir = g_string_new(ICONS_PATH);
icon_filename = g_string_new(icons_dir->str);
icon_msg_filename = g_string_new(icons_dir->str);
g_string_append(icon_filename, "/proIcon.png");
g_string_append(icon_msg_filename, "/proIconMsg.png");
g_string_free(icons_dir, true);
#endif /* ICONS_PATH */
gchar *xdg_config = xdg_get_config_home();
icons_dir = g_string_new(xdg_config);
g_free(xdg_config);
g_string_append(icons_dir, "/profanity/icons");
GError *err = NULL;
if (!g_file_test(icons_dir->str, G_FILE_TEST_IS_DIR)) {
return;
}
GDir *dir = g_dir_open(icons_dir->str, 0, &err);
if (dir) {
GString *name = g_string_new(g_dir_read_name(dir));
while (name->len) {
if (g_strcmp0("proIcon.png", name->str) == 0) {
g_string_free(icon_filename, true);
icon_filename = g_string_new(icons_dir->str);
g_string_append(icon_filename, "/proIcon.png");
} else
if (g_strcmp0("proIconMsg.png", name->str) == 0){
g_string_free(icon_msg_filename, true);
icon_msg_filename = g_string_new(icons_dir->str);
g_string_append(icon_msg_filename, "/proIconMsg.png");
}
g_string_free(name, true);
name = g_string_new(g_dir_read_name(dir));
}
g_string_free(name, true);
} else {
fprintf (stderr, "Unable to open dir: %s\n", err->message);
g_error_free(err);
}
g_dir_close(dir);
g_string_free(icons_dir, true);
}
/*
* Callback for the timer
*
* This is the callback that the timer is calling in order to check if messages are there.
*
*/
gboolean _tray_change_icon(gpointer data)
{
if (shutting_down) {
return false;
}
unread_messages = wins_get_total_unread();
if (unread_messages) {
gtk_status_icon_set_from_file(prof_tray, icon_msg_filename->str);
} else {
gtk_status_icon_set_from_file(prof_tray, icon_filename->str);
}
return true;
}
/* }}} */
/* {{{ Public */
void create_tray(void)
{
_get_icons();
prof_tray = gtk_status_icon_new_from_file(icon_filename->str);
shutting_down = false;
timer = g_timeout_add(5000, _tray_change_icon, NULL);
}
void destroy_tray(void)
{
shutting_down = true;
g_source_remove(timer);
if (prof_tray) {
gtk_widget_destroy(GTK_WIDGET(prof_tray));
prof_tray = NULL;
}
g_string_free(icon_filename, true);
g_string_free(icon_msg_filename, true);
}
/* }}} */

50
src/tray.h Normal file
View File

@ -0,0 +1,50 @@
/*
* tray.h
*
* Copyright (C) 2012 - 2016 David Petroni <petrodavi@gmail.com>
*
* This file is part of Profanity.
*
* Profanity 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.
*
* Profanity 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 Profanity. If not, see <http://www.gnu.org/licenses/>.
*
* In addition, as a special exception, the copyright holders give permission to
* link the code of portions of this program with the OpenSSL library under
* certain conditions as described in each individual source file, and
* distribute linked combinations including the two.
*
* You must obey the GNU General Public License in all respects for all of the
* code used other than OpenSSL. If you modify file(s) with this exception, you
* may extend this exception to your version of the file(s), but you are not
* obligated to do so. If you do not wish to do so, delete this exception
* statement from your version. If you delete this exception statement from all
* source files in the program, then also delete it here.
*
*/
#ifndef PROFANITY_TRAY_H
#define PROFANITY_TRAY_H
/*
* Create tray icon
*
* This will initialize the timer that will be called in order to change the icons
* and will search the icons in the defaults paths
*/
void create_tray(void);
/*
* Destroy tray icon
*/
void destroy_tray(void);
#endif