mirror of
https://github.com/Llewellynvdm/conky.git
synced 2024-11-17 18:45:10 +00:00
Clear stored graphs on config reload
Includes missed formatting from previous commit.
This commit is contained in:
parent
594d0c85ba
commit
dcc188ebe2
@ -100,6 +100,7 @@
|
||||
#include "mail.h"
|
||||
#include "nc.h"
|
||||
#include "net_stat.h"
|
||||
#include "specials.h"
|
||||
#include "temphelper.h"
|
||||
#include "template.h"
|
||||
#include "timeinfo.h"
|
||||
@ -2381,6 +2382,8 @@ void free_specials(special_t *¤t) {
|
||||
delete current;
|
||||
current = nullptr;
|
||||
}
|
||||
|
||||
clear_stored_graphs();
|
||||
}
|
||||
|
||||
void clean_up_without_threads(void *memtofree1, void *memtofree2) {
|
||||
|
@ -38,8 +38,8 @@
|
||||
#include <sys/param.h>
|
||||
#endif /* HAVE_SYS_PARAM_H */
|
||||
#include <algorithm>
|
||||
#include <sstream>
|
||||
#include <map>
|
||||
#include <sstream>
|
||||
#include "colours.h"
|
||||
#include "common.h"
|
||||
#include "conky.h"
|
||||
@ -49,7 +49,7 @@ struct special_t *specials = nullptr;
|
||||
int special_count;
|
||||
int graph_count = 0;
|
||||
|
||||
std::map<int, double*> graphs;
|
||||
std::map<int, double *> graphs;
|
||||
|
||||
namespace {
|
||||
conky::range_config_setting<int> default_bar_width(
|
||||
@ -507,19 +507,18 @@ graph_buf_end:
|
||||
*p = '\0';
|
||||
}
|
||||
|
||||
double* copy_graph(double* original_graph, int graph_width) {
|
||||
double* new_graph = new double[graph_width];
|
||||
double *copy_graph(double *original_graph, int graph_width) {
|
||||
double *new_graph = new double[graph_width];
|
||||
|
||||
memcpy(new_graph, original_graph, graph_width * sizeof(double));
|
||||
|
||||
return new_graph;
|
||||
}
|
||||
|
||||
double* retrieve_graph(int graph_id, int graph_width) {
|
||||
double *retrieve_graph(int graph_id, int graph_width) {
|
||||
if (graphs.find(graph_id) == graphs.end()) {
|
||||
return new double[graph_width];
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
return copy_graph(graphs[graph_id], graph_width);
|
||||
}
|
||||
}
|
||||
@ -527,8 +526,7 @@ double* retrieve_graph(int graph_id, int graph_width) {
|
||||
void store_graph(int graph_id, struct special_t *s) {
|
||||
if (s->graph == nullptr) {
|
||||
graphs[graph_id] = nullptr;
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
graphs[graph_id] = copy_graph(s->graph, s->graph_width);
|
||||
}
|
||||
}
|
||||
@ -592,7 +590,7 @@ void new_graph(struct text_object *obj, char *buf, int buf_max_size,
|
||||
if ((g->flags & SF_SHOWLOG) != 0) { s->scale = log10(s->scale + 1); }
|
||||
#endif
|
||||
|
||||
int graph_id = ((struct graph*)obj->special_data)->id;
|
||||
int graph_id = ((struct graph *)obj->special_data)->id;
|
||||
s->graph = retrieve_graph(graph_id, s->graph_width);
|
||||
|
||||
graph_append(s, val, g->flags);
|
||||
@ -789,3 +787,8 @@ void new_tab(struct text_object *obj, char *p, unsigned int p_max_size) {
|
||||
s->width = t->width;
|
||||
s->arg = t->arg;
|
||||
}
|
||||
|
||||
void clear_stored_graphs() {
|
||||
graph_count = 0;
|
||||
graphs.clear();
|
||||
}
|
||||
|
@ -109,6 +109,8 @@ void new_alignc(struct text_object *, char *, unsigned int);
|
||||
void new_goto(struct text_object *, char *, unsigned int);
|
||||
void new_tab(struct text_object *, char *, unsigned int);
|
||||
|
||||
void clear_stored_graphs();
|
||||
|
||||
struct special_t *new_special(char *buf, enum special_types t);
|
||||
|
||||
#endif /* _SPECIALS_H */
|
||||
|
Loading…
Reference in New Issue
Block a user