get rid of str_array

This commit is contained in:
Sascha Kruse 2013-02-17 03:38:48 +01:00
parent 5e66f5d007
commit 74bae9ee0b
6 changed files with 13 additions and 79 deletions

View File

@ -3,7 +3,7 @@
include config.mk include config.mk
SRC = draw.c dunst.c container.c dunst_dbus.c utils.c options.c SRC = draw.c dunst.c dunst_dbus.c utils.c options.c
OBJ = ${SRC:.c=.o} OBJ = ${SRC:.c=.o}
all: doc options dunst service all: doc options dunst service

View File

@ -1,43 +0,0 @@
#include "stdlib.h"
#include "stdio.h"
#include <string.h>
#include "container.h"
str_array *str_array_malloc(void)
{
str_array *a = malloc(sizeof(str_array));
a->count = 0;
a->strs = NULL;
return a;
}
void str_array_append(str_array *a, char *str)
{
if (!a)
return;
a->count++;
a->strs = realloc(a->strs, a->count * sizeof(char *));
(a->strs)[a->count-1] = str;
}
void str_array_dup_append(str_array *a, const char *str)
{
if (!a)
return;
char *dup = g_strdup(str);
str_array_append(a, dup);
}
void str_array_deep_free(str_array *a)
{
if (!a)
return;
for (int i = 0; i < a->count; i++) {
free((a->strs)[i]);
}
free(a);
}
/* vim: set ts=8 sw=8 tw=0: */

View File

@ -1,17 +0,0 @@
#ifndef _LIST_H
#define _LIST_H
#include "dunst.h"
typedef struct _str_array {
int count;
char **strs;
} str_array;
str_array *str_array_malloc(void);
void str_array_dup_append(str_array *a, const char *str);
void str_array_append(str_array *a, char *str);
void str_array_deep_free(str_array *a);
#endif
/* vim: set ts=8 sw=8 tw=0: */

25
dunst.c
View File

@ -31,7 +31,6 @@
#include "dunst.h" #include "dunst.h"
#include "draw.h" #include "draw.h"
#include "dunst_dbus.h" #include "dunst_dbus.h"
#include "container.h"
#include "utils.h" #include "utils.h"
#include "options.h" #include "options.h"
@ -108,7 +107,7 @@ void draw_win(void);
void hide_win(void); void hide_win(void);
void move_all_to_history(void); void move_all_to_history(void);
void print_version(void); void print_version(void);
str_array *extract_urls(const char *str); char *extract_urls(const char *str);
void context_menu(void); void context_menu(void);
void run_script(notification *n); void run_script(notification *n);
@ -135,7 +134,7 @@ int cmp_notification_data(const void *va, const void *vb, void *data)
} }
str_array *extract_urls( const char * to_match) char *extract_urls( const char * to_match)
{ {
static bool is_initialized = false; static bool is_initialized = false;
static regex_t cregex; static regex_t cregex;
@ -151,7 +150,7 @@ str_array *extract_urls( const char * to_match)
} }
} }
str_array *urls = str_array_malloc(); char *urls = NULL;
const char * p = to_match; const char * p = to_match;
regmatch_t m; regmatch_t m;
@ -171,12 +170,10 @@ str_array *extract_urls( const char * to_match)
char *match = strndup(to_match+start, finish-start); char *match = strndup(to_match+start, finish-start);
str_array_append(urls, match); urls = string_append(urls, match, "\n");
p += m.rm_eo; p += m.rm_eo;
} }
return 0;
return urls; return urls;
} }
@ -184,10 +181,8 @@ void context_menu(void) {
char *dmenu_input = NULL; char *dmenu_input = NULL;
for (GList *iter = g_queue_peek_head_link(displayed); iter; iter = iter->next) { for (GList *iter = g_queue_peek_head_link(displayed); iter; iter = iter->next) {
for (int i = 0; i < ((notification*)iter->data)->urls->count; i++) { notification *n = iter->data;
dmenu_input = string_append(dmenu_input, dmenu_input = string_append(dmenu_input, n->urls, "\n");
(((notification*)iter->data)->urls->strs)[i], "\n");
}
} }
@ -332,12 +327,12 @@ static void print_notification(notification * n)
printf("\turgency: %d\n", n->urgency); printf("\turgency: %d\n", n->urgency);
printf("\tformatted: '%s'\n", n->msg); printf("\tformatted: '%s'\n", n->msg);
printf("\tid: %d\n", n->id); printf("\tid: %d\n", n->id);
printf("urls\n"); if (n->urls) {
printf("\turls\n");
printf("\t{\n"); printf("\t{\n");
for (int i = 0; i < n->urls->count; i++) { printf("%s\n", n->urls);
printf("\t\t%s\n", (n->urls->strs)[i]);
}
printf("\t}\n"); printf("\t}\n");
}
printf("\tscript: %s\n", n->script); printf("\tscript: %s\n", n->script);
printf("}\n"); printf("}\n");
} }

View File

@ -57,7 +57,7 @@ typedef struct _notification {
int progress; /* percentage + 1, 0 to hide */ int progress; /* percentage + 1, 0 to hide */
int line_count; int line_count;
const char *script; const char *script;
struct { int count; char **strs; } *urls; char *urls;
} notification; } notification;
typedef struct _rule_t { typedef struct _rule_t {

View File

@ -4,7 +4,6 @@
#include <dbus/dbus.h> #include <dbus/dbus.h>
#include "dunst.h" #include "dunst.h"
#include "container.h"
#include "dunst_dbus.h" #include "dunst_dbus.h"