aboutsummaryrefslogtreecommitdiffstats
path: root/MetersPanel.c
diff options
context:
space:
mode:
authorDaniel Lange <DLange@git.local>2016-04-11 13:00:20 +0200
committerDaniel Lange <DLange@git.local>2016-04-11 13:00:20 +0200
commit85bb4ad9cb820ac3b8e935a930084a06cbfd2847 (patch)
tree681fd9b2d9fa80931b2a8bec4bb6667865b7c569 /MetersPanel.c
parentea859f50d9438bc61ae96721a4d255b49de78653 (diff)
downloaddebian_htop-85bb4ad9cb820ac3b8e935a930084a06cbfd2847.tar.gz
debian_htop-85bb4ad9cb820ac3b8e935a930084a06cbfd2847.tar.bz2
debian_htop-85bb4ad9cb820ac3b8e935a930084a06cbfd2847.zip
Imported Upstream version 0.6.3upstream/0.6.3
Diffstat (limited to 'MetersPanel.c')
-rw-r--r--MetersPanel.c105
1 files changed, 105 insertions, 0 deletions
diff --git a/MetersPanel.c b/MetersPanel.c
new file mode 100644
index 0000000..b87f510
--- /dev/null
+++ b/MetersPanel.c
@@ -0,0 +1,105 @@
+
+#include "MetersPanel.h"
+
+#include "Panel.h"
+#include "Settings.h"
+#include "ScreenManager.h"
+
+#include "debug.h"
+#include <assert.h>
+
+/*{
+
+typedef struct MetersPanel_ {
+ Panel super;
+
+ Settings* settings;
+ Vector* meters;
+ ScreenManager* scr;
+} MetersPanel;
+
+}*/
+
+MetersPanel* MetersPanel_new(Settings* settings, char* header, Vector* meters, ScreenManager* scr) {
+ MetersPanel* this = (MetersPanel*) malloc(sizeof(MetersPanel));
+ Panel* super = (Panel*) this;
+ Panel_init(super, 1, 1, 1, 1, LISTITEM_CLASS, true);
+ ((Object*)this)->delete = MetersPanel_delete;
+
+ this->settings = settings;
+ this->meters = meters;
+ this->scr = scr;
+ super->eventHandler = MetersPanel_EventHandler;
+ Panel_setHeader(super, header);
+ for (int i = 0; i < Vector_size(meters); i++) {
+ Meter* meter = (Meter*) Vector_get(meters, i);
+ Panel_add(super, (Object*) Meter_toListItem(meter));
+ }
+ return this;
+}
+
+void MetersPanel_delete(Object* object) {
+ Panel* super = (Panel*) object;
+ MetersPanel* this = (MetersPanel*) object;
+ Panel_done(super);
+ free(this);
+}
+
+HandlerResult MetersPanel_EventHandler(Panel* super, int ch) {
+ MetersPanel* this = (MetersPanel*) super;
+
+ int selected = Panel_getSelectedIndex(super);
+ HandlerResult result = IGNORED;
+
+ switch(ch) {
+ case 0x0a:
+ case 0x0d:
+ case KEY_ENTER:
+ case KEY_F(4):
+ case 't':
+ {
+ Meter* meter = (Meter*) Vector_get(this->meters, selected);
+ int mode = meter->mode + 1;
+ if (mode == LAST_METERMODE) mode = 1;
+ Meter_setMode(meter, mode);
+ Panel_set(super, selected, (Object*) Meter_toListItem(meter));
+ result = HANDLED;
+ break;
+ }
+ case KEY_F(7):
+ case '[':
+ case '-':
+ {
+ Vector_moveUp(this->meters, selected);
+ Panel_moveSelectedUp(super);
+ result = HANDLED;
+ break;
+ }
+ case KEY_F(8):
+ case ']':
+ case '+':
+ {
+ Vector_moveDown(this->meters, selected);
+ Panel_moveSelectedDown(super);
+ result = HANDLED;
+ break;
+ }
+ case KEY_F(9):
+ case KEY_DC:
+ {
+ if (selected < Vector_size(this->meters)) {
+ Vector_remove(this->meters, selected);
+ Panel_remove(super, selected);
+ }
+ result = HANDLED;
+ break;
+ }
+ }
+ if (result == HANDLED) {
+ Header* header = this->settings->header;
+ Header_calculateHeight(header);
+ Header_draw(header);
+ ScreenManager_resize(this->scr, this->scr->x1, header->height, this->scr->x2, this->scr->y2);
+ }
+ return result;
+}

© 2014-2024 Faster IT GmbH | imprint | privacy policy