mirror of
				https://github.com/DreamMaoMao/maomaowm.git
				synced 2025-10-29 05:40:21 -04:00 
			
		
		
		
	feat: use regex to match no strstr
This commit is contained in:
		
							parent
							
								
									aa0e1e1fe9
								
							
						
					
					
						commit
						64b15fe4e7
					
				
					 5 changed files with 59 additions and 18 deletions
				
			
		|  | @ -57,7 +57,7 @@ https://github.com/user-attachments/assets/c9bf9415-fad1-4400-bcdc-3ad2d76de85a | ||||||
| ## depend | ## depend | ||||||
| 
 | 
 | ||||||
| ```bash | ```bash | ||||||
| yay -S glibc wayland libinput libdrm pixman libxkbcommon git meson ninja wayland-protocols libdisplay-info libliftoff hwdata seatd | yay -S glibc wayland libinput libdrm pixman libxkbcommon git meson ninja wayland-protocols libdisplay-info libliftoff hwdata seatd pcre2 | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| ## arch | ## arch | ||||||
|  |  | ||||||
|  | @ -37,6 +37,7 @@ wlroots_dep = dependency('wlroots-0.19') | ||||||
| xkbcommon_dep = dependency('xkbcommon') | xkbcommon_dep = dependency('xkbcommon') | ||||||
| libinput_dep = dependency('libinput') | libinput_dep = dependency('libinput') | ||||||
| libwayland_client_dep = dependency('wayland-client') | libwayland_client_dep = dependency('wayland-client') | ||||||
|  | pcre2_dep = dependency('libpcre2-8') | ||||||
| 
 | 
 | ||||||
| # 获取 Git Commit Hash 和最新的 tag | # 获取 Git Commit Hash 和最新的 tag | ||||||
| git = find_program('git', required : false) | git = find_program('git', required : false) | ||||||
|  | @ -79,6 +80,7 @@ executable('maomao', | ||||||
|     xkbcommon_dep, |     xkbcommon_dep, | ||||||
|     libinput_dep, |     libinput_dep, | ||||||
|     libwayland_client_dep, |     libwayland_client_dep, | ||||||
|  |     pcre2_dep, | ||||||
|   ], |   ], | ||||||
|   install : true, |   install : true, | ||||||
|   c_args : c_args |   c_args : c_args | ||||||
|  |  | ||||||
|  | @ -7,6 +7,12 @@ | ||||||
| 
 | 
 | ||||||
| #include "util.h" | #include "util.h" | ||||||
| 
 | 
 | ||||||
|  | #define PCRE2_CODE_UNIT_WIDTH 8 | ||||||
|  | #include <pcre2.h> | ||||||
|  | #include <wchar.h> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| void die(const char *fmt, ...) { | void die(const char *fmt, ...) { | ||||||
|   va_list ap; |   va_list ap; | ||||||
| 
 | 
 | ||||||
|  | @ -45,3 +51,34 @@ int fd_set_nonblock(int fd) { | ||||||
| 
 | 
 | ||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | int regex_match(const char *pattern, const char *str) { | ||||||
|  |     int errnum; | ||||||
|  |     PCRE2_SIZE erroffset; | ||||||
|  |     pcre2_code *re = pcre2_compile( | ||||||
|  |         (PCRE2_SPTR)pattern, | ||||||
|  |         PCRE2_ZERO_TERMINATED, | ||||||
|  |         PCRE2_UTF,  // 启用 UTF-8 支持
 | ||||||
|  |         &errnum, &erroffset, NULL | ||||||
|  |     ); | ||||||
|  |     if (!re) { | ||||||
|  |         PCRE2_UCHAR errbuf[256]; | ||||||
|  |         pcre2_get_error_message(errnum, errbuf, sizeof(errbuf)); | ||||||
|  |         fprintf(stderr, "PCRE2 error: %s at offset %zu\n", errbuf, erroffset); | ||||||
|  |         return 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     pcre2_match_data *match_data = pcre2_match_data_create_from_pattern(re, NULL); | ||||||
|  |     int ret = pcre2_match( | ||||||
|  |         re, | ||||||
|  |         (PCRE2_SPTR)str, | ||||||
|  |         strlen(str), | ||||||
|  |         0, 0, | ||||||
|  |         match_data, | ||||||
|  |         NULL | ||||||
|  |     ); | ||||||
|  | 
 | ||||||
|  |     pcre2_match_data_free(match_data); | ||||||
|  |     pcre2_code_free(re); | ||||||
|  |     return ret >= 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -1,5 +1,7 @@ | ||||||
| /* See LICENSE.dwm file for copyright and license details. */ | /* See LICENSE.dwm file for copyright and license details. */ | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| void die(const char *fmt, ...); | void die(const char *fmt, ...); | ||||||
| void *ecalloc(size_t nmemb, size_t size); | void *ecalloc(size_t nmemb, size_t size); | ||||||
| int fd_set_nonblock(int fd); | int fd_set_nonblock(int fd); | ||||||
|  | int regex_match(const char *pattern_mb, const char *str_mb); | ||||||
|  |  | ||||||
							
								
								
									
										34
									
								
								src/maomao.c
									
										
									
									
									
								
							
							
						
						
									
										34
									
								
								src/maomao.c
									
										
									
									
									
								
							|  | @ -1579,10 +1579,10 @@ Client *get_client_by_id_or_title(const char *arg_id, const char *arg_title) { | ||||||
|     if (arg_title && strncmp(arg_title, "none", 4) == 0) |     if (arg_title && strncmp(arg_title, "none", 4) == 0) | ||||||
|       arg_title = NULL; |       arg_title = NULL; | ||||||
| 
 | 
 | ||||||
|     if ((arg_title && strstr(title, arg_title) && !arg_id) || |     if ((arg_title && regex_match(arg_title, title) && !arg_id) || | ||||||
|         (arg_id && strstr(appid, arg_id) && !arg_title) || |         (arg_id && regex_match(arg_id, appid) && !arg_title) || | ||||||
|         (arg_id && strstr(appid, arg_id) && arg_title && |         (arg_id && regex_match(arg_id, appid) && arg_title && | ||||||
|          strstr(title, arg_title))) { |          regex_match(arg_title, title))) { | ||||||
|       target_client = c; |       target_client = c; | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
|  | @ -1774,10 +1774,10 @@ applyrulesgeom(Client *c) { | ||||||
|     if (config.window_rules_count < 1) |     if (config.window_rules_count < 1) | ||||||
|       break; |       break; | ||||||
|     r = &config.window_rules[ji]; |     r = &config.window_rules[ji]; | ||||||
|     if ((r->title && strstr(title, r->title) && !r->id) || |     if ((regex_match(r->title,title) && !r->id) || | ||||||
|         (r->id && strstr(appid, r->id) && !r->title) || |         (r->id && regex_match(r->id,appid) && !r->title) || | ||||||
|         (r->id && strstr(appid, r->id) && r->title && |         (r->id && regex_match(r->id,appid) && r->title && | ||||||
|          strstr(title, r->title))) { |          regex_match(r->title,title))) { | ||||||
|       c->geom.width = r->width > 0 ? r->width : c->geom.width; |       c->geom.width = r->width > 0 ? r->width : c->geom.width; | ||||||
|       c->geom.height = r->height > 0 ? r->height : c->geom.height; |       c->geom.height = r->height > 0 ? r->height : c->geom.height; | ||||||
|       // 重新计算居中的坐标
 |       // 重新计算居中的坐标
 | ||||||
|  | @ -1814,10 +1814,10 @@ applyrules(Client *c) { | ||||||
|       break; |       break; | ||||||
|     r = &config.window_rules[ji]; |     r = &config.window_rules[ji]; | ||||||
| 
 | 
 | ||||||
|     if ((r->title && strstr(title, r->title) && !r->id) || |     if ((r->title && regex_match(r->title,title) && !r->id) || | ||||||
|         (r->id && strstr(appid, r->id) && !r->title) || |         (r->id && regex_match(r->id,appid) && !r->title) || | ||||||
|         (r->id && strstr(appid, r->id) && r->title && |         (r->id && regex_match(r->id,appid) && r->title && | ||||||
|          strstr(title, r->title))) { |          regex_match(r->title,title))) { | ||||||
|       c->isterm = r->isterm > 0 ? r->isterm : c->isterm; |       c->isterm = r->isterm > 0 ? r->isterm : c->isterm; | ||||||
|       c->noswallow = r->noswallow > 0 ? r->noswallow : c->noswallow; |       c->noswallow = r->noswallow > 0 ? r->noswallow : c->noswallow; | ||||||
|       c->scratchpad_geom.width = |       c->scratchpad_geom.width = | ||||||
|  | @ -3244,7 +3244,7 @@ void createmon(struct wl_listener *listener, void *data) { | ||||||
|       break; |       break; | ||||||
| 
 | 
 | ||||||
|     r = &config.monitor_rules[ji]; |     r = &config.monitor_rules[ji]; | ||||||
|     if (!r->name || strstr(wlr_output->name, r->name)) { |     if (!r->name || regex_match(r->name, wlr_output->name)) { | ||||||
|       m->mfact = r->mfact; |       m->mfact = r->mfact; | ||||||
|       m->nmaster = r->nmaster; |       m->nmaster = r->nmaster; | ||||||
|       m->m.x = r->x; |       m->m.x = r->x; | ||||||
|  | @ -4125,10 +4125,10 @@ bool keypressglobal(struct wlr_surface *last_surface, | ||||||
|           appid = client_get_appid(c); |           appid = client_get_appid(c); | ||||||
|           title = client_get_title(c); |           title = client_get_title(c); | ||||||
| 
 | 
 | ||||||
|           if ((r->title && strstr(title, r->title) && !r->id) || |           if ((r->title && regex_match(r->title, title) && !r->id) || | ||||||
|               (r->id && strstr(appid, r->id) && !r->title) || |               (r->id && regex_match(r->id, appid) && !r->title) || | ||||||
|               (r->id && strstr(appid, r->id) && r->title && |               (r->id && regex_match(r->id, appid) && r->title && | ||||||
|                strstr(title, r->title))) { |                regex_match(r->title, title))) { | ||||||
|             reset = true; |             reset = true; | ||||||
|             wlr_seat_keyboard_enter(seat, client_surface(c), keycodes, 0, |             wlr_seat_keyboard_enter(seat, client_surface(c), keycodes, 0, | ||||||
|                                     &keyboard->modifiers); |                                     &keyboard->modifiers); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 DreamMaoMao
						DreamMaoMao