Commit a19024d309470ea2c4fe4b935cd1f51a151bf393
1 parent
f638ef95
Exists in
master
and in
5 other branches
Melhorando mecanismo de seleção
Showing
6 changed files
with
61 additions
and
47 deletions
Show diff stats
src/gtk/v3270/mouse.c
@@ -60,7 +60,7 @@ static void button_1_press(GtkWidget *widget, GdkEventType type, int baddr) | @@ -60,7 +60,7 @@ static void button_1_press(GtkWidget *widget, GdkEventType type, int baddr) | ||
60 | { | 60 | { |
61 | case GDK_BUTTON_PRESS: // Single click - Just move cursor | 61 | case GDK_BUTTON_PRESS: // Single click - Just move cursor |
62 | lib3270_set_cursor_address(GTK_V3270(widget)->host,baddr); | 62 | lib3270_set_cursor_address(GTK_V3270(widget)->host,baddr); |
63 | - lib3270_clear_selection(GTK_V3270(widget)->host); | 63 | + lib3270_unselect(GTK_V3270(widget)->host); |
64 | break; | 64 | break; |
65 | 65 | ||
66 | case GDK_2BUTTON_PRESS: // Double click - Select word | 66 | case GDK_2BUTTON_PRESS: // Double click - Select word |
src/include/lib3270/action_table.h
@@ -62,6 +62,7 @@ | @@ -62,6 +62,7 @@ | ||
62 | DECLARE_LIB3270_ACTION( selectfield ) | 62 | DECLARE_LIB3270_ACTION( selectfield ) |
63 | DECLARE_LIB3270_ACTION( selectall ) | 63 | DECLARE_LIB3270_ACTION( selectall ) |
64 | DECLARE_LIB3270_ACTION( unselect ) | 64 | DECLARE_LIB3270_ACTION( unselect ) |
65 | + DECLARE_LIB3270_ACTION( reselect ) | ||
65 | 66 | ||
66 | DECLARE_LIB3270_ACTION( firstfield ) | 67 | DECLARE_LIB3270_ACTION( firstfield ) |
67 | DECLARE_LIB3270_ACTION( eraseeof ) | 68 | DECLARE_LIB3270_ACTION( eraseeof ) |
src/include/lib3270/session.h
@@ -38,7 +38,7 @@ | @@ -38,7 +38,7 @@ | ||
38 | 38 | ||
39 | struct _h3270 | 39 | struct _h3270 |
40 | { | 40 | { |
41 | - unsigned short sz; /**< Struct size */ | 41 | + unsigned short sz; /**< Struct size */ |
42 | 42 | ||
43 | // Connection info | 43 | // Connection info |
44 | int secure_connection; | 44 | int secure_connection; |
@@ -50,6 +50,10 @@ | @@ -50,6 +50,10 @@ | ||
50 | HANDLE sock_handle; | 50 | HANDLE sock_handle; |
51 | #endif /*]*/ | 51 | #endif /*]*/ |
52 | 52 | ||
53 | + // flags | ||
54 | + int selected : 1; | ||
55 | + | ||
56 | + // Network & Termtype | ||
53 | char * hostname; | 57 | char * hostname; |
54 | char * connected_type; | 58 | char * connected_type; |
55 | char * connected_lu; | 59 | char * connected_lu; |
@@ -104,7 +108,7 @@ | @@ -104,7 +108,7 @@ | ||
104 | { | 108 | { |
105 | int begin; | 109 | int begin; |
106 | int end; | 110 | int end; |
107 | - } selected; | 111 | + } select; |
108 | 112 | ||
109 | // xio | 113 | // xio |
110 | unsigned long ns_read_id; | 114 | unsigned long ns_read_id; |
src/lib3270/glue.c
@@ -169,9 +169,6 @@ static void lib3270_session_init(H3270 *hSession, const char *model) | @@ -169,9 +169,6 @@ static void lib3270_session_init(H3270 *hSession, const char *model) | ||
169 | hSession->cstate = NOT_CONNECTED; | 169 | hSession->cstate = NOT_CONNECTED; |
170 | hSession->oia_status = -1; | 170 | hSession->oia_status = -1; |
171 | 171 | ||
172 | - hSession->selected.begin = -1; | ||
173 | - hSession->selected.end = -1; | ||
174 | - | ||
175 | strncpy(hSession->full_model_name,"IBM-",LIB3270_FULL_MODEL_NAME_LENGTH); | 172 | strncpy(hSession->full_model_name,"IBM-",LIB3270_FULL_MODEL_NAME_LENGTH); |
176 | hSession->model_name = &hSession->full_model_name[4]; | 173 | hSession->model_name = &hSession->full_model_name[4]; |
177 | 174 | ||
@@ -294,7 +291,8 @@ static void initialize(void) | @@ -294,7 +291,8 @@ static void initialize(void) | ||
294 | Trace("Initializing library (calls: %d)",init_calls); | 291 | Trace("Initializing library (calls: %d)",init_calls); |
295 | #endif | 292 | #endif |
296 | 293 | ||
297 | - h3270.selected.begin = h3270.selected.end = -1; | 294 | + h3270.selected = 0; |
295 | + h3270.select.begin = h3270.select.end = 0; | ||
298 | initialize_toggles(&h3270,appres.toggle); | 296 | initialize_toggles(&h3270,appres.toggle); |
299 | 297 | ||
300 | #if defined(_WIN32) | 298 | #if defined(_WIN32) |
src/lib3270/selection.c
@@ -44,8 +44,8 @@ static void update_selected_rectangle(H3270 *session) | @@ -44,8 +44,8 @@ static void update_selected_rectangle(H3270 *session) | ||
44 | int col; | 44 | int col; |
45 | } p[2]; | 45 | } p[2]; |
46 | 46 | ||
47 | - int begin = session->selected.begin; | ||
48 | - int end = session->selected.end; | 47 | + int begin = session->select.begin; |
48 | + int end = session->select.end; | ||
49 | int row, col, baddr; | 49 | int row, col, baddr; |
50 | 50 | ||
51 | if(begin > end) | 51 | if(begin > end) |
@@ -96,8 +96,8 @@ static void update_selected_rectangle(H3270 *session) | @@ -96,8 +96,8 @@ static void update_selected_rectangle(H3270 *session) | ||
96 | static void update_selected_region(H3270 *session) | 96 | static void update_selected_region(H3270 *session) |
97 | { | 97 | { |
98 | int baddr; | 98 | int baddr; |
99 | - int begin = session->selected.begin; | ||
100 | - int end = session->selected.end; | 99 | + int begin = session->select.begin; |
100 | + int end = session->select.end; | ||
101 | int len = session->rows*session->cols; | 101 | int len = session->rows*session->cols; |
102 | 102 | ||
103 | if(begin > end) | 103 | if(begin > end) |
@@ -146,9 +146,18 @@ void update_selection(H3270 *session) | @@ -146,9 +146,18 @@ void update_selection(H3270 *session) | ||
146 | update_selected_region(session); | 146 | update_selected_region(session); |
147 | } | 147 | } |
148 | 148 | ||
149 | +static void set_selected(H3270 *session) | ||
150 | +{ | ||
151 | + if(session->selected) | ||
152 | + return; | ||
153 | + | ||
154 | + session->selected = 1; | ||
155 | + session->set_selection(session,1); | ||
156 | +} | ||
157 | + | ||
149 | void toggle_rectselect(H3270 *session, struct toggle *t, LIB3270_TOGGLE_TYPE tt) | 158 | void toggle_rectselect(H3270 *session, struct toggle *t, LIB3270_TOGGLE_TYPE tt) |
150 | { | 159 | { |
151 | - if(session->selected.begin < 0) | 160 | + if(!session->selected) |
152 | return; | 161 | return; |
153 | 162 | ||
154 | if(t->value) | 163 | if(t->value) |
@@ -157,24 +166,25 @@ void toggle_rectselect(H3270 *session, struct toggle *t, LIB3270_TOGGLE_TYPE tt) | @@ -157,24 +166,25 @@ void toggle_rectselect(H3270 *session, struct toggle *t, LIB3270_TOGGLE_TYPE tt) | ||
157 | update_selected_region(session); | 166 | update_selected_region(session); |
158 | } | 167 | } |
159 | 168 | ||
160 | -LIB3270_EXPORT void lib3270_clear_selection(H3270 *session) | 169 | +LIB3270_ACTION(unselect) |
161 | { | 170 | { |
162 | int a; | 171 | int a; |
163 | 172 | ||
164 | - session->selected.begin = -1; | ||
165 | - session->selected.end = -1; | 173 | + CHECK_SESSION_HANDLE(hSession); |
174 | + | ||
175 | + hSession->selected = 0; | ||
166 | 176 | ||
167 | - for(a = 0; a < session->rows*session->cols; a++) | 177 | + for(a = 0; a < hSession->rows*hSession->cols; a++) |
168 | { | 178 | { |
169 | if(ea_buf[a].attr & LIB3270_ATTR_SELECTED) | 179 | if(ea_buf[a].attr & LIB3270_ATTR_SELECTED) |
170 | { | 180 | { |
171 | ea_buf[a].attr &= ~LIB3270_ATTR_SELECTED; | 181 | ea_buf[a].attr &= ~LIB3270_ATTR_SELECTED; |
172 | - if(session->update) | ||
173 | - session->update(session,a,ea_buf[a].chr,ea_buf[a].attr,a == session->cursor_addr); | 182 | + if(hSession->update) |
183 | + hSession->update(hSession,a,ea_buf[a].chr,ea_buf[a].attr,a == hSession->cursor_addr); | ||
174 | } | 184 | } |
175 | } | 185 | } |
176 | 186 | ||
177 | - session->set_selection(session,0); | 187 | + hSession->set_selection(hSession,0); |
178 | 188 | ||
179 | } | 189 | } |
180 | 190 | ||
@@ -185,12 +195,12 @@ LIB3270_EXPORT void lib3270_select_to(H3270 *session, int baddr) | @@ -185,12 +195,12 @@ LIB3270_EXPORT void lib3270_select_to(H3270 *session, int baddr) | ||
185 | if(!lib3270_connected(session)) | 195 | if(!lib3270_connected(session)) |
186 | return; | 196 | return; |
187 | 197 | ||
188 | - lib3270_set_cursor_address(session,session->selected.end = baddr); | 198 | + lib3270_set_cursor_address(session,session->select.end = baddr); |
189 | 199 | ||
190 | - if(session->selected.begin < 0) | 200 | + if(!session->selected) |
191 | { | 201 | { |
192 | - session->selected.begin = session->cursor_addr; | ||
193 | - session->set_selection(session,1); | 202 | + session->select.begin = session->cursor_addr; |
203 | + set_selected(session); | ||
194 | } | 204 | } |
195 | 205 | ||
196 | update_selection(session); | 206 | update_selection(session); |
@@ -210,12 +220,13 @@ LIB3270_EXPORT void lib3270_select_word(H3270 *session, int baddr) | @@ -210,12 +220,13 @@ LIB3270_EXPORT void lib3270_select_word(H3270 *session, int baddr) | ||
210 | } | 220 | } |
211 | 221 | ||
212 | for(pos = baddr; pos > 0 && !isspace(ea_buf[pos].chr);pos--); | 222 | for(pos = baddr; pos > 0 && !isspace(ea_buf[pos].chr);pos--); |
213 | - session->selected.begin = pos > 0 ? pos+1 : 0; | 223 | + session->select.begin = pos > 0 ? pos+1 : 0; |
214 | 224 | ||
215 | len = session->rows * session->cols; | 225 | len = session->rows * session->cols; |
216 | for(pos = baddr; pos < len && !isspace(ea_buf[pos].chr);pos++); | 226 | for(pos = baddr; pos < len && !isspace(ea_buf[pos].chr);pos++); |
217 | - session->selected.end = pos < len ? pos-1 : len; | 227 | + session->select.end = pos < len ? pos-1 : len; |
218 | 228 | ||
229 | + set_selected(session); | ||
219 | update_selected_region(session); | 230 | update_selected_region(session); |
220 | } | 231 | } |
221 | 232 | ||
@@ -239,14 +250,15 @@ LIB3270_EXPORT int lib3270_select_field_at(H3270 *session, int baddr) | @@ -239,14 +250,15 @@ LIB3270_EXPORT int lib3270_select_field_at(H3270 *session, int baddr) | ||
239 | return -1; | 250 | return -1; |
240 | } | 251 | } |
241 | 252 | ||
242 | - session->selected.begin = (start+1); | 253 | + session->select.begin = (start+1); |
243 | 254 | ||
244 | len = (session->rows * session->cols)-1; | 255 | len = (session->rows * session->cols)-1; |
245 | 256 | ||
246 | - session->selected.end = start + lib3270_field_length(session,start); | ||
247 | - if(session->selected.end > len) | ||
248 | - session->selected.end = len; | 257 | + session->select.end = start + lib3270_field_length(session,start); |
258 | + if(session->select.end > len) | ||
259 | + session->select.end = len; | ||
249 | 260 | ||
261 | + set_selected(session); | ||
250 | update_selected_region(session); | 262 | update_selected_region(session); |
251 | 263 | ||
252 | return 0; | 264 | return 0; |
@@ -254,13 +266,16 @@ LIB3270_EXPORT int lib3270_select_field_at(H3270 *session, int baddr) | @@ -254,13 +266,16 @@ LIB3270_EXPORT int lib3270_select_field_at(H3270 *session, int baddr) | ||
254 | 266 | ||
255 | LIB3270_ACTION( selectfield ) | 267 | LIB3270_ACTION( selectfield ) |
256 | { | 268 | { |
269 | + CHECK_SESSION_HANDLE(hSession); | ||
257 | lib3270_select_field_at(hSession,hSession->cursor_addr); | 270 | lib3270_select_field_at(hSession,hSession->cursor_addr); |
258 | } | 271 | } |
259 | 272 | ||
260 | LIB3270_ACTION( selectall ) | 273 | LIB3270_ACTION( selectall ) |
261 | { | 274 | { |
262 | - int len = hSession->rows*hSession->cols; | ||
263 | - int baddr; | 275 | + int len, baddr; |
276 | + | ||
277 | + CHECK_SESSION_HANDLE(hSession); | ||
278 | + len = hSession->rows*hSession->cols; | ||
264 | 279 | ||
265 | // First remove unselected areas | 280 | // First remove unselected areas |
266 | for(baddr = 0; baddr < len; baddr++) | 281 | for(baddr = 0; baddr < len; baddr++) |
@@ -271,21 +286,17 @@ LIB3270_ACTION( selectall ) | @@ -271,21 +286,17 @@ LIB3270_ACTION( selectall ) | ||
271 | hSession->update(hSession,baddr,ea_buf[baddr].chr,ea_buf[baddr].attr,baddr == hSession->cursor_addr); | 286 | hSession->update(hSession,baddr,ea_buf[baddr].chr,ea_buf[baddr].attr,baddr == hSession->cursor_addr); |
272 | } | 287 | } |
273 | } | 288 | } |
289 | + | ||
290 | + set_selected(hSession); | ||
274 | } | 291 | } |
275 | 292 | ||
276 | -LIB3270_ACTION( unselect ) | 293 | +LIB3270_ACTION( reselect ) |
277 | { | 294 | { |
278 | - int len = hSession->rows*hSession->cols; | ||
279 | - int baddr; | 295 | + CHECK_SESSION_HANDLE(hSession); |
280 | 296 | ||
281 | - // First remove unselected areas | ||
282 | - for(baddr = 0; baddr < len; baddr++) | ||
283 | - { | ||
284 | - if(ea_buf[baddr].attr & LIB3270_ATTR_SELECTED) | ||
285 | - { | ||
286 | - ea_buf[baddr].attr &= ~LIB3270_ATTR_SELECTED; | ||
287 | - hSession->update(hSession,baddr,ea_buf[baddr].chr,ea_buf[baddr].attr,baddr == hSession->cursor_addr); | ||
288 | - } | ||
289 | - } | ||
290 | -} | 297 | + if(hSession->selected || hSession->select.begin == hSession->select.end) |
298 | + return; | ||
291 | 299 | ||
300 | + update_selection(hSession); | ||
301 | + set_selected(hSession); | ||
302 | +} |
ui/default.xml
@@ -62,11 +62,11 @@ | @@ -62,11 +62,11 @@ | ||
62 | 62 | ||
63 | <menuitem action='selectfield' key='<Ctrl>f' group='online' label='Select Field' /> | 63 | <menuitem action='selectfield' key='<Ctrl>f' group='online' label='Select Field' /> |
64 | <menuitem action='unselect' group='selection' label='unselect' /> | 64 | <menuitem action='unselect' group='selection' label='unselect' /> |
65 | - <!--- menuitem action='Reselect' key='<Ctrl>r' group='online' label='Reselect' /---> | 65 | + <menuitem action='reselect' key='<Ctrl>r' group='online' label='Reselect' /> |
66 | 66 | ||
67 | <separator/> | 67 | <separator/> |
68 | - <menuitem action='Clear' group='online' key='Pause' label='Clear' /> | ||
69 | - <menuitem action='EraseInput' icon='clear' group='online' label='Erase input' /> | 68 | + <menuitem action='clear' group='online' key='Pause' label='Clear' /> |
69 | + <menuitem action='eraseinput' icon='clear' group='online' label='Erase input' /> | ||
70 | <!--- <menuitem action='EraseField' key='<Ctrl>u' group='online' /> --> | 70 | <!--- <menuitem action='EraseField' key='<Ctrl>u' group='online' /> --> |
71 | <menuitem action='EraseEOF' group='online' label='Erase to end of field' /> | 71 | <menuitem action='EraseEOF' group='online' label='Erase to end of field' /> |
72 | <menuitem action='EraseEOL' group='online' label='Erase to end of line' /> | 72 | <menuitem action='EraseEOL' group='online' label='Erase to end of line' /> |