Remove one indentation level in getsel().
This commit is contained in:
		
				
					committed by
					
						
						Roberto E. Vargas Caballero
					
				
			
			
				
	
			
			
			
						parent
						
							6681af165b
						
					
				
				
					commit
					74962bf566
				
			
							
								
								
									
										97
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										97
									
								
								st.c
									
									
									
									
									
								
							@ -922,60 +922,59 @@ getsel(void) {
 | 
				
			|||||||
	int x, y, bufsize, size, i, ex;
 | 
						int x, y, bufsize, size, i, ex;
 | 
				
			||||||
	Glyph *gp, *last;
 | 
						Glyph *gp, *last;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(sel.ob.x == -1) {
 | 
						if(sel.ob.x == -1)
 | 
				
			||||||
		str = NULL;
 | 
							return NULL;
 | 
				
			||||||
	} else {
 | 
					 | 
				
			||||||
		bufsize = (term.col+1) * (sel.ne.y-sel.nb.y+1) * UTF_SIZ;
 | 
					 | 
				
			||||||
		ptr = str = xmalloc(bufsize);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* append every set & selected glyph to the selection */
 | 
						bufsize = (term.col+1) * (sel.ne.y-sel.nb.y+1) * UTF_SIZ;
 | 
				
			||||||
		for(y = sel.nb.y; y < sel.ne.y + 1; y++) {
 | 
						ptr = str = xmalloc(bufsize);
 | 
				
			||||||
			gp = &term.line[y][0];
 | 
					 | 
				
			||||||
			last = &gp[term.col-1];
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
			while(last >= gp && !(selected(last - gp, y) &&
 | 
						/* append every set & selected glyph to the selection */
 | 
				
			||||||
			                      strcmp(last->c, " ") != 0)) {
 | 
						for(y = sel.nb.y; y < sel.ne.y + 1; y++) {
 | 
				
			||||||
				--last;
 | 
							gp = &term.line[y][0];
 | 
				
			||||||
			}
 | 
							last = &gp[term.col-1];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			for(x = 0; gp <= last; x++, ++gp) {
 | 
							while(last >= gp && !(selected(last - gp, y) &&
 | 
				
			||||||
				if(!selected(x, y) || (gp->mode & ATTR_WDUMMY))
 | 
									      strcmp(last->c, " ") != 0)) {
 | 
				
			||||||
					continue;
 | 
								--last;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
				size = utf8len(gp->c);
 | 
					
 | 
				
			||||||
				memcpy(ptr, gp->c, size);
 | 
							for(x = 0; gp <= last; x++, ++gp) {
 | 
				
			||||||
				ptr += size;
 | 
								if(!selected(x, y) || (gp->mode & ATTR_WDUMMY))
 | 
				
			||||||
			}
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			/*
 | 
								size = utf8len(gp->c);
 | 
				
			||||||
			 * Copy and pasting of line endings is inconsistent
 | 
								memcpy(ptr, gp->c, size);
 | 
				
			||||||
			 * in the inconsistent terminal and GUI world.
 | 
								ptr += size;
 | 
				
			||||||
			 * The best solution seems like to produce '\n' when
 | 
							}
 | 
				
			||||||
			 * something is copied from st and convert '\n' to
 | 
					
 | 
				
			||||||
			 * '\r', when something to be pasted is received by
 | 
							/*
 | 
				
			||||||
			 * st.
 | 
							 * Copy and pasting of line endings is inconsistent
 | 
				
			||||||
			 * FIXME: Fix the computer world.
 | 
							 * in the inconsistent terminal and GUI world.
 | 
				
			||||||
			 */
 | 
							 * The best solution seems like to produce '\n' when
 | 
				
			||||||
			if(y < sel.ne.y && x > 0 && !((gp-1)->mode & ATTR_WRAP))
 | 
							 * something is copied from st and convert '\n' to
 | 
				
			||||||
				*ptr++ = '\n';
 | 
							 * '\r', when something to be pasted is received by
 | 
				
			||||||
 | 
							 * st.
 | 
				
			||||||
			/*
 | 
							 * FIXME: Fix the computer world.
 | 
				
			||||||
			 * If the last selected line expands in the selection
 | 
							 */
 | 
				
			||||||
			 * after the visible text '\n' is appended.
 | 
							if(y < sel.ne.y && x > 0 && !((gp-1)->mode & ATTR_WRAP))
 | 
				
			||||||
			 */
 | 
								*ptr++ = '\n';
 | 
				
			||||||
			if(y == sel.ne.y) {
 | 
					
 | 
				
			||||||
				i = term.col;
 | 
							/*
 | 
				
			||||||
				while(--i > 0 && term.line[y][i].c[0] == ' ')
 | 
							 * If the last selected line expands in the selection
 | 
				
			||||||
					/* nothing */;
 | 
							 * after the visible text '\n' is appended.
 | 
				
			||||||
				ex = sel.ne.x;
 | 
							 */
 | 
				
			||||||
				if(sel.nb.y == sel.ne.y && sel.ne.x < sel.nb.x)
 | 
							if(y == sel.ne.y) {
 | 
				
			||||||
					ex = sel.nb.x;
 | 
								i = term.col;
 | 
				
			||||||
				if(i < ex)
 | 
								while(--i > 0 && term.line[y][i].c[0] == ' ')
 | 
				
			||||||
					*ptr++ = '\n';
 | 
									/* nothing */;
 | 
				
			||||||
			}
 | 
								ex = sel.ne.x;
 | 
				
			||||||
 | 
								if(sel.nb.y == sel.ne.y && sel.ne.x < sel.nb.x)
 | 
				
			||||||
 | 
									ex = sel.nb.x;
 | 
				
			||||||
 | 
								if(i < ex)
 | 
				
			||||||
 | 
									*ptr++ = '\n';
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		*ptr = 0;
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
						*ptr = 0;
 | 
				
			||||||
	return str;
 | 
						return str;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user