Compare commits
	
		
			2 Commits
		
	
	
		
			bb4e732a25
			...
			2b5eb86a9f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 2b5eb86a9f | |||
| 85ca0c5857 | 
							
								
								
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							| @ -1,4 +1,4 @@ | ||||
| Copyright (c) 2013 - 2020, Přemysl Eric Janouch <p@janouch.name> | ||||
| Copyright (c) 2013 - 2021, Přemysl Eric Janouch <p@janouch.name> | ||||
| 
 | ||||
| Permission to use, copy, modify, and/or distribute this software for any | ||||
| purpose with or without fee is hereby granted. | ||||
|  | ||||
							
								
								
									
										70
									
								
								src/sdtui.c
									
									
									
									
									
								
							
							
						
						
									
										70
									
								
								src/sdtui.c
									
									
									
									
									
								
							| @ -1,7 +1,7 @@ | ||||
| /*
 | ||||
|  * StarDict terminal UI | ||||
|  * | ||||
|  * Copyright (c) 2013 - 2020, Přemysl Eric Janouch <p@janouch.name> | ||||
|  * Copyright (c) 2013 - 2021, Přemysl Eric Janouch <p@janouch.name> | ||||
|  * | ||||
|  * Permission to use, copy, modify, and/or distribute this software for any | ||||
|  * purpose with or without fee is hereby granted. | ||||
| @ -157,12 +157,14 @@ resolve_filename (const gchar *filename, gchar *(*relative_cb) (const char *)) | ||||
| 
 | ||||
| // --- Application -------------------------------------------------------------
 | ||||
| 
 | ||||
| #define ATTRIBUTE_TABLE(XX)                            \ | ||||
| 	XX( HEADER, "header",        -1, -1, A_REVERSE   ) \ | ||||
| 	XX( ACTIVE, "header-active", -1, -1, A_UNDERLINE ) \ | ||||
| 	XX( SEARCH, "search",        -1, -1, A_UNDERLINE ) \ | ||||
| 	XX( EVEN,   "even",          -1, -1, 0           ) \ | ||||
| 	XX( ODD,    "odd",           -1, -1, 0           ) | ||||
| #define ATTRIBUTE_TABLE(XX)                               \ | ||||
| 	XX( HEADER,    "header",        -1, -1, A_REVERSE   ) \ | ||||
| 	XX( ACTIVE,    "header-active", -1, -1, A_UNDERLINE ) \ | ||||
| 	XX( SEARCH,    "search",        -1, -1, A_UNDERLINE ) \ | ||||
| 	XX( EVEN,      "even",          -1, -1, 0           ) \ | ||||
| 	XX( ODD,       "odd",           -1, -1, 0           ) \ | ||||
| 	XX( SELECTION, "selection",     -1, -1, A_REVERSE   ) \ | ||||
| 	XX( DEFOCUSED, "defocused",     -1, -1, A_REVERSE   ) | ||||
| 
 | ||||
| enum | ||||
| { | ||||
| @ -210,6 +212,7 @@ struct application | ||||
| 	guint           tk_timer;           ///< termo timeout timer
 | ||||
| 	GIConv          ucs4_to_locale;     ///< UTF-32 -> locale conversion
 | ||||
| 	gboolean        locale_is_utf8;     ///< The locale is Unicode
 | ||||
| 	gboolean        focused;            ///< Whether the terminal has focus
 | ||||
| 
 | ||||
| 	GArray        * dictionaries;       ///< All loaded dictionaries
 | ||||
| 
 | ||||
| @ -628,6 +631,7 @@ app_init (Application *self, char **filenames) | ||||
| #else // G_BYTE_ORDER != G_LITTLE_ENDIAN
 | ||||
| 	self->ucs4_to_locale = g_iconv_open (charset, "UTF-32BE"); | ||||
| #endif // G_BYTE_ORDER != G_LITTLE_ENDIAN
 | ||||
| 	self->focused = TRUE; | ||||
| 
 | ||||
| 	app_init_attrs (self); | ||||
| 	self->dictionaries = g_array_new (FALSE, TRUE, sizeof (Dictionary)); | ||||
| @ -688,6 +692,10 @@ app_init_terminal (Application *self) | ||||
| 	gboolean failed = FALSE; | ||||
| 	for (int a = 0; a < ATTRIBUTE_COUNT; a++) | ||||
| 	{ | ||||
| 		if (self->attrs[a].fg == -1 && | ||||
| 			self->attrs[a].bg == -1) | ||||
| 			continue; | ||||
| 
 | ||||
| 		if (self->attrs[a].fg >= COLORS || self->attrs[a].fg < -1 | ||||
| 		 || self->attrs[a].bg >= COLORS || self->attrs[a].bg < -1) | ||||
| 		{ | ||||
| @ -980,7 +988,7 @@ app_show_help (Application *self) | ||||
| 	{ | ||||
| 		PROJECT_NAME " " PROJECT_VERSION, | ||||
| 		_("Terminal UI for StarDict dictionaries"), | ||||
| 		"Copyright (c) 2013 - 2020, Přemysl Eric Janouch", | ||||
| 		"Copyright (c) 2013 - 2021, Přemysl Eric Janouch", | ||||
| 		"", | ||||
| 		_("Type to search") | ||||
| 	}; | ||||
| @ -988,6 +996,16 @@ app_show_help (Application *self) | ||||
| 	app_show_message (self, lines, G_N_ELEMENTS (lines)); | ||||
| } | ||||
| 
 | ||||
| /// Combine attributes, taking care to replace colour bits entirely
 | ||||
| static void | ||||
| app_merge_attributes (int *target, int merged) | ||||
| { | ||||
| 	if (merged & A_COLOR) | ||||
| 		*target = (*target & ~A_COLOR) | merged; | ||||
| 	else | ||||
| 		*target |= merged; | ||||
| } | ||||
| 
 | ||||
| /// Redraw the dictionary view.
 | ||||
| static void | ||||
| app_redraw_view (Application *self) | ||||
| @ -1014,9 +1032,14 @@ app_redraw_view (Application *self) | ||||
| 		{ | ||||
| 			int attrs = ((self->top_position + i) & 1) | ||||
| 				? APP_ATTR (ODD) : APP_ATTR (EVEN); | ||||
| 			if (shown == self->selected)      attrs |= A_REVERSE; | ||||
| 
 | ||||
| 			if (shown == self->selected) | ||||
| 				app_merge_attributes (&attrs, self->focused | ||||
| 					? APP_ATTR (SELECTION) : APP_ATTR (DEFOCUSED)); | ||||
| 
 | ||||
| 			gboolean last = k + 1 == ve->definitions_length; | ||||
| 			if (last && self->underline_last) attrs |= A_UNDERLINE; | ||||
| 			if (last && self->underline_last) | ||||
| 				attrs |= A_UNDERLINE; | ||||
| 
 | ||||
| 			RowBuffer buf; | ||||
| 			row_buffer_init (&buf, self); | ||||
| @ -1793,6 +1816,14 @@ app_process_termo_event (Application *self, termo_key_t *event) | ||||
| 		return app_process_key (self, event); | ||||
| 	case TERMO_TYPE_KEYSYM: | ||||
| 		return app_process_keysym (self, event); | ||||
| 	case TERMO_TYPE_FOCUS: | ||||
| 	{ | ||||
| 		SAVE_CURSOR | ||||
| 		self->focused = !!event->code.focused; | ||||
| 		app_redraw_view (self); | ||||
| 		RESTORE_CURSOR | ||||
| 		return TRUE; | ||||
| 	} | ||||
| 	default: | ||||
| 		return TRUE; | ||||
| 	} | ||||
| @ -1842,13 +1873,26 @@ app_set_input (Application *self, const gchar *text, gsize text_len) | ||||
| 	self->input_pos = 0; | ||||
| 
 | ||||
| 	gunichar *p = output; | ||||
| 	gboolean last_was_space = false; | ||||
| 	while (size--) | ||||
| 	{ | ||||
| 		// XXX: skip?
 | ||||
| 		if (!g_unichar_isprint (*p)) | ||||
| 		// Normalize whitespace, to cover OCR anomalies
 | ||||
| 		gunichar c = *p++; | ||||
| 		if (!g_unichar_isspace (c)) | ||||
| 			last_was_space = FALSE; | ||||
| 		else if (last_was_space) | ||||
| 			continue; | ||||
| 		else | ||||
| 		{ | ||||
| 			c = ' '; | ||||
| 			last_was_space = TRUE; | ||||
| 		} | ||||
| 
 | ||||
| 		// XXX: skip?  Might be some binary nonsense.
 | ||||
| 		if (!g_unichar_isprint (c)) | ||||
| 			break; | ||||
| 
 | ||||
| 		g_array_insert_val (self->input, self->input_pos++, *p++); | ||||
| 		g_array_insert_val (self->input, self->input_pos++, c); | ||||
| 	} | ||||
| 	g_free (output); | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										2
									
								
								termo
									
									
									
									
									
								
							
							
								
								
								
								
								
								
									
									
								
							
						
						
									
										2
									
								
								termo
									
									
									
									
									
								
							| @ -1 +1 @@ | ||||
| Subproject commit f7912a8ce7bbf7f701b5217bbb3879b13b66cfe7 | ||||
| Subproject commit 94a77a10d87367ef33156cd68b2caf601c3f72d0 | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user