mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-13 11:15:27 +00:00
fs_bar, fs_bar_free: merge init and print routines
This commit is contained in:
parent
b9a28c37a8
commit
4d70cf07b8
58
src/conky.c
58
src/conky.c
@ -1744,34 +1744,7 @@ static void generate_text_internal(char *p, int p_max_size,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
OBJ(fs_bar) {
|
OBJ(fs_bar) {
|
||||||
if (obj->data.fs != NULL) {
|
print_fs_bar(obj, 0, p, p_max_size);
|
||||||
if (obj->data.fs->size == 0) {
|
|
||||||
#ifdef X11
|
|
||||||
if(output_methods & TO_X) {
|
|
||||||
new_bar(p, obj->data.fsbar.w, obj->data.fsbar.h, 255);
|
|
||||||
}else{
|
|
||||||
#endif /* X11 */
|
|
||||||
if(!obj->data.fsbar.w) obj->data.fsbar.w = DEFAULT_BAR_WIDTH_NO_X;
|
|
||||||
new_bar_in_shell(p, p_max_size, 100, obj->data.fsbar.w);
|
|
||||||
#ifdef X11
|
|
||||||
}
|
|
||||||
#endif /* X11 */
|
|
||||||
} else {
|
|
||||||
#ifdef X11
|
|
||||||
if(output_methods & TO_X) {
|
|
||||||
new_bar(p, obj->data.fsbar.w, obj->data.fsbar.h,
|
|
||||||
(int) (255 - obj->data.fsbar.fs->avail * 255 /
|
|
||||||
obj->data.fs->size));
|
|
||||||
}else{
|
|
||||||
#endif /* X11 */
|
|
||||||
if(!obj->data.fsbar.w) obj->data.fsbar.w = DEFAULT_BAR_WIDTH_NO_X;
|
|
||||||
new_bar_in_shell(p, p_max_size,
|
|
||||||
(int) (100 - obj->data.fsbar.fs->avail * 100 / obj->data.fs->size), obj->data.fsbar.w);
|
|
||||||
#ifdef X11
|
|
||||||
}
|
|
||||||
#endif /* X11 */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
OBJ(fs_free) {
|
OBJ(fs_free) {
|
||||||
if (obj->data.fs != NULL) {
|
if (obj->data.fs != NULL) {
|
||||||
@ -1805,34 +1778,7 @@ static void generate_text_internal(char *p, int p_max_size,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
OBJ(fs_bar_free) {
|
OBJ(fs_bar_free) {
|
||||||
if (obj->data.fs != NULL) {
|
print_fs_bar(obj, 1, p, p_max_size);
|
||||||
if (obj->data.fs->size == 0) {
|
|
||||||
#ifdef X11
|
|
||||||
if(output_methods & TO_X) {
|
|
||||||
new_bar(p, obj->data.fsbar.w, obj->data.fsbar.h, 255);
|
|
||||||
}else{
|
|
||||||
#endif /* X11 */
|
|
||||||
if(!obj->data.fsbar.w) obj->data.fsbar.w = DEFAULT_BAR_WIDTH_NO_X;
|
|
||||||
new_bar_in_shell(p, p_max_size, 100, obj->data.fsbar.w);
|
|
||||||
#ifdef X11
|
|
||||||
}
|
|
||||||
#endif /* X11 */
|
|
||||||
} else {
|
|
||||||
#ifdef X11
|
|
||||||
if(output_methods & TO_X) {
|
|
||||||
new_bar(p, obj->data.fsbar.w, obj->data.fsbar.h,
|
|
||||||
(int) (obj->data.fsbar.fs->avail * 255 /
|
|
||||||
obj->data.fs->size));
|
|
||||||
}else{
|
|
||||||
#endif /* X11 */
|
|
||||||
if(!obj->data.fsbar.w) obj->data.fsbar.w = DEFAULT_BAR_WIDTH_NO_X;
|
|
||||||
new_bar_in_shell(p, p_max_size,
|
|
||||||
(int) (obj->data.fsbar.fs->avail * 100 / obj->data.fs->size), obj->data.fsbar.w);
|
|
||||||
#ifdef X11
|
|
||||||
}
|
|
||||||
#endif /* X11 */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
OBJ(fs_used_perc) {
|
OBJ(fs_used_perc) {
|
||||||
if (obj->data.fs != NULL) {
|
if (obj->data.fs != NULL) {
|
||||||
|
29
src/core.c
29
src/core.c
@ -713,34 +713,9 @@ struct text_object *construct_text_object(const char *s, const char *arg, long
|
|||||||
obj->data.s = strndup("", text_buffer_size);
|
obj->data.s = strndup("", text_buffer_size);
|
||||||
}
|
}
|
||||||
END OBJ(fs_bar, &update_fs_stats)
|
END OBJ(fs_bar, &update_fs_stats)
|
||||||
SIZE_DEFAULTS(bar);
|
init_fs_bar(obj, arg);
|
||||||
arg = scan_bar(arg, &obj->data.fsbar.w, &obj->data.fsbar.h);
|
|
||||||
if (arg) {
|
|
||||||
while (isspace(*arg)) {
|
|
||||||
arg++;
|
|
||||||
}
|
|
||||||
if (*arg == '\0') {
|
|
||||||
arg = "/";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
arg = "/";
|
|
||||||
}
|
|
||||||
obj->data.fsbar.fs = prepare_fs_stat(arg);
|
|
||||||
END OBJ(fs_bar_free, &update_fs_stats)
|
END OBJ(fs_bar_free, &update_fs_stats)
|
||||||
SIZE_DEFAULTS(bar);
|
init_fs_bar(obj, arg);
|
||||||
arg = scan_bar(arg, &obj->data.fsbar.w, &obj->data.fsbar.h);
|
|
||||||
if (arg) {
|
|
||||||
while (isspace(*arg)) {
|
|
||||||
arg++;
|
|
||||||
}
|
|
||||||
if (*arg == '\0') {
|
|
||||||
arg = "/";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
arg = "/";
|
|
||||||
}
|
|
||||||
|
|
||||||
obj->data.fsbar.fs = prepare_fs_stat(arg);
|
|
||||||
END OBJ(fs_free, &update_fs_stats)
|
END OBJ(fs_free, &update_fs_stats)
|
||||||
if (!arg) {
|
if (!arg) {
|
||||||
arg = "/";
|
arg = "/";
|
||||||
|
46
src/fs.c
46
src/fs.c
@ -31,6 +31,9 @@
|
|||||||
#include "conky.h"
|
#include "conky.h"
|
||||||
#include "logging.h"
|
#include "logging.h"
|
||||||
#include "fs.h"
|
#include "fs.h"
|
||||||
|
#include "specials.h"
|
||||||
|
#include "text_object.h"
|
||||||
|
#include <ctype.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
@ -191,3 +194,46 @@ void get_fs_type(const char *path, char *result)
|
|||||||
strncpy(result, "unknown", DEFAULT_TEXT_BUFFER_SIZE);
|
strncpy(result, "unknown", DEFAULT_TEXT_BUFFER_SIZE);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void init_fs_bar(struct text_object *obj, const char *arg)
|
||||||
|
{
|
||||||
|
SIZE_DEFAULTS(bar);
|
||||||
|
arg = scan_bar(arg, &obj->data.fsbar.w, &obj->data.fsbar.h);
|
||||||
|
if (arg) {
|
||||||
|
while (isspace(*arg)) {
|
||||||
|
arg++;
|
||||||
|
}
|
||||||
|
if (*arg == '\0') {
|
||||||
|
arg = "/";
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
arg = "/";
|
||||||
|
}
|
||||||
|
obj->data.fsbar.fs = prepare_fs_stat(arg);
|
||||||
|
}
|
||||||
|
|
||||||
|
void print_fs_bar(struct text_object *obj, int be_free_bar, char *p, int p_max_size)
|
||||||
|
{
|
||||||
|
double val;
|
||||||
|
|
||||||
|
if (!obj->data.fsbar.fs)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (!obj->data.fsbar.fs->size)
|
||||||
|
val = 1.0;
|
||||||
|
else
|
||||||
|
val = (double)obj->data.fsbar.fs->avail / (double)obj->data.fsbar.fs->size;
|
||||||
|
|
||||||
|
if (!be_free_bar)
|
||||||
|
val = 1.0 - val;
|
||||||
|
|
||||||
|
#ifdef X11
|
||||||
|
if(output_methods & TO_X) {
|
||||||
|
new_bar(p, obj->data.fsbar.w, obj->data.fsbar.h, (int)(255 * val));
|
||||||
|
}else
|
||||||
|
#endif /* X11 */
|
||||||
|
{
|
||||||
|
if(!obj->data.fsbar.w) obj->data.fsbar.w = DEFAULT_BAR_WIDTH_NO_X;
|
||||||
|
new_bar_in_shell(p, p_max_size, (int)(100 * val), obj->data.fsbar.w);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
5
src/fs.h
5
src/fs.h
@ -15,6 +15,11 @@ struct fs_stat {
|
|||||||
char set;
|
char set;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* forward declare to make gcc happy (fs.h <-> text_object.h include) */
|
||||||
|
struct text_object;
|
||||||
|
|
||||||
|
void init_fs_bar(struct text_object *, const char *);
|
||||||
|
void print_fs_bar(struct text_object *, int, char *, int);
|
||||||
void update_fs_stats(void);
|
void update_fs_stats(void);
|
||||||
struct fs_stat *prepare_fs_stat(const char *path);
|
struct fs_stat *prepare_fs_stat(const char *path);
|
||||||
void clear_fs_stats(void);
|
void clear_fs_stats(void);
|
||||||
|
Loading…
Reference in New Issue
Block a user