summaryrefslogtreecommitdiff
path: root/src/config_node.h
blob: 979ab1e047dc86dc8d8fd3fdec8f62fd7669a68b (plain)
    1 /**
    2  * I3cstat prints a configurable status bar for the i3 window manager
    3  * Copyright (C) 2022 Aaron Ball <nullspoon@oper.io>
    4  * 
    5  * This program is free software: you can redistribute it and/or modify
    6  * it under the terms of the GNU General Public License as published by
    7  * the Free Software Foundation, either version 3 of the License, or
    8  * (at your option) any later version.
    9  * 
   10  * This program is distributed in the hope that it will be useful,
   11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
   12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   13  * GNU General Public License for more details.
   14  * 
   15  * You should have received a copy of the GNU General Public License
   16  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
   17  */
   18 #ifndef CONFIG_NODE
   19 #define CONFIG_NODE
   20 
   21 #include <stdio.h>
   22 #include <stdlib.h>
   23 #include <string.h>
   24 #include <time.h>
   25 
   26 struct node {
   27   struct node* next;
   28   int type;
   29   void* data;                    // Additional data for the specific node type
   30   int (*loadfunc)(struct node*); // callback function so modules can manipulate their node entity
   31   void (*loadkey)(struct node*, char*, char*);  // callback function to load a type-specific ini key
   32   char color[8];                 // Color to print
   33   char label_color[8];           // Color to print
   34   char label[256];               // Label for the node
   35   char text[256];                // Value for full_text
   36   char display[64];              // How to display the data (eg: bar, percent, etc)
   37   long width;                    // Width of the element (only used when display == bar)
   38   size_t interval;               // How frequently the load function should be called
   39   time_t lastrun;                // Last time the node's load function was called
   40 };
   41 
   42 //struct node* config_node_new(void* data, void(*init_callback)(struct node*)) {
   43 struct node* node_new(void (*init_callback)(struct node*));
   44 
   45 struct node* lladd(struct node*, struct node*);
   46 
   47 void llfree(struct node*);
   48 
   49 void _load_node_key(struct node*, char*, char*);
   50 
   51 void node_print(struct node*);
   52 
   53 #endif

Generated by cgit