more tint2conf cleanup
git-svn-id: http://tint2.googlecode.com/svn/trunk@234 121b4492-b84c-0410-8b4c-0d4edfb3f3cc
This commit is contained in:
parent
97a1e6f6c4
commit
698f253f96
6 changed files with 183 additions and 133 deletions
|
@ -31,12 +31,12 @@ AM_CONDITIONAL([INSTALL_EXAMPLES], [test x$examples = xtrue])
|
|||
|
||||
# tint2conf
|
||||
AC_ARG_ENABLE([tint2conf],
|
||||
[AS_HELP_STRING([--enable-tint2conf], [Build and install tint2conf, a GTK+2 configuration utility for tint2 (EXPERIMENTAL)])],
|
||||
[AS_HELP_STRING([--disable-tint2conf], [Disable tint2conf build, a GTK+2 theme switcher for tint2])],
|
||||
[case "${enableval}" in
|
||||
yes) tint2conf=true ;;
|
||||
no) tint2conf=false ;;
|
||||
*) AC_MSG_ERROR([bad value ${enableval} for --enable-tint2conf]) ;;
|
||||
esac],[tint2conf=false])
|
||||
*) AC_MSG_ERROR([bad value ${enableval} for --disable-tint2conf]) ;;
|
||||
esac],[tint2conf=true])
|
||||
AM_CONDITIONAL([ENABLE_TINT2CONF], [test x$tint2conf = xtrue])
|
||||
#
|
||||
|
||||
|
|
111
src/config.c
111
src/config.c
|
@ -100,25 +100,6 @@ void cleanup_config()
|
|||
}
|
||||
|
||||
|
||||
void copy_file(const char *pathSrc, const char *pathDest)
|
||||
{
|
||||
FILE *fileSrc, *fileDest;
|
||||
char line[100];
|
||||
int nb;
|
||||
|
||||
fileSrc = fopen(pathSrc, "rb");
|
||||
if (fileSrc == NULL) return;
|
||||
|
||||
fileDest = fopen(pathDest, "wb");
|
||||
if (fileDest == NULL) return;
|
||||
|
||||
while ((nb = fread(line, 1, 100, fileSrc)) > 0) fwrite(line, 1, nb, fileDest);
|
||||
|
||||
fclose (fileDest);
|
||||
fclose (fileSrc);
|
||||
}
|
||||
|
||||
|
||||
void extract_values (const char *value, char **value1, char **value2, char **value3)
|
||||
{
|
||||
char *b=0, *c=0;
|
||||
|
@ -158,58 +139,6 @@ void extract_values (const char *value, char **value1, char **value2, char **val
|
|||
}
|
||||
|
||||
|
||||
int hex_char_to_int (char c)
|
||||
{
|
||||
int r;
|
||||
|
||||
if (c >= '0' && c <= '9') r = c - '0';
|
||||
else if (c >= 'a' && c <= 'f') r = c - 'a' + 10;
|
||||
else if (c >= 'A' && c <= 'F') r = c - 'A' + 10;
|
||||
else r = 0;
|
||||
|
||||
return r;
|
||||
}
|
||||
|
||||
|
||||
int hex_to_rgb (char *hex, int *r, int *g, int *b)
|
||||
{
|
||||
int len;
|
||||
|
||||
if (hex == NULL || hex[0] != '#') return (0);
|
||||
|
||||
len = strlen (hex);
|
||||
if (len == 3 + 1) {
|
||||
*r = hex_char_to_int (hex[1]);
|
||||
*g = hex_char_to_int (hex[2]);
|
||||
*b = hex_char_to_int (hex[3]);
|
||||
}
|
||||
else if (len == 6 + 1) {
|
||||
*r = hex_char_to_int (hex[1]) * 16 + hex_char_to_int (hex[2]);
|
||||
*g = hex_char_to_int (hex[3]) * 16 + hex_char_to_int (hex[4]);
|
||||
*b = hex_char_to_int (hex[5]) * 16 + hex_char_to_int (hex[6]);
|
||||
}
|
||||
else if (len == 12 + 1) {
|
||||
*r = hex_char_to_int (hex[1]) * 16 + hex_char_to_int (hex[2]);
|
||||
*g = hex_char_to_int (hex[5]) * 16 + hex_char_to_int (hex[6]);
|
||||
*b = hex_char_to_int (hex[9]) * 16 + hex_char_to_int (hex[10]);
|
||||
}
|
||||
else return 0;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
void get_color (char *hex, double *rgb)
|
||||
{
|
||||
int r, g, b;
|
||||
hex_to_rgb (hex, &r, &g, &b);
|
||||
|
||||
rgb[0] = (r / 255.0);
|
||||
rgb[1] = (g / 255.0);
|
||||
rgb[2] = (b / 255.0);
|
||||
}
|
||||
|
||||
|
||||
void get_action (char *event, int *action)
|
||||
{
|
||||
if (strcmp (event, "none") == 0)
|
||||
|
@ -709,35 +638,6 @@ void add_entry (char *key, char *value)
|
|||
}
|
||||
|
||||
|
||||
int parse_line (const char *line)
|
||||
{
|
||||
char *a, *b, *key, *value;
|
||||
|
||||
/* Skip useless lines */
|
||||
if ((line[0] == '#') || (line[0] == '\n')) return 0;
|
||||
if (!(a = strchr (line, '='))) return 0;
|
||||
|
||||
/* overwrite '=' with '\0' */
|
||||
a[0] = '\0';
|
||||
key = strdup (line);
|
||||
a++;
|
||||
|
||||
/* overwrite '\n' with '\0' if '\n' present */
|
||||
if ((b = strchr (a, '\n'))) b[0] = '\0';
|
||||
|
||||
value = strdup (a);
|
||||
|
||||
g_strstrip(key);
|
||||
g_strstrip(value);
|
||||
|
||||
add_entry (key, value);
|
||||
|
||||
free (key);
|
||||
free (value);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
void config_finish ()
|
||||
{
|
||||
if (panel_config.monitor > (server.nb_monitor-1)) {
|
||||
|
@ -830,15 +730,20 @@ int config_read_file (const char *path)
|
|||
{
|
||||
FILE *fp;
|
||||
char line[80];
|
||||
char *key, *value;
|
||||
|
||||
if ((fp = fopen(path, "r")) == NULL) return 0;
|
||||
old_task_font = 0;
|
||||
old_time1_font = 0;
|
||||
old_time2_font = 0;
|
||||
|
||||
while (fgets(line, sizeof(line), fp) != NULL)
|
||||
parse_line (line);
|
||||
|
||||
while (fgets(line, sizeof(line), fp) != NULL) {
|
||||
if (parse_line(line, &key, &value)) {
|
||||
add_entry (key, value);
|
||||
free (key);
|
||||
free (value);
|
||||
}
|
||||
}
|
||||
fclose (fp);
|
||||
|
||||
if (save_file_config)
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
if ENABLE_TINT2CONF
|
||||
bin_PROGRAMS = tint2conf
|
||||
tint2conf_SOURCES = main.c
|
||||
tint2conf_SOURCES = main.c ../util/common.c
|
||||
INCLUDES = -I../util
|
||||
|
||||
AM_CFLAGS += @TINT2CONF_CFLAGS@
|
||||
LIBS += @TINT2CONF_LIBS@
|
||||
|
|
|
@ -24,6 +24,8 @@
|
|||
#include <glib/gstdio.h>
|
||||
#include <glib/gi18n.h>
|
||||
|
||||
#include "common.h"
|
||||
|
||||
|
||||
// TODO
|
||||
// ** add, saveas
|
||||
|
@ -75,6 +77,9 @@ static void init_list(GtkWidget *list);
|
|||
static void add_to_list(GtkWidget *list, const gchar *str);
|
||||
void on_changed(GtkWidget *widget, gpointer label);
|
||||
|
||||
void read_config(char **defaultTheme);
|
||||
void write_config(char *defaultTheme);
|
||||
void check_theme();
|
||||
|
||||
|
||||
// define menubar and toolbar
|
||||
|
@ -136,7 +141,7 @@ int main (int argc, char ** argv)
|
|||
|
||||
gtk_init (&argc, &argv);
|
||||
g_thread_init( NULL );
|
||||
checkConfig();
|
||||
check_theme();
|
||||
|
||||
// define main layout : container, menubar, toolbar
|
||||
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
|
||||
|
@ -314,7 +319,6 @@ static void menuDelete (void)
|
|||
|
||||
static void menuProperties (void)
|
||||
{
|
||||
printf("menuProperties\n");
|
||||
system("python /home/thil/Desktop/tintwizard/tintwizard.py");
|
||||
}
|
||||
|
||||
|
@ -355,9 +359,11 @@ static void menuApply (void)
|
|||
gtk_tree_model_get(model, &iter, LIST_ITEM, &value, -1);
|
||||
name1 = g_build_filename (g_get_user_config_dir(), "tint2", value, NULL);
|
||||
name2 = g_strdup_printf("%s.tint2rc", name1);
|
||||
copy_file(name2, pathConfig);
|
||||
g_free(value);
|
||||
g_free(name1);
|
||||
|
||||
copy_file(name2, pathConfig);
|
||||
write_config(value);
|
||||
g_free(value);
|
||||
g_free(name2);
|
||||
|
||||
// restart panel
|
||||
|
@ -395,12 +401,64 @@ static void loadTheme(GtkWidget *list)
|
|||
}
|
||||
}
|
||||
g_dir_close(dir);
|
||||
|
||||
// search default theme
|
||||
GtkTreeIter iter;
|
||||
GtkTreeModel *model;
|
||||
name = NULL;
|
||||
read_config(&name);
|
||||
if (name) {
|
||||
printf("defaultTheme %s\n", name);
|
||||
//gtk_tree_selection_select_iter(GtkTreeSelection *selection, GtkTreeIter *iter);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// config file management
|
||||
// theme file management
|
||||
void read_config(char **defaultTheme)
|
||||
{
|
||||
char *path;
|
||||
|
||||
void checkConfig()
|
||||
path = g_build_filename (g_get_user_config_dir(), "tint2", "tint2confrc", NULL);
|
||||
if (g_file_test (path, G_FILE_TEST_EXISTS)) {
|
||||
FILE *fp;
|
||||
char line[80];
|
||||
char *key, *value;
|
||||
if ((fp = fopen(path, "r")) != NULL) {
|
||||
while (fgets(line, sizeof(line), fp) != NULL) {
|
||||
if (parse_line(line, &key, &value)) {
|
||||
if (strcmp (key, "default_theme") == 0) {
|
||||
*defaultTheme = strdup (value);
|
||||
}
|
||||
free (key);
|
||||
free (value);
|
||||
}
|
||||
}
|
||||
fclose (fp);
|
||||
}
|
||||
}
|
||||
g_free(path);
|
||||
}
|
||||
|
||||
|
||||
void write_config(char *defaultTheme)
|
||||
{
|
||||
char *path;
|
||||
FILE *fp;
|
||||
|
||||
path = g_build_filename (g_get_user_config_dir(), "tint2", "tint2confrc", NULL);
|
||||
fp = fopen(path, "w");
|
||||
if (fp != NULL) {
|
||||
fputs("#---------------------------------------------\n", fp);
|
||||
fputs("# TINT2CONF CONFIG FILE\n", fp);
|
||||
fprintf(fp, "default_theme = %s\n\n", defaultTheme);
|
||||
fclose (fp);
|
||||
}
|
||||
g_free(path);
|
||||
}
|
||||
|
||||
|
||||
void check_theme()
|
||||
{
|
||||
pathDir = g_build_filename (g_get_user_config_dir(), "tint2", NULL);
|
||||
if (!g_file_test (pathDir, G_FILE_TEST_IS_DIR))
|
||||
|
@ -411,25 +469,6 @@ void checkConfig()
|
|||
}
|
||||
|
||||
|
||||
void copy_file(const char *pathSrc, const char *pathDest)
|
||||
{
|
||||
FILE *fileSrc, *fileDest;
|
||||
char line[100];
|
||||
int nb;
|
||||
|
||||
fileSrc = fopen(pathSrc, "rb");
|
||||
if (fileSrc == NULL) return;
|
||||
|
||||
fileDest = fopen(pathDest, "wb");
|
||||
if (fileDest == NULL) return;
|
||||
|
||||
while ((nb = fread(line, 1, 100, fileSrc)) > 0) fwrite(line, 1, nb, fileDest);
|
||||
|
||||
fclose (fileDest);
|
||||
fclose (fileSrc);
|
||||
}
|
||||
|
||||
|
||||
static void add_to_list(GtkWidget *list, const gchar *str)
|
||||
{
|
||||
GtkListStore *store;
|
||||
|
|
|
@ -30,6 +30,101 @@
|
|||
|
||||
|
||||
|
||||
void copy_file(const char *pathSrc, const char *pathDest)
|
||||
{
|
||||
FILE *fileSrc, *fileDest;
|
||||
char line[100];
|
||||
int nb;
|
||||
|
||||
fileSrc = fopen(pathSrc, "rb");
|
||||
if (fileSrc == NULL) return;
|
||||
|
||||
fileDest = fopen(pathDest, "wb");
|
||||
if (fileDest == NULL) return;
|
||||
|
||||
while ((nb = fread(line, 1, 100, fileSrc)) > 0) fwrite(line, 1, nb, fileDest);
|
||||
|
||||
fclose (fileDest);
|
||||
fclose (fileSrc);
|
||||
}
|
||||
|
||||
|
||||
int parse_line (const char *line, char **key, char **value)
|
||||
{
|
||||
char *a, *b;
|
||||
|
||||
/* Skip useless lines */
|
||||
if ((line[0] == '#') || (line[0] == '\n')) return 0;
|
||||
if (!(a = strchr (line, '='))) return 0;
|
||||
|
||||
/* overwrite '=' with '\0' */
|
||||
a[0] = '\0';
|
||||
*key = strdup (line);
|
||||
a++;
|
||||
|
||||
/* overwrite '\n' with '\0' if '\n' present */
|
||||
if ((b = strchr (a, '\n'))) b[0] = '\0';
|
||||
|
||||
*value = strdup (a);
|
||||
|
||||
g_strstrip(*key);
|
||||
g_strstrip(*value);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
int hex_char_to_int (char c)
|
||||
{
|
||||
int r;
|
||||
|
||||
if (c >= '0' && c <= '9') r = c - '0';
|
||||
else if (c >= 'a' && c <= 'f') r = c - 'a' + 10;
|
||||
else if (c >= 'A' && c <= 'F') r = c - 'A' + 10;
|
||||
else r = 0;
|
||||
|
||||
return r;
|
||||
}
|
||||
|
||||
|
||||
int hex_to_rgb (char *hex, int *r, int *g, int *b)
|
||||
{
|
||||
int len;
|
||||
|
||||
if (hex == NULL || hex[0] != '#') return (0);
|
||||
|
||||
len = strlen (hex);
|
||||
if (len == 3 + 1) {
|
||||
*r = hex_char_to_int (hex[1]);
|
||||
*g = hex_char_to_int (hex[2]);
|
||||
*b = hex_char_to_int (hex[3]);
|
||||
}
|
||||
else if (len == 6 + 1) {
|
||||
*r = hex_char_to_int (hex[1]) * 16 + hex_char_to_int (hex[2]);
|
||||
*g = hex_char_to_int (hex[3]) * 16 + hex_char_to_int (hex[4]);
|
||||
*b = hex_char_to_int (hex[5]) * 16 + hex_char_to_int (hex[6]);
|
||||
}
|
||||
else if (len == 12 + 1) {
|
||||
*r = hex_char_to_int (hex[1]) * 16 + hex_char_to_int (hex[2]);
|
||||
*g = hex_char_to_int (hex[5]) * 16 + hex_char_to_int (hex[6]);
|
||||
*b = hex_char_to_int (hex[9]) * 16 + hex_char_to_int (hex[10]);
|
||||
}
|
||||
else return 0;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
void get_color (char *hex, double *rgb)
|
||||
{
|
||||
int r, g, b;
|
||||
hex_to_rgb (hex, &r, &g, &b);
|
||||
|
||||
rgb[0] = (r / 255.0);
|
||||
rgb[1] = (g / 255.0);
|
||||
rgb[2] = (b / 255.0);
|
||||
}
|
||||
|
||||
|
||||
void adjust_asb(DATA32 *data, int w, int h, int alpha, float satur, float bright)
|
||||
{
|
||||
unsigned int x, y;
|
||||
|
|
|
@ -50,10 +50,20 @@ typedef struct config_color
|
|||
} config_color;
|
||||
|
||||
|
||||
// copy file source to file dest
|
||||
void copy_file(const char *pathSrc, const char *pathDest);
|
||||
|
||||
// extract key = value
|
||||
int parse_line (const char *line, char **key, char **value);
|
||||
|
||||
// conversion
|
||||
int hex_char_to_int (char c);
|
||||
int hex_to_rgb (char *hex, int *r, int *g, int *b);
|
||||
void get_color (char *hex, double *rgb);
|
||||
|
||||
// adjust Alpha/Saturation/Brightness on an ARGB icon
|
||||
// alpha from 0 to 100, satur from 0 to 1, bright from 0 to 1.
|
||||
void adjust_asb(DATA32 *data, int w, int h, int alpha, float satur, float bright);
|
||||
|
||||
|
||||
#endif
|
||||
|
||||
|
|
Loading…
Reference in a new issue