patch 8.1.1221: filtering does not work when listing marks
Problem: Filtering does not work when listing marks. Solution: Implement filtering marks. (Marcin Szamotulski, closes #3895)
This commit is contained in:
		| @ -572,6 +572,7 @@ N  *+X11*		Unix only: can restore window title |X11| | ||||
| 			commands support filtering, try it out to check if it | ||||
| 			works. Some of the commands that support filtering: | ||||
| 			   |:#|          - filter whole line | ||||
| 			   |:clist|      - filter by file name or module name | ||||
| 			   |:command|    - filter by command name | ||||
| 			   |:files|      - filter by file name | ||||
| 			   |:highlight|  - filter by highlight group | ||||
| @ -579,8 +580,9 @@ N  *+X11*		Unix only: can restore window title |X11| | ||||
| 			   |:let|        - filter by variable name | ||||
| 			   |:list|       - filter whole line | ||||
| 			   |:llist|      - filter by file name or module name | ||||
| 			   |:marks|      - filter by text in the current file, | ||||
| 					   or file name for other files | ||||
| 			   |:oldfiles|   - filter by file name | ||||
|                           |:clist|      - filter by file name or module name | ||||
| 			   |:set|        - filter by variable name | ||||
|  | ||||
| 			Only normal messages are filtered, error messages are | ||||
|  | ||||
							
								
								
									
										26
									
								
								src/mark.c
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								src/mark.c
									
									
									
									
									
								
							| @ -744,11 +744,12 @@ show_one_mark( | ||||
|     int		c, | ||||
|     char_u	*arg, | ||||
|     pos_T	*p, | ||||
|     char_u	*name, | ||||
|     char_u	*name_arg, | ||||
|     int		current)	/* in current file */ | ||||
| { | ||||
|     static int	did_title = FALSE; | ||||
|     int		mustfree = FALSE; | ||||
|     char_u	*name = name_arg; | ||||
|  | ||||
|     if (c == -1)			    /* finish up */ | ||||
|     { | ||||
| @ -762,14 +763,21 @@ show_one_mark( | ||||
| 		semsg(_("E283: No marks matching \"%s\""), arg); | ||||
| 	} | ||||
|     } | ||||
|     /* don't output anything if 'q' typed at --more-- prompt */ | ||||
|     // don't output anything if 'q' typed at --more-- prompt | ||||
|     else if (!got_int | ||||
| 	    && (arg == NULL || vim_strchr(arg, c) != NULL) | ||||
| 	    && p->lnum != 0) | ||||
|     { | ||||
| 	if (name == NULL && current) | ||||
| 	{ | ||||
| 	    name = mark_line(p, 15); | ||||
| 	    mustfree = TRUE; | ||||
| 	} | ||||
| 	if (!message_filtered(name)) | ||||
| 	{ | ||||
| 	    if (!did_title) | ||||
| 	    { | ||||
| 	    /* Highlight title */ | ||||
| 		// Highlight title | ||||
| 		msg_puts_title(_("\nmark line  col file/text")); | ||||
| 		did_title = TRUE; | ||||
| 	    } | ||||
| @ -778,20 +786,16 @@ show_one_mark( | ||||
| 	    { | ||||
| 		sprintf((char *)IObuff, " %c %6ld %4d ", c, p->lnum, p->col); | ||||
| 		msg_outtrans(IObuff); | ||||
| 	    if (name == NULL && current) | ||||
| 	    { | ||||
| 		name = mark_line(p, 15); | ||||
| 		mustfree = TRUE; | ||||
| 	    } | ||||
| 		if (name != NULL) | ||||
| 		{ | ||||
| 		    msg_outtrans_attr(name, current ? HL_ATTR(HLF_D) : 0); | ||||
| 		} | ||||
| 	    } | ||||
| 	    out_flush();		    // show one line at a time | ||||
| 	} | ||||
| 	if (mustfree) | ||||
| 	    vim_free(name); | ||||
|     } | ||||
| 	} | ||||
| 	out_flush();		    /* show one line at a time */ | ||||
|     } | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | ||||
| @ -126,7 +126,22 @@ func Test_filter_commands() | ||||
|   let res = split(execute("filter /\.c$/ jumps"), "\n")[1:] | ||||
|   call assert_equal(["   2     1    0 file.c", ">"], res) | ||||
|  | ||||
|   bwipe file.c | ||||
|   bwipe file.h | ||||
|   bwipe file.hs | ||||
|   " Test filtering :marks command | ||||
|   b file.c | ||||
|   mark A | ||||
|   b file.h | ||||
|   mark B | ||||
|   let res = split(execute("filter /\.c$/ marks"), "\n")[1:] | ||||
|   call assert_equal([" A      1    0 file.c"], res) | ||||
|  | ||||
|   call setline(1, ['one', 'two', 'three']) | ||||
|   1mark a | ||||
|   2mark b | ||||
|   3mark c | ||||
|   let res = split(execute("filter /two/ marks abc"), "\n")[1:] | ||||
|   call assert_equal([" b      2    0 two"], res) | ||||
|  | ||||
|   bwipe! file.c | ||||
|   bwipe! file.h | ||||
|   bwipe! file.hs | ||||
| endfunc | ||||
|  | ||||
| @ -767,6 +767,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     1221, | ||||
| /**/ | ||||
|     1220, | ||||
| /**/ | ||||
|  | ||||
		Reference in New Issue
	
	Block a user