add center flag

This commit is contained in:
finbargiusti 2025-07-08 19:36:19 +01:00
parent 0a38d45abb
commit c417daa0a0
3 changed files with 28 additions and 8 deletions

9
menu.c
View file

@ -85,14 +85,17 @@ static bool parse_color(const char *color, uint32_t *result) {
// Parse menu options from command line arguments.
void menu_getopts(struct menu *menu, int argc, char *argv[]) {
const char *usage =
"Usage: wmenu [-biPv] [-f font] [-l lines] [-o output] [-p prompt]\n"
"Usage: wmenu [-bciPv] [-f font] [-l lines] [-o output] [-p prompt]\n"
"\t[-N color] [-n color] [-M color] [-m color] [-S color] [-s color]\n";
int opt;
while ((opt = getopt(argc, argv, "bhiPvf:l:o:p:N:n:M:m:S:s:")) != -1) {
while ((opt = getopt(argc, argv, "bchiPvf:l:o:p:N:n:M:m:S:s:")) != -1) {
switch (opt) {
case 'b':
menu->bottom = true;
menu->position = POSITION_BOTTOM;
break;
case 'c':
menu->position = POSITION_CENTER;
break;
case 'i':
menu->strncmp = strncasecmp;

10
menu.h
View file

@ -27,10 +27,18 @@ struct page {
struct page *next; // next page
};
enum e_position {
POSITION_TOP,
POSITION_BOTTOM,
POSITION_CENTER,
};
typedef enum e_position POSITION;
// Menu state.
struct menu {
// Whether the menu appears at the bottom of the screen
bool bottom;
POSITION position;
// The function used to match menu items
int (*strncmp)(const char *, const char *, size_t);
// Whether the input is a password

View file

@ -448,10 +448,19 @@ int menu_run(struct menu *menu) {
uint32_t anchor = ZWLR_LAYER_SURFACE_V1_ANCHOR_LEFT |
ZWLR_LAYER_SURFACE_V1_ANCHOR_RIGHT;
if (menu->bottom) {
anchor |= ZWLR_LAYER_SURFACE_V1_ANCHOR_BOTTOM;
} else {
anchor |= ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP;
switch (menu->position) {
case POSITION_BOTTOM:
anchor |= ZWLR_LAYER_SURFACE_V1_ANCHOR_BOTTOM;
break;
case POSITION_TOP:
anchor |= ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP;
break;
case POSITION_CENTER:
anchor |= ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP | ZWLR_LAYER_SURFACE_V1_ANCHOR_BOTTOM;
// we will handle this in rendering.
break;
}
zwlr_layer_surface_v1_set_anchor(layer_surface, anchor);