bemenu/lib/internal.h
Jari Vetoniemi bc584cc5f0 menu: make SHIFT_RETURN handling more elegant
Don't handle this on client side. Instead have a filter item and return
it if filter text is requested.
2020-02-07 21:54:13 +02:00

363 lines
8.0 KiB
C

#ifndef _BEMENU_INTERNAL_H_
#define _BEMENU_INTERNAL_H_
#include "bemenu.h"
#if __GNUC__
# define BM_LOG_ATTR(x, y) __attribute__((format(printf, x, y)))
#else
# define BM_LOG_ATTR(x, y)
#endif
#ifndef __GLIBC__
# define secure_getenv getenv
#else
extern char *secure_getenv(const char *name);
#endif
#include <stddef.h> /* for size_t */
#include <stdarg.h>
/**
* Destructor function pointer for some list calls.
*/
typedef void (*list_free_fun)(void*);
/**
* List type
*/
struct list {
/**
* Items in the list.
*/
void **items;
/**
* Number of items.
*/
uint32_t count;
/**
* Number of allocated items.
*/
uint32_t allocated;
};
/**
* Internal render api struct.
* Renderers should be able to fill this one as they see fit.
*/
struct render_api {
/**
* Create underlying renderer.
*/
bool (*constructor)(struct bm_menu *menu);
/**
* Release underlying renderer.
*/
void (*destructor)(struct bm_menu *menu);
/**
* Get count of displayed items by the underlying renderer.
*/
uint32_t (*get_displayed_count)(const struct bm_menu *menu);
/**
* If the underlying renderer is a UI toolkit. (curses, etc...)
* There might be possibility to get user input, and this should be thus implemented.
*/
enum bm_key (*poll_key)(const struct bm_menu *menu, uint32_t *unicode);
/**
* Tells underlying renderer to draw the menu.
*/
void (*render)(const struct bm_menu *menu);
/**
* Set menu to appear from bottom of the screen.
*/
void (*set_bottom)(const struct bm_menu *menu, bool bottom);
/**
* Set monitor indeax where menu will appear
*/
void (*set_monitor)(const struct bm_menu *menu, uint32_t monitor);
/**
* Grab/Ungrab keyboard
*/
void (*grab_keyboard)(const struct bm_menu *menu, bool grab);
/**
* Control overlap with panels
*/
void (*set_overlap)(const struct bm_menu *menu, bool overlap);
/**
* Version of the plugin.
* Should match BM_PLUGIN_VERSION or failure.
*/
const char *version;
/**
* Priorty of the plugin.
* Terminal renderers should be first, then graphicals.
*/
enum bm_priorty priorty;
};
/**
* Internal bm_renderer struct.
*/
struct bm_renderer {
/**
* Name of the renderer.
*/
char *name;
/**
* File path of the renderer.
*/
char *file;
/**
* Open handle to the plugin file of this renderer.
*/
void *handle;
/**
* Data used by the renderer internally.
* Nobody else should touch this.
*/
void *internal;
/**
* API
*/
struct render_api api;
};
/**
* Internal bm_item struct that is not exposed to public.
* Represents a single item in menu.
*/
struct bm_item {
/**
* Userdata pointer.
* This pointer will be passed around with the item untouched.
*/
void *userdata;
/**
* Primary text shown on item as null terminated C "string".
* Matching will be done against this text as well.
*/
char *text;
};
/**
* Internal bm_hex_color struct that is not exposed to public.
* Represent a color for element.
*/
struct bm_hex_color {
/**
* Provided hex for the color.
*/
char *hex;
/**
* RGB values.
*/
uint8_t r, g, b;
};
/**
* Internal bm_font struct that is not exposed to public.
* Represent a font for text.
*/
struct bm_font {
/**
* Name of the font.
*/
char *name;
};
/**
* Internal bm_menu struct that is not exposed to public.
*/
struct bm_menu {
/**
* Userdata pointer.
* This pointer will be passed around with the menu untouched.
*/
void *userdata;
/**
* Underlying renderer access.
*/
struct bm_renderer *renderer;
/**
* Items contained in menu instance.
*/
struct list items;
/**
* Filtered/displayed items contained in menu instance.
*/
struct list filtered;
/**
* Selected items.
*/
struct list selection;
/**
* Menu instance title.
*/
char *title;
/**
* Font.
*/
struct bm_font font;
/**
* Line height.
*/
uint32_t line_height;
/**
* Colors.
*/
struct bm_hex_color colors[BM_COLOR_LAST];
/**
* Prefix shown for highlighted item.
* Vertical mode only.
*/
char *prefix;
/**
* Text used to filter matches.
*/
char *filter;
/**
* Used as optimization.
*/
char *old_filter;
/**
* Used when selecting the filter text (ex. SHIFT_RETURN)
*/
struct bm_item *filter_item;
/**
* Size of filter buffer
*/
size_t filter_size;
/**
* Current byte offset on filter text.
*/
uint32_t cursor;
/**
* Current column/cursor position on filter text.
*/
uint32_t curses_cursor;
/**
* Current filtered/highlighted item index in menu instance.
* This index is valid for the list returned by bmMenuGetFilteredItems.
*/
uint32_t index;
/**
* Max number of vertical lines to be shown.
* Some renderers such as ncurses may ignore this when it does not make sense.
*/
uint32_t lines;
/**
* Current monitor.
*/
uint32_t monitor;
/**
* Current filtering method in menu instance.
*/
enum bm_filter_mode filter_mode;
/**
* Current Scrollbar display mode.
*/
enum bm_scrollbar_mode scrollbar;
/**
* Should selection be wrapped?
*/
bool wrap;
/**
* Is menu shown from bottom?
*/
bool bottom;
/**
* Is menu grabbed?
*/
bool grabbed;
/**
* Should the menu overlap panels
*/
bool overlap;
};
/* library.c */
bool bm_renderer_activate(struct bm_renderer *renderer, struct bm_menu *menu);
/* menu.c */
bool bm_menu_item_is_selected(const struct bm_menu *menu, const struct bm_item *item);
/* filter.c */
struct bm_item** bm_filter_dmenu(struct bm_menu *menu, bool addition, uint32_t *out_nmemb);
struct bm_item** bm_filter_dmenu_case_insensitive(struct bm_menu *menu, bool addition, uint32_t *out_nmemb);
/* list.c */
void list_free_list(struct list *list);
void list_free_items(struct list *list, list_free_fun destructor);
void* list_get_items(const struct list *list, uint32_t *out_nmemb);
bool list_set_items_no_copy(struct list *list, void *items, uint32_t nmemb);
bool list_set_items(struct list *list, const void *items, uint32_t nmemb, list_free_fun destructor);
bool list_grow(struct list *list, uint32_t step);
bool list_add_item_at(struct list *list, void *item, uint32_t index);
bool list_add_item(struct list *list, void *item);
bool list_remove_item_at(struct list *list, uint32_t index);
bool list_remove_item(struct list *list, const void *item);
void list_sort(struct list *list, int (*compar)(const void *a, const void *b));
/* util.c */
char* bm_strdup(const char *s);
bool bm_resize_buffer(char **in_out_buffer, size_t *in_out_size, size_t nsize);
BM_LOG_ATTR(1, 2) char* bm_dprintf(const char *fmt, ...);
BM_LOG_ATTR(3, 0) bool bm_vrprintf(char **in_out_buffer, size_t *in_out_len, const char *fmt, va_list args);
size_t bm_strip_token(char *string, const char *token, size_t *out_next);
int bm_strupcmp(const char *hay, const char *needle);
int bm_strnupcmp(const char *hay, const char *needle, size_t len);
char* bm_strupstr(const char *hay, const char *needle);
int32_t bm_utf8_string_screen_width(const char *string);
size_t bm_utf8_rune_next(const char *string, size_t start);
size_t bm_utf8_rune_prev(const char *string, size_t start);
size_t bm_utf8_rune_width(const char *rune, uint32_t u8len);
size_t bm_utf8_rune_remove(char *string, size_t start, size_t *out_rune_width);
size_t bm_utf8_rune_insert(char **string, size_t *bufSize, size_t start, const char *rune, uint32_t u8len, size_t *out_rune_width);
size_t bm_unicode_insert(char **string, size_t *bufSize, size_t start, uint32_t unicode, size_t *out_rune_width);
#endif /* _BEMENU_INTERNAL_H_ */
/* vim: set ts=8 sw=4 tw=0 :*/