panel: allow building the applet without X11
This commit is contained in:
parent
39c84f1faf
commit
fb36a3f24b
|
@ -34,8 +34,10 @@
|
||||||
#endif
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
#if GTK_CHECK_VERSION(3, 0, 0)
|
#if defined(GDK_WINDOWING_X11)
|
||||||
# include <gtk/gtkx.h>
|
# if GTK_CHECK_VERSION(3, 0, 0)
|
||||||
|
# include <gtk/gtkx.h>
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
#include <Desktop.h>
|
#include <Desktop.h>
|
||||||
#include "Phone.h"
|
#include "Phone.h"
|
||||||
|
@ -73,6 +75,7 @@ typedef struct _PhonePlugin
|
||||||
{
|
{
|
||||||
PhonePluginHelper * helper;
|
PhonePluginHelper * helper;
|
||||||
|
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
guint timeout;
|
guint timeout;
|
||||||
GtkWidget * plug;
|
GtkWidget * plug;
|
||||||
GtkWidget * hbox;
|
GtkWidget * hbox;
|
||||||
|
@ -92,6 +95,7 @@ typedef struct _PhonePlugin
|
||||||
GtkWidget * window;
|
GtkWidget * window;
|
||||||
GtkWidget * battery;
|
GtkWidget * battery;
|
||||||
GtkWidget * truncate;
|
GtkWidget * truncate;
|
||||||
|
#endif
|
||||||
} Panel;
|
} Panel;
|
||||||
|
|
||||||
|
|
||||||
|
@ -101,12 +105,14 @@ static void _panel_destroy(Panel * panel);
|
||||||
static int _panel_event(Panel * panel, PhoneEvent * event);
|
static int _panel_event(Panel * panel, PhoneEvent * event);
|
||||||
static void _panel_settings(Panel * panel);
|
static void _panel_settings(Panel * panel);
|
||||||
|
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
static void _panel_set_battery_level(Panel * panel, gdouble level,
|
static void _panel_set_battery_level(Panel * panel, gdouble level,
|
||||||
gboolean charging);
|
gboolean charging);
|
||||||
static void _panel_set_operator(Panel * panel, ModemRegistrationStatus status,
|
static void _panel_set_operator(Panel * panel, ModemRegistrationStatus status,
|
||||||
char const * _operator);
|
char const * _operator);
|
||||||
static void _panel_set_signal_level(Panel * panel, gdouble level);
|
static void _panel_set_signal_level(Panel * panel, gdouble level);
|
||||||
static void _panel_set_status(Panel * panel, gboolean data, gboolean roaming);
|
static void _panel_set_status(Panel * panel, gboolean data, gboolean roaming);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* public */
|
/* public */
|
||||||
|
@ -126,19 +132,22 @@ PhonePluginDefinition plugin =
|
||||||
/* private */
|
/* private */
|
||||||
/* functions */
|
/* functions */
|
||||||
/* panel_init */
|
/* panel_init */
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
static gboolean _on_plug_delete_event(gpointer data);
|
static gboolean _on_plug_delete_event(gpointer data);
|
||||||
static void _on_plug_embedded(gpointer data);
|
static void _on_plug_embedded(gpointer data);
|
||||||
static gboolean _on_battery_timeout(gpointer data);
|
static gboolean _on_battery_timeout(gpointer data);
|
||||||
|
#endif
|
||||||
|
|
||||||
static Panel * _panel_init(PhonePluginHelper * helper)
|
static Panel * _panel_init(PhonePluginHelper * helper)
|
||||||
{
|
{
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
Panel * panel;
|
Panel * panel;
|
||||||
PangoFontDescription * bold;
|
PangoFontDescription * bold;
|
||||||
char const * p;
|
char const * p;
|
||||||
|
|
||||||
#ifdef DEBUG
|
# ifdef DEBUG
|
||||||
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
||||||
#endif
|
# endif
|
||||||
if((panel = object_new(sizeof(*panel))) == NULL)
|
if((panel = object_new(sizeof(*panel))) == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
panel->helper = helper;
|
panel->helper = helper;
|
||||||
|
@ -150,11 +159,11 @@ static Panel * _panel_init(PhonePluginHelper * helper)
|
||||||
_on_plug_delete_event), panel);
|
_on_plug_delete_event), panel);
|
||||||
g_signal_connect_swapped(panel->plug, "embedded", G_CALLBACK(
|
g_signal_connect_swapped(panel->plug, "embedded", G_CALLBACK(
|
||||||
_on_plug_embedded), panel);
|
_on_plug_embedded), panel);
|
||||||
#if GTK_CHECK_VERSION(3, 0, 0)
|
# if GTK_CHECK_VERSION(3, 0, 0)
|
||||||
panel->hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 2);
|
panel->hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 2);
|
||||||
#else
|
# else
|
||||||
panel->hbox = gtk_hbox_new(FALSE, 2);
|
panel->hbox = gtk_hbox_new(FALSE, 2);
|
||||||
#endif
|
# endif
|
||||||
/* battery */
|
/* battery */
|
||||||
panel->battery_timeout = 0;
|
panel->battery_timeout = 0;
|
||||||
panel->battery_level = -1;
|
panel->battery_level = -1;
|
||||||
|
@ -178,9 +187,9 @@ static Panel * _panel_init(PhonePluginHelper * helper)
|
||||||
&& strtol(p, NULL, 10) != 0)
|
&& strtol(p, NULL, 10) != 0)
|
||||||
gtk_label_set_ellipsize(GTK_LABEL(panel->operator),
|
gtk_label_set_ellipsize(GTK_LABEL(panel->operator),
|
||||||
PANGO_ELLIPSIZE_END);
|
PANGO_ELLIPSIZE_END);
|
||||||
#if GTK_CHECK_VERSION(2, 6, 0)
|
# if GTK_CHECK_VERSION(2, 6, 0)
|
||||||
gtk_label_set_max_width_chars(GTK_LABEL(panel->operator), 12);
|
gtk_label_set_max_width_chars(GTK_LABEL(panel->operator), 12);
|
||||||
#endif
|
# endif
|
||||||
gtk_widget_modify_font(panel->operator, bold);
|
gtk_widget_modify_font(panel->operator, bold);
|
||||||
gtk_box_pack_start(GTK_BOX(panel->hbox), panel->operator, TRUE, TRUE,
|
gtk_box_pack_start(GTK_BOX(panel->hbox), panel->operator, TRUE, TRUE,
|
||||||
0);
|
0);
|
||||||
|
@ -188,16 +197,16 @@ static Panel * _panel_init(PhonePluginHelper * helper)
|
||||||
/* connection status */
|
/* connection status */
|
||||||
panel->data = gtk_image_new_from_icon_name("stock_internet",
|
panel->data = gtk_image_new_from_icon_name("stock_internet",
|
||||||
GTK_ICON_SIZE_SMALL_TOOLBAR);
|
GTK_ICON_SIZE_SMALL_TOOLBAR);
|
||||||
#if GTK_CHECK_VERSION(2, 12, 0)
|
# if GTK_CHECK_VERSION(2, 12, 0)
|
||||||
gtk_widget_set_tooltip_text(panel->data, "Connected to GPRS");
|
gtk_widget_set_tooltip_text(panel->data, "Connected to GPRS");
|
||||||
#endif
|
# endif
|
||||||
gtk_widget_set_no_show_all(panel->data, TRUE);
|
gtk_widget_set_no_show_all(panel->data, TRUE);
|
||||||
gtk_box_pack_start(GTK_BOX(panel->hbox), panel->data, FALSE, TRUE, 0);
|
gtk_box_pack_start(GTK_BOX(panel->hbox), panel->data, FALSE, TRUE, 0);
|
||||||
panel->roaming = gtk_image_new_from_icon_name("phone-roaming",
|
panel->roaming = gtk_image_new_from_icon_name("phone-roaming",
|
||||||
GTK_ICON_SIZE_SMALL_TOOLBAR);
|
GTK_ICON_SIZE_SMALL_TOOLBAR);
|
||||||
#if GTK_CHECK_VERSION(2, 12, 0)
|
# if GTK_CHECK_VERSION(2, 12, 0)
|
||||||
gtk_widget_set_tooltip_text(panel->roaming, "Roaming");
|
gtk_widget_set_tooltip_text(panel->roaming, "Roaming");
|
||||||
#endif
|
# endif
|
||||||
gtk_widget_set_no_show_all(panel->roaming, TRUE);
|
gtk_widget_set_no_show_all(panel->roaming, TRUE);
|
||||||
gtk_box_pack_start(GTK_BOX(panel->hbox), panel->roaming, FALSE, TRUE,
|
gtk_box_pack_start(GTK_BOX(panel->hbox), panel->roaming, FALSE, TRUE,
|
||||||
0);
|
0);
|
||||||
|
@ -208,15 +217,22 @@ static Panel * _panel_init(PhonePluginHelper * helper)
|
||||||
pango_font_description_free(bold);
|
pango_font_description_free(bold);
|
||||||
_on_plug_delete_event(panel);
|
_on_plug_delete_event(panel);
|
||||||
return panel;
|
return panel;
|
||||||
|
#else
|
||||||
|
(void) helper;
|
||||||
|
|
||||||
|
error_set_code(-ENOSYS, "%s", "X11 support not detected");
|
||||||
|
return NULL;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
static gboolean _on_plug_delete_event(gpointer data)
|
static gboolean _on_plug_delete_event(gpointer data)
|
||||||
{
|
{
|
||||||
Panel * panel = data;
|
Panel * panel = data;
|
||||||
|
|
||||||
#ifdef DEBUG
|
# ifdef DEBUG
|
||||||
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
||||||
#endif
|
# endif
|
||||||
if(panel->timeout == 0)
|
if(panel->timeout == 0)
|
||||||
panel->timeout = g_timeout_add(5000, _on_plug_delete_event,
|
panel->timeout = g_timeout_add(5000, _on_plug_delete_event,
|
||||||
panel);
|
panel);
|
||||||
|
@ -230,9 +246,9 @@ static void _on_plug_embedded(gpointer data)
|
||||||
Panel * panel = data;
|
Panel * panel = data;
|
||||||
PhonePluginHelper * helper = panel->helper;
|
PhonePluginHelper * helper = panel->helper;
|
||||||
|
|
||||||
#ifdef DEBUG
|
# ifdef DEBUG
|
||||||
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
||||||
#endif
|
# endif
|
||||||
if(panel->timeout != 0)
|
if(panel->timeout != 0)
|
||||||
g_source_remove(panel->timeout);
|
g_source_remove(panel->timeout);
|
||||||
panel->timeout = 0;
|
panel->timeout = 0;
|
||||||
|
@ -250,25 +266,33 @@ static gboolean _on_battery_timeout(gpointer data)
|
||||||
panel->helper->request(panel->helper->phone, &request);
|
panel->helper->request(panel->helper->phone, &request);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* panel_destroy */
|
/* panel_destroy */
|
||||||
static void _panel_destroy(Panel * panel)
|
static void _panel_destroy(Panel * panel)
|
||||||
{
|
{
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
if(panel->battery_timeout != 0)
|
if(panel->battery_timeout != 0)
|
||||||
g_source_remove(panel->battery_timeout);
|
g_source_remove(panel->battery_timeout);
|
||||||
if(panel->timeout != 0)
|
if(panel->timeout != 0)
|
||||||
g_source_remove(panel->timeout);
|
g_source_remove(panel->timeout);
|
||||||
gtk_widget_destroy(panel->hbox);
|
gtk_widget_destroy(panel->hbox);
|
||||||
object_delete(panel);
|
object_delete(panel);
|
||||||
|
#else
|
||||||
|
(void) panel;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* panel_event */
|
/* panel_event */
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
static int _event_modem_event(Panel * panel, ModemEvent * event);
|
static int _event_modem_event(Panel * panel, ModemEvent * event);
|
||||||
|
#endif
|
||||||
|
|
||||||
static int _panel_event(Panel * panel, PhoneEvent * event)
|
static int _panel_event(Panel * panel, PhoneEvent * event)
|
||||||
{
|
{
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
switch(event->type)
|
switch(event->type)
|
||||||
{
|
{
|
||||||
case PHONE_EVENT_TYPE_MODEM_EVENT:
|
case PHONE_EVENT_TYPE_MODEM_EVENT:
|
||||||
|
@ -297,9 +321,15 @@ static int _panel_event(Panel * panel, PhoneEvent * event)
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
(void) panel;
|
||||||
|
(void) event;
|
||||||
|
|
||||||
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
static int _event_modem_event(Panel * panel, ModemEvent * event)
|
static int _event_modem_event(Panel * panel, ModemEvent * event)
|
||||||
{
|
{
|
||||||
char const * media = "";
|
char const * media = "";
|
||||||
|
@ -328,8 +358,10 @@ static int _event_modem_event(Panel * panel, ModemEvent * event)
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
/* panel_set_battery_level */
|
/* panel_set_battery_level */
|
||||||
static void _set_battery_image(Panel * panel, PanelBattery battery,
|
static void _set_battery_image(Panel * panel, PanelBattery battery,
|
||||||
gboolean charging);
|
gboolean charging);
|
||||||
|
@ -337,20 +369,20 @@ static void _set_battery_image(Panel * panel, PanelBattery battery,
|
||||||
static void _panel_set_battery_level(Panel * panel, gdouble level,
|
static void _panel_set_battery_level(Panel * panel, gdouble level,
|
||||||
gboolean charging)
|
gboolean charging)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG
|
# ifdef DEBUG
|
||||||
fprintf(stderr, "DEBUG: %s(panel, %f)\n", __func__, level);
|
fprintf(stderr, "DEBUG: %s(panel, %f)\n", __func__, level);
|
||||||
#endif
|
# endif
|
||||||
#if GTK_CHECK_VERSION(2, 12, 0)
|
# if GTK_CHECK_VERSION(2, 12, 0)
|
||||||
char buf[32];
|
char buf[32];
|
||||||
|
|
||||||
snprintf(buf, sizeof(buf), "%.0f%%%s", level * 100.0, charging
|
snprintf(buf, sizeof(buf), "%.0f%%%s", level * 100.0, charging
|
||||||
? " (charging)" : "");
|
? " (charging)" : "");
|
||||||
#endif
|
# endif
|
||||||
if(level < 0.0)
|
if(level < 0.0)
|
||||||
{
|
{
|
||||||
#if GTK_CHECK_VERSION(2, 12, 0)
|
# if GTK_CHECK_VERSION(2, 12, 0)
|
||||||
snprintf(buf, sizeof(buf), "%s", "Unknown status");
|
snprintf(buf, sizeof(buf), "%s", "Unknown status");
|
||||||
#endif
|
# endif
|
||||||
_set_battery_image(panel, PANEL_BATTERY_UNKNOWN, charging);
|
_set_battery_image(panel, PANEL_BATTERY_UNKNOWN, charging);
|
||||||
}
|
}
|
||||||
else if(level <= 0.01)
|
else if(level <= 0.01)
|
||||||
|
@ -365,14 +397,14 @@ static void _panel_set_battery_level(Panel * panel, gdouble level,
|
||||||
_set_battery_image(panel, PANEL_BATTERY_FULL, charging);
|
_set_battery_image(panel, PANEL_BATTERY_FULL, charging);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
#if GTK_CHECK_VERSION(2, 12, 0)
|
# if GTK_CHECK_VERSION(2, 12, 0)
|
||||||
snprintf(buf, sizeof(buf), "%s", "Error");
|
snprintf(buf, sizeof(buf), "%s", "Error");
|
||||||
#endif
|
# endif
|
||||||
_set_battery_image(panel, PANEL_BATTERY_ERROR, FALSE);
|
_set_battery_image(panel, PANEL_BATTERY_ERROR, FALSE);
|
||||||
}
|
}
|
||||||
#if GTK_CHECK_VERSION(2, 12, 0)
|
# if GTK_CHECK_VERSION(2, 12, 0)
|
||||||
gtk_widget_set_tooltip_text(panel->battery_image, buf);
|
gtk_widget_set_tooltip_text(panel->battery_image, buf);
|
||||||
#endif
|
# endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _set_battery_image(Panel * panel, PanelBattery battery,
|
static void _set_battery_image(Panel * panel, PanelBattery battery,
|
||||||
|
@ -489,15 +521,19 @@ static void _panel_set_status(Panel * panel, gboolean data, gboolean roaming)
|
||||||
else
|
else
|
||||||
gtk_widget_hide(panel->roaming);
|
gtk_widget_hide(panel->roaming);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* panel_settings */
|
/* panel_settings */
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
static void _on_settings_cancel(gpointer data);
|
static void _on_settings_cancel(gpointer data);
|
||||||
static gboolean _on_settings_closex(gpointer data);
|
static gboolean _on_settings_closex(gpointer data);
|
||||||
static void _on_settings_ok(gpointer data);
|
static void _on_settings_ok(gpointer data);
|
||||||
|
#endif
|
||||||
|
|
||||||
static void _panel_settings(Panel * panel)
|
static void _panel_settings(Panel * panel)
|
||||||
{
|
{
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
GtkWidget * vbox;
|
GtkWidget * vbox;
|
||||||
GtkWidget * bbox;
|
GtkWidget * bbox;
|
||||||
GtkWidget * widget;
|
GtkWidget * widget;
|
||||||
|
@ -510,17 +546,17 @@ static void _panel_settings(Panel * panel)
|
||||||
panel->window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
|
panel->window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
|
||||||
gtk_container_set_border_width(GTK_CONTAINER(panel->window), 4);
|
gtk_container_set_border_width(GTK_CONTAINER(panel->window), 4);
|
||||||
gtk_window_set_default_size(GTK_WINDOW(panel->window), 200, 300);
|
gtk_window_set_default_size(GTK_WINDOW(panel->window), 200, 300);
|
||||||
#if GTK_CHECK_VERSION(2, 6, 0)
|
# if GTK_CHECK_VERSION(2, 6, 0)
|
||||||
gtk_window_set_icon_name(GTK_WINDOW(panel->window), "gnome-settings");
|
gtk_window_set_icon_name(GTK_WINDOW(panel->window), "gnome-settings");
|
||||||
#endif
|
# endif
|
||||||
gtk_window_set_title(GTK_WINDOW(panel->window), "Panel preferences");
|
gtk_window_set_title(GTK_WINDOW(panel->window), "Panel preferences");
|
||||||
g_signal_connect_swapped(panel->window, "delete-event", G_CALLBACK(
|
g_signal_connect_swapped(panel->window, "delete-event", G_CALLBACK(
|
||||||
_on_settings_closex), panel);
|
_on_settings_closex), panel);
|
||||||
#if GTK_CHECK_VERSION(3, 0, 0)
|
# if GTK_CHECK_VERSION(3, 0, 0)
|
||||||
vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0);
|
vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0);
|
||||||
#else
|
# else
|
||||||
vbox = gtk_vbox_new(FALSE, 0);
|
vbox = gtk_vbox_new(FALSE, 0);
|
||||||
#endif
|
# endif
|
||||||
/* check button */
|
/* check button */
|
||||||
panel->battery = gtk_check_button_new_with_label(
|
panel->battery = gtk_check_button_new_with_label(
|
||||||
"Monitor battery activity");
|
"Monitor battery activity");
|
||||||
|
@ -529,11 +565,11 @@ static void _panel_settings(Panel * panel)
|
||||||
"Shorten the operator name");
|
"Shorten the operator name");
|
||||||
gtk_box_pack_start(GTK_BOX(vbox), panel->truncate, FALSE, TRUE, 0);
|
gtk_box_pack_start(GTK_BOX(vbox), panel->truncate, FALSE, TRUE, 0);
|
||||||
/* button box */
|
/* button box */
|
||||||
#if GTK_CHECK_VERSION(3, 0, 0)
|
# if GTK_CHECK_VERSION(3, 0, 0)
|
||||||
bbox = gtk_button_box_new(GTK_ORIENTATION_HORIZONTAL);
|
bbox = gtk_button_box_new(GTK_ORIENTATION_HORIZONTAL);
|
||||||
#else
|
# else
|
||||||
bbox = gtk_hbutton_box_new();
|
bbox = gtk_hbutton_box_new();
|
||||||
#endif
|
# endif
|
||||||
gtk_button_box_set_layout(GTK_BUTTON_BOX(bbox), GTK_BUTTONBOX_END);
|
gtk_button_box_set_layout(GTK_BUTTON_BOX(bbox), GTK_BUTTONBOX_END);
|
||||||
gtk_box_set_spacing(GTK_BOX(bbox), 4);
|
gtk_box_set_spacing(GTK_BOX(bbox), 4);
|
||||||
widget = gtk_button_new_from_stock(GTK_STOCK_CANCEL);
|
widget = gtk_button_new_from_stock(GTK_STOCK_CANCEL);
|
||||||
|
@ -548,8 +584,13 @@ static void _panel_settings(Panel * panel)
|
||||||
gtk_container_add(GTK_CONTAINER(panel->window), vbox);
|
gtk_container_add(GTK_CONTAINER(panel->window), vbox);
|
||||||
_on_settings_cancel(panel);
|
_on_settings_cancel(panel);
|
||||||
gtk_widget_show_all(panel->window);
|
gtk_widget_show_all(panel->window);
|
||||||
|
#else
|
||||||
|
(void) panel;
|
||||||
|
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
static void _on_settings_cancel(gpointer data)
|
static void _on_settings_cancel(gpointer data)
|
||||||
{
|
{
|
||||||
Panel * panel = data;
|
Panel * panel = data;
|
||||||
|
@ -610,3 +651,4 @@ static void _on_settings_ok(gpointer data)
|
||||||
helper->config_set(helper->phone, "panel", "truncate", value
|
helper->config_set(helper->phone, "panel", "truncate", value
|
||||||
? "1" : "0");
|
? "1" : "0");
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue
Block a user