Modes must explicitly declare support for execution without a matching entry
This commit is contained in:
		| @@ -126,3 +126,7 @@ const char** wofi_dmenu_get_arg_names(void) { | |||||||
| size_t wofi_dmenu_get_arg_count(void) { | size_t wofi_dmenu_get_arg_count(void) { | ||||||
| 	return sizeof(arg_names) / sizeof(char*); | 	return sizeof(arg_names) / sizeof(char*); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool wofi_dmenu_no_entry(void) { | ||||||
|  | 	return true; | ||||||
|  | } | ||||||
|   | |||||||
| @@ -168,3 +168,7 @@ const char** wofi_run_get_arg_names(void) { | |||||||
| size_t wofi_run_get_arg_count(void) { | size_t wofi_run_get_arg_count(void) { | ||||||
| 	return sizeof(arg_names) / sizeof(char*); | 	return sizeof(arg_names) / sizeof(char*); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool wofi_run_no_entry(void) { | ||||||
|  | 	return true; | ||||||
|  | } | ||||||
|   | |||||||
							
								
								
									
										49
									
								
								src/wofi.c
									
									
									
									
									
								
							
							
						
						
									
										49
									
								
								src/wofi.c
									
									
									
									
									
								
							| @@ -64,7 +64,7 @@ static bool no_actions; | |||||||
|  |  | ||||||
| struct mode { | struct mode { | ||||||
| 	void (*mode_exec)(const gchar* cmd); | 	void (*mode_exec)(const gchar* cmd); | ||||||
| 	struct widget* (*mode_get_widget)(); | 	struct widget* (*mode_get_widget)(void); | ||||||
| 	char* name; | 	char* name; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -646,9 +646,9 @@ static GtkWidget* get_first_child(GtkContainer* container) { | |||||||
| static void activate_search(GtkEntry* entry, gpointer data) { | static void activate_search(GtkEntry* entry, gpointer data) { | ||||||
| 	(void) data; | 	(void) data; | ||||||
| 	GtkWidget* child = get_first_child(GTK_CONTAINER(inner_box)); | 	GtkWidget* child = get_first_child(GTK_CONTAINER(inner_box)); | ||||||
| 	if(exec_search || child == NULL) { | 	if(mode != NULL && (exec_search || child == NULL)) { | ||||||
| 		execute_action(mode, gtk_entry_get_text(entry)); | 		execute_action(mode, gtk_entry_get_text(entry)); | ||||||
| 	} else { | 	} else if(child != NULL) { | ||||||
| 		GtkWidget* box = gtk_bin_get_child(GTK_BIN(child)); | 		GtkWidget* box = gtk_bin_get_child(GTK_BIN(child)); | ||||||
| 		bool primary_action = GTK_IS_EXPANDER(box); | 		bool primary_action = GTK_IS_EXPANDER(box); | ||||||
| 		if(primary_action) { | 		if(primary_action) { | ||||||
| @@ -767,25 +767,27 @@ static void* get_plugin_proc(const char* prefix, const char* suffix) { | |||||||
| 	return proc; | 	return proc; | ||||||
| } | } | ||||||
|  |  | ||||||
| static void add_mode(char* mode) { | static void add_mode(char* _mode) { | ||||||
| 	char* dso = strstr(mode, ".so"); | 	char* dso = strstr(_mode, ".so"); | ||||||
| 	struct mode* mode_ptr = calloc(1, sizeof(struct mode)); | 	struct mode* mode_ptr = calloc(1, sizeof(struct mode)); | ||||||
| 	map_put_void(modes, mode, mode_ptr); | 	map_put_void(modes, _mode, mode_ptr); | ||||||
|  |  | ||||||
| 	mode_ptr->name = strdup(mode); | 	mode_ptr->name = strdup(_mode); | ||||||
|  |  | ||||||
| 	void (*init)(struct mode* mode, struct map* props); | 	void (*init)(struct mode* _mode, struct map* props); | ||||||
| 	const char** (*get_arg_names)(); | 	const char** (*get_arg_names)(void); | ||||||
| 	size_t (*get_arg_count)(); | 	size_t (*get_arg_count)(void); | ||||||
|  | 	bool (*no_entry)(void); | ||||||
| 	if(dso == NULL) { | 	if(dso == NULL) { | ||||||
| 		init = get_plugin_proc(mode, "_init"); | 		init = get_plugin_proc(_mode, "_init"); | ||||||
| 		get_arg_names = get_plugin_proc(mode, "_get_arg_names"); | 		get_arg_names = get_plugin_proc(_mode, "_get_arg_names"); | ||||||
| 		get_arg_count = get_plugin_proc(mode, "_get_arg_count"); | 		get_arg_count = get_plugin_proc(_mode, "_get_arg_count"); | ||||||
| 		mode_ptr->mode_exec = get_plugin_proc(mode, "_exec"); | 		mode_ptr->mode_exec = get_plugin_proc(_mode, "_exec"); | ||||||
| 		mode_ptr->mode_get_widget = get_plugin_proc(mode, "_get_widget"); | 		mode_ptr->mode_get_widget = get_plugin_proc(_mode, "_get_widget"); | ||||||
|  | 		no_entry = get_plugin_proc(_mode, "_no_entry"); | ||||||
| 	} else { | 	} else { | ||||||
| 		char* plugins_dir = utils_concat(2, config_dir, "/plugins/"); | 		char* plugins_dir = utils_concat(2, config_dir, "/plugins/"); | ||||||
| 		char* full_name = utils_concat(2, plugins_dir, mode); | 		char* full_name = utils_concat(2, plugins_dir, _mode); | ||||||
| 		void* plugin = dlopen(full_name, RTLD_LAZY | RTLD_LOCAL); | 		void* plugin = dlopen(full_name, RTLD_LAZY | RTLD_LOCAL); | ||||||
| 		free(full_name); | 		free(full_name); | ||||||
| 		free(plugins_dir); | 		free(plugins_dir); | ||||||
| @@ -794,6 +796,7 @@ static void add_mode(char* mode) { | |||||||
| 		get_arg_count = dlsym(plugin, "get_arg_count"); | 		get_arg_count = dlsym(plugin, "get_arg_count"); | ||||||
| 		mode_ptr->mode_exec = dlsym(plugin, "exec"); | 		mode_ptr->mode_exec = dlsym(plugin, "exec"); | ||||||
| 		mode_ptr->mode_get_widget = dlsym(plugin, "get_widget"); | 		mode_ptr->mode_get_widget = dlsym(plugin, "get_widget"); | ||||||
|  | 		no_entry = dlsym(plugin, "no_entry"); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	const char** arg_names = NULL; | 	const char** arg_names = NULL; | ||||||
| @@ -803,10 +806,14 @@ static void add_mode(char* mode) { | |||||||
| 		arg_count = get_arg_count(); | 		arg_count = get_arg_count(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	if(mode == NULL && no_entry != NULL && no_entry()) { | ||||||
|  | 		mode = _mode; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	struct map* props = map_init(); | 	struct map* props = map_init(); | ||||||
| 	for(size_t count = 0; count < arg_count; ++count) { | 	for(size_t count = 0; count < arg_count; ++count) { | ||||||
| 		const char* arg = arg_names[count]; | 		const char* arg = arg_names[count]; | ||||||
| 		char* full_name = utils_concat(3, mode, "-", arg); | 		char* full_name = utils_concat(3, _mode, "-", arg); | ||||||
| 		map_put(props, arg, config_get(config, full_name, NULL)); | 		map_put(props, arg, config_get(config, full_name, NULL)); | ||||||
| 		free(full_name); | 		free(full_name); | ||||||
| 	} | 	} | ||||||
| @@ -815,7 +822,7 @@ static void add_mode(char* mode) { | |||||||
| 		init(mode_ptr, props); | 		init(mode_ptr, props); | ||||||
| 		gdk_threads_add_idle(_insert_widget, mode_ptr); | 		gdk_threads_add_idle(_insert_widget, mode_ptr); | ||||||
| 	} else { | 	} else { | ||||||
| 		fprintf(stderr, "I would love to show %s but Idk what it is\n", mode); | 		fprintf(stderr, "I would love to show %s but Idk what it is\n", _mode); | ||||||
| 		exit(1); | 		exit(1); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -823,7 +830,7 @@ static void add_mode(char* mode) { | |||||||
| } | } | ||||||
|  |  | ||||||
| static void* start_thread(void* data) { | static void* start_thread(void* data) { | ||||||
| 	(void) data; | 	char* mode = data; | ||||||
| 	if(strchr(mode, ',') != NULL) { | 	if(strchr(mode, ',') != NULL) { | ||||||
| 		char* save_ptr; | 		char* save_ptr; | ||||||
| 		char* str = strtok_r(mode, ",", &save_ptr); | 		char* str = strtok_r(mode, ",", &save_ptr); | ||||||
| @@ -843,7 +850,7 @@ void wofi_init(struct map* _config) { | |||||||
| 	x = map_get(config, "x"); | 	x = map_get(config, "x"); | ||||||
| 	y = map_get(config, "y"); | 	y = map_get(config, "y"); | ||||||
| 	bool normal_window = strcmp(config_get(config, "normal_window", "false"), "true") == 0; | 	bool normal_window = strcmp(config_get(config, "normal_window", "false"), "true") == 0; | ||||||
| 	mode = map_get(config, "mode"); | 	char* mode = map_get(config, "mode"); | ||||||
| 	GtkOrientation orientation = config_get_mnemonic(config, "orientation", "vertical", 2, "vertical", "horizontal"); | 	GtkOrientation orientation = config_get_mnemonic(config, "orientation", "vertical", 2, "vertical", "horizontal"); | ||||||
| 	outer_orientation = config_get_mnemonic(config, "orientation", "vertical", 2, "horizontal", "vertical"); | 	outer_orientation = config_get_mnemonic(config, "orientation", "vertical", 2, "horizontal", "vertical"); | ||||||
| 	GtkAlign halign = config_get_mnemonic(config, "halign", "fill", 4, "fill", "start", "end", "center"); | 	GtkAlign halign = config_get_mnemonic(config, "halign", "fill", 4, "fill", "start", "end", "center"); | ||||||
| @@ -954,7 +961,7 @@ void wofi_init(struct map* _config) { | |||||||
| 	g_signal_connect(window, "key-press-event", G_CALLBACK(key_press), NULL); | 	g_signal_connect(window, "key-press-event", G_CALLBACK(key_press), NULL); | ||||||
|  |  | ||||||
| 	pthread_t thread; | 	pthread_t thread; | ||||||
| 	pthread_create(&thread, NULL, start_thread, NULL); | 	pthread_create(&thread, NULL, start_thread, mode); | ||||||
| 	gtk_widget_grab_focus(scroll); | 	gtk_widget_grab_focus(scroll); | ||||||
| 	gtk_window_set_title(GTK_WINDOW(window), prompt); | 	gtk_window_set_title(GTK_WINDOW(window), prompt); | ||||||
| 	gtk_widget_show_all(window); | 	gtk_widget_show_all(window); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Scoopta
					Scoopta