mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-15 19:56:55 +00:00
cpp-ify prioqueue.c and use free_and_zero in [p-r]*.cc where appropriate
This commit is contained in:
parent
6092d063c9
commit
4afe96b9ce
@ -37,7 +37,7 @@ endif(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/build.h)
|
|||||||
set(conky_sources colours.cc combine.cc common.cc conky.cc core.cc
|
set(conky_sources colours.cc combine.cc common.cc conky.cc core.cc
|
||||||
diskio.cc entropy.cc exec.cc fs.cc mail.cc mixer.cc net_stat.cc template.cc
|
diskio.cc entropy.cc exec.cc fs.cc mail.cc mixer.cc net_stat.cc template.cc
|
||||||
mboxscan.cc read_tcp.cc scroll.cc specials.cc tailhead.cc
|
mboxscan.cc read_tcp.cc scroll.cc specials.cc tailhead.cc
|
||||||
temphelper.cc text_object.cc timeinfo.cc top.cc algebra.cc prioqueue.c proc.cc
|
temphelper.cc text_object.cc timeinfo.cc top.cc algebra.cc prioqueue.cc proc.cc
|
||||||
user.cc)
|
user.cc)
|
||||||
|
|
||||||
# add timed thread library
|
# add timed thread library
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "conky.h"
|
||||||
#include <limits.h> /* INT_MAX */
|
#include <limits.h> /* INT_MAX */
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@ -69,7 +70,7 @@ struct prio_queue *init_prio_queue(void)
|
|||||||
{
|
{
|
||||||
struct prio_queue *retval;
|
struct prio_queue *retval;
|
||||||
|
|
||||||
retval = malloc(sizeof(struct prio_queue));
|
retval = (struct prio_queue *) malloc(sizeof(struct prio_queue));
|
||||||
memset(retval, 0, sizeof(struct prio_queue));
|
memset(retval, 0, sizeof(struct prio_queue));
|
||||||
|
|
||||||
/* use pq_free_nop by default */
|
/* use pq_free_nop by default */
|
||||||
@ -110,7 +111,7 @@ static struct prio_elem *init_prio_elem(void *data)
|
|||||||
{
|
{
|
||||||
struct prio_elem *retval;
|
struct prio_elem *retval;
|
||||||
|
|
||||||
retval = malloc(sizeof(struct prio_elem));
|
retval = (struct prio_elem *) malloc(sizeof(struct prio_elem));
|
||||||
memset(retval, 0, sizeof(struct prio_elem));
|
memset(retval, 0, sizeof(struct prio_elem));
|
||||||
|
|
||||||
retval->data = data;
|
retval->data = data;
|
||||||
@ -171,8 +172,7 @@ check_cur_size:
|
|||||||
queue->cur_size--;
|
queue->cur_size--;
|
||||||
queue->tail = queue->tail->prev;
|
queue->tail = queue->tail->prev;
|
||||||
(*queue->free)(queue->tail->next->data);
|
(*queue->free)(queue->tail->next->data);
|
||||||
free(queue->tail->next);
|
free_and_zero(queue->tail->next);
|
||||||
queue->tail->next = NULL;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -25,9 +25,6 @@
|
|||||||
#ifndef _PRIOQUEUE_H
|
#ifndef _PRIOQUEUE_H
|
||||||
#define _PRIOQUEUE_H
|
#define _PRIOQUEUE_H
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
/* forward-define for private data */
|
/* forward-define for private data */
|
||||||
struct prio_queue;
|
struct prio_queue;
|
||||||
|
|
||||||
@ -66,8 +63,4 @@ void *pop_prio_elem(prio_queue_t);
|
|||||||
/* clear and free the given queue */
|
/* clear and free the given queue */
|
||||||
void free_prio_queue(prio_queue_t);
|
void free_prio_queue(prio_queue_t);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* _PRIOQUEUE_H */
|
#endif /* _PRIOQUEUE_H */
|
||||||
|
47
src/prss.cc
47
src/prss.cc
@ -49,19 +49,20 @@ void free_rss_items(PRSS *data)
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < data->item_count; i++) {
|
if(data->items) {
|
||||||
#define CLEAR(a) if (data->items[i].a) { free(data->items[i].a); data->items[i].a = 0; }
|
for (i = 0; i < data->item_count; i++) {
|
||||||
CLEAR(title);
|
#define CLEAR(a) free_and_zero(data->items[i].a);
|
||||||
CLEAR(link);
|
CLEAR(title);
|
||||||
CLEAR(description);
|
CLEAR(link);
|
||||||
CLEAR(category);
|
CLEAR(description);
|
||||||
CLEAR(pubDate);
|
CLEAR(category);
|
||||||
CLEAR(guid);
|
CLEAR(pubDate);
|
||||||
|
CLEAR(guid);
|
||||||
#undef CLEAR
|
#undef CLEAR
|
||||||
|
}
|
||||||
|
free_and_zero(data->items);
|
||||||
|
data->item_count = 0;
|
||||||
}
|
}
|
||||||
free(data->items);
|
|
||||||
data->item_count = 0;
|
|
||||||
data->items = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void prss_free(PRSS *data)
|
void prss_free(PRSS *data)
|
||||||
@ -69,16 +70,10 @@ void prss_free(PRSS *data)
|
|||||||
if (!data) {
|
if (!data) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (data->version) {
|
free_and_zero(data->version);
|
||||||
free(data->version);
|
free_rss_items(data);
|
||||||
data->version = 0;
|
|
||||||
}
|
|
||||||
if (data->items) {
|
|
||||||
free_rss_items(data);
|
|
||||||
}
|
|
||||||
data->version = 0;
|
data->version = 0;
|
||||||
data->items = 0;
|
#define CLEAR(a) free_and_zero(data->a);
|
||||||
#define CLEAR(a) if (data->a) { free(data->a); data->a = 0; }
|
|
||||||
CLEAR(title);
|
CLEAR(title);
|
||||||
CLEAR(link);
|
CLEAR(link);
|
||||||
CLEAR(description);
|
CLEAR(description);
|
||||||
@ -116,7 +111,7 @@ static inline void read_item(PRSS_Item *res, xmlNodePtr data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define ASSIGN(a) if (strcasecmp((const char*)data->name, #a) == EQUAL) { \
|
#define ASSIGN(a) if (strcasecmp((const char*)data->name, #a) == EQUAL) { \
|
||||||
if (res->a) free(res->a); \
|
free_and_zero(res->a); \
|
||||||
res->a = strdup((const char*)child->content); \
|
res->a = strdup((const char*)child->content); \
|
||||||
continue; \
|
continue; \
|
||||||
}
|
}
|
||||||
@ -143,7 +138,7 @@ static inline void read_element(PRSS *res, xmlNodePtr n)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define ASSIGN(a) if (strcasecmp((const char*)n->name, #a) == EQUAL) { \
|
#define ASSIGN(a) if (strcasecmp((const char*)n->name, #a) == EQUAL) { \
|
||||||
if (res->a) free(res->a); \
|
free_and_zero(res->a); \
|
||||||
res->a = strdup((const char*)child->content); \
|
res->a = strdup((const char*)child->content); \
|
||||||
return; \
|
return; \
|
||||||
}
|
}
|
||||||
@ -188,9 +183,9 @@ static inline int parse_rss_2_0(PRSS *res, xmlNodePtr root)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (res->version) free(res->version);
|
free_and_zero(res->version);
|
||||||
res->version = strndup("2.0", text_buffer_size);
|
res->version = strndup("2.0", text_buffer_size);
|
||||||
if (res->items) free_rss_items(res);
|
free_rss_items(res);
|
||||||
res->items = (PRSS_Item*) malloc(items * sizeof(PRSS_Item));
|
res->items = (PRSS_Item*) malloc(items * sizeof(PRSS_Item));
|
||||||
res->item_count = 0;
|
res->item_count = 0;
|
||||||
|
|
||||||
@ -221,9 +216,9 @@ static inline int parse_rss_1_0(PRSS *res, xmlNodePtr root)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (res->version) free(res->version);
|
free_and_zero(res->version);
|
||||||
res->version = strndup("1.0", text_buffer_size);
|
res->version = strndup("1.0", text_buffer_size);
|
||||||
if (res->items) free_rss_items(res);
|
free_rss_items(res);
|
||||||
res->items = (PRSS_Item*) malloc(items * sizeof(PRSS_Item));
|
res->items = (PRSS_Item*) malloc(items * sizeof(PRSS_Item));
|
||||||
res->item_count = 0;
|
res->item_count = 0;
|
||||||
|
|
||||||
|
@ -109,8 +109,6 @@ void free_read_tcp(struct text_object *obj)
|
|||||||
if (!rtd)
|
if (!rtd)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (rtd->host)
|
free_and_zero(rtd->host);
|
||||||
free(rtd->host);
|
free_and_zero(obj->data.opaque);
|
||||||
free(obj->data.opaque);
|
|
||||||
obj->data.opaque = NULL;
|
|
||||||
}
|
}
|
||||||
|
@ -183,8 +183,5 @@ void rss_print_info(struct text_object *obj, char *p, int p_max_size)
|
|||||||
|
|
||||||
void rss_free_obj_info(struct text_object *obj)
|
void rss_free_obj_info(struct text_object *obj)
|
||||||
{
|
{
|
||||||
if (obj->data.opaque) {
|
free_and_zero(obj->data.opaque);
|
||||||
free(obj->data.opaque);
|
|
||||||
obj->data.opaque = NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user