Commit 3b6932ddbd5be57245042224b2fd316289a8ce41
1 parent
36c13ad1
Exists in
master
and in
3 other branches
Refactoring "lunames" property.
Showing
8 changed files
with
162 additions
and
46 deletions
Show diff stats
src/core/host.c
... | ... | @@ -261,13 +261,6 @@ static void update_url(H3270 *hSession) |
261 | 261 | |
262 | 262 | } |
263 | 263 | |
264 | -LIB3270_EXPORT int lib3270_set_luname(H3270 *hSession, const char *luname) | |
265 | -{ | |
266 | - FAIL_IF_ONLINE(hSession); | |
267 | - strncpy(hSession->lu.names,luname,LIB3270_LUNAME_LENGTH); | |
268 | - return 0; | |
269 | -} | |
270 | - | |
271 | 264 | LIB3270_EXPORT const char * lib3270_get_associated_luname(const H3270 *hSession) |
272 | 265 | { |
273 | 266 | if(check_online_session(hSession)) | ... | ... |
src/core/properties/string.c
... | ... | @@ -33,6 +33,7 @@ |
33 | 33 | #include <lib3270.h> |
34 | 34 | #include <lib3270/properties.h> |
35 | 35 | #include <lib3270/keyboard.h> |
36 | + #include <lib3270/log.h> | |
36 | 37 | |
37 | 38 | static const char * get_version(const H3270 GNUC_UNUSED(*hSession)) |
38 | 39 | { |
... | ... | @@ -289,3 +290,73 @@ int lib3270_set_string_property(H3270 *hSession, const char *name, const char * |
289 | 290 | |
290 | 291 | } |
291 | 292 | |
293 | +/* | |
294 | +LIB3270_EXPORT int lib3270_set_luname(H3270 *hSession, const char *luname) | |
295 | +{ | |
296 | + FAIL_IF_ONLINE(hSession); | |
297 | + strncpy(hSession->lu.names,luname,LIB3270_LUNAME_LENGTH); | |
298 | + return 0; | |
299 | +} | |
300 | +*/ | |
301 | + | |
302 | +LIB3270_EXPORT int lib3270_set_lunames(H3270 *hSession, const char *lunames) | |
303 | +{ | |
304 | + FAIL_IF_ONLINE(hSession); | |
305 | + | |
306 | + if(hSession->lu.names) | |
307 | + { | |
308 | + lib3270_free(hSession->lu.names); | |
309 | + hSession->lu.names = NULL; | |
310 | + } | |
311 | + | |
312 | + // Do I have lunames to set? If not just return. | |
313 | + if(!lunames) | |
314 | + return 0; | |
315 | + | |
316 | + // | |
317 | + // Count the commas in the LU names. That plus one is the | |
318 | + // number of LUs to try. | |
319 | + // | |
320 | + char *comma; | |
321 | + char *lu; | |
322 | + int n_lus = 1; | |
323 | + | |
324 | + lu = (char *) lunames; | |
325 | + while ((comma = strchr(lu, ',')) != CN) | |
326 | + { | |
327 | + n_lus++; | |
328 | + lu++; | |
329 | + } | |
330 | + | |
331 | + // | |
332 | + // Allocate enough memory to construct an argv[] array for | |
333 | + // the LUs. | |
334 | + // | |
335 | + Replace(hSession->lu.names,(char **)lib3270_malloc((n_lus+1) * sizeof(char *) + strlen(lunames) + 1)); | |
336 | + | |
337 | + // Copy each LU into the array. | |
338 | + lu = (char *)(hSession->lu.names + n_lus + 1); | |
339 | + (void) strcpy(lu, lunames); | |
340 | + | |
341 | + size_t i = 0; | |
342 | + do | |
343 | + { | |
344 | + hSession->lu.names[i++] = lu; | |
345 | + comma = strchr(lu, ','); | |
346 | + if (comma != CN) | |
347 | + { | |
348 | + *comma = '\0'; | |
349 | + lu = comma + 1; | |
350 | + } | |
351 | + } while (comma != CN); | |
352 | + | |
353 | + hSession->lu.names[i] = CN; | |
354 | + | |
355 | + return 0; | |
356 | +} | |
357 | + | |
358 | +LIB3270_EXPORT const char ** lib3270_get_lunames(H3270 *hSession) | |
359 | +{ | |
360 | + return (const char **) hSession->lu.names; | |
361 | +} | |
362 | + | ... | ... |
src/core/session.c
... | ... | @@ -99,6 +99,14 @@ void lib3270_session_free(H3270 *h) |
99 | 99 | for(f=0;f<LIB3270_ACTION_GROUP_CUSTOM;f++) |
100 | 100 | lib3270_linked_list_free(&h->listeners.actions[f]); |
101 | 101 | |
102 | + // Release Lu names | |
103 | + if(h->lu.names) | |
104 | + { | |
105 | + lib3270_free(h->lu.names); | |
106 | + h->lu.names = NULL; | |
107 | + } | |
108 | + | |
109 | + | |
102 | 110 | // Release memory |
103 | 111 | #define release_pointer(x) lib3270_free(x); x = NULL; |
104 | 112 | ... | ... |
src/core/telnet.c
... | ... | @@ -369,13 +369,26 @@ void popup_a_sockerr(H3270 *hSession, char *fmt, ...) |
369 | 369 | // Set up the LU list. |
370 | 370 | static void setup_lus(H3270 *hSession) |
371 | 371 | { |
372 | + hSession->lu.associated = CN; | |
373 | + hSession->connected_type = CN; | |
374 | + | |
375 | + if(hSession->lu.names) | |
376 | + { | |
377 | + hSession->lu.curr = hSession->lu.names; | |
378 | + hSession->lu.try = * hSession->lu.curr; | |
379 | + } | |
380 | + else | |
381 | + { | |
382 | + hSession->lu.curr = (char **)NULL; | |
383 | + hSession->lu.try = CN; | |
384 | + } | |
385 | + | |
386 | + /* | |
372 | 387 | char *lu; |
373 | 388 | char *comma; |
374 | 389 | int n_lus = 1; |
375 | 390 | int i; |
376 | 391 | |
377 | - hSession->lu.associated = CN; | |
378 | - hSession->connected_type = CN; | |
379 | 392 | |
380 | 393 | if (!hSession->lu.names[0]) |
381 | 394 | { |
... | ... | @@ -419,8 +432,8 @@ static void setup_lus(H3270 *hSession) |
419 | 432 | } while (comma != CN); |
420 | 433 | |
421 | 434 | hSession->lus[i] = CN; |
422 | - hSession->curr_lu = hSession->lus; | |
423 | - hSession->try_lu = *hSession->curr_lu; | |
435 | + */ | |
436 | + | |
424 | 437 | } |
425 | 438 | |
426 | 439 | static int net_connected(H3270 *hSession) |
... | ... | @@ -775,11 +788,13 @@ static void send_naws(H3270 *hSession) |
775 | 788 | |
776 | 789 | |
777 | 790 | |
778 | -/* Advance 'try_lu' to the next desired LU name. */ | |
791 | +/// | |
792 | +/// @brief Advance 'try_lu' to the next desired LU name. | |
793 | +/// | |
779 | 794 | static void next_lu(H3270 *hSession) |
780 | 795 | { |
781 | - if (hSession->curr_lu != (char **)NULL && (hSession->try_lu = *++hSession->curr_lu) == CN) | |
782 | - hSession->curr_lu = (char **)NULL; | |
796 | + if (hSession->lu.curr != (char **)NULL && (hSession->lu.try = *++hSession->lu.curr) == CN) | |
797 | + hSession->lu.curr = (char **)NULL; | |
783 | 798 | } |
784 | 799 | |
785 | 800 | /* |
... | ... | @@ -1087,7 +1102,7 @@ static int telnet_fsm(H3270 *hSession, unsigned char c) |
1087 | 1102 | |
1088 | 1103 | trace_dsn(hSession,"%s %s\n", opt(hSession->sbbuf[0]),telquals[hSession->sbbuf[1]]); |
1089 | 1104 | |
1090 | - if (hSession->lus != (char **)NULL && hSession->try_lu == CN) | |
1105 | + if (hSession->lu.names != (char **)NULL && hSession->lu.try == CN) | |
1091 | 1106 | { |
1092 | 1107 | // None of the LUs worked. |
1093 | 1108 | popup_an_error(hSession, _( "Cannot connect to specified LU" ) ); |
... | ... | @@ -1095,10 +1110,10 @@ static int telnet_fsm(H3270 *hSession, unsigned char c) |
1095 | 1110 | } |
1096 | 1111 | |
1097 | 1112 | tt_len = strlen(hSession->termtype); |
1098 | - if (hSession->try_lu != CN && *hSession->try_lu) | |
1113 | + if (hSession->lu.try != CN && *hSession->lu.try) | |
1099 | 1114 | { |
1100 | - tt_len += strlen(hSession->try_lu) + 1; | |
1101 | - hSession->lu.associated = hSession->try_lu; | |
1115 | + tt_len += strlen(hSession->lu.try) + 1; | |
1116 | + hSession->lu.associated = hSession->lu.try; | |
1102 | 1117 | } |
1103 | 1118 | else |
1104 | 1119 | { |
... | ... | @@ -1112,8 +1127,8 @@ static int telnet_fsm(H3270 *hSession, unsigned char c) |
1112 | 1127 | (void) sprintf(tt_out, "%c%c%c%c%s%s%s%c%c", |
1113 | 1128 | IAC, SB, TELOPT_TTYPE, TELQUAL_IS, |
1114 | 1129 | hSession->termtype, |
1115 | - (hSession->try_lu != CN && *hSession->try_lu) ? "@" : "", | |
1116 | - (hSession->try_lu != CN && *hSession->try_lu) ? hSession->try_lu : "", | |
1130 | + (hSession->lu.try != CN && *hSession->lu.try) ? "@" : "", | |
1131 | + (hSession->lu.try != CN && *hSession->lu.try) ? hSession->lu.try : "", | |
1117 | 1132 | IAC, SE); |
1118 | 1133 | net_rawout(hSession, (unsigned char *)tt_out, tb_len); |
1119 | 1134 | |
... | ... | @@ -1175,7 +1190,7 @@ static void continue_tls(H3270 *hSession, unsigned char *sbbuf, int len) |
1175 | 1190 | #endif // HAVE_LIBSSL |
1176 | 1191 | |
1177 | 1192 | #if defined(X3270_TN3270E) /*[*/ |
1178 | -/* Send a TN3270E terminal type request. */ | |
1193 | +/// @brief Send a TN3270E terminal type request. | |
1179 | 1194 | static void tn3270e_request(H3270 *hSession) |
1180 | 1195 | { |
1181 | 1196 | int tt_len, tb_len; |
... | ... | @@ -1183,8 +1198,8 @@ static void tn3270e_request(H3270 *hSession) |
1183 | 1198 | char *t; |
1184 | 1199 | |
1185 | 1200 | tt_len = strlen(hSession->termtype); |
1186 | - if (hSession->try_lu != CN && *hSession->try_lu) | |
1187 | - tt_len += strlen(hSession->try_lu) + 1; | |
1201 | + if (hSession->lu.try != CN && *hSession->lu.try) | |
1202 | + tt_len += strlen(hSession->lu.try) + 1; | |
1188 | 1203 | |
1189 | 1204 | tb_len = 5 + tt_len + 2; |
1190 | 1205 | tt_out = lib3270_malloc(tb_len + 1); |
... | ... | @@ -1197,8 +1212,8 @@ static void tn3270e_request(H3270 *hSession) |
1197 | 1212 | if (tt_out[12] == '9') |
1198 | 1213 | tt_out[12] = '8'; |
1199 | 1214 | |
1200 | - if (hSession->try_lu != CN && *hSession->try_lu) | |
1201 | - t += sprintf(t, "%c%s", TN3270E_OP_CONNECT, hSession->try_lu); | |
1215 | + if (hSession->lu.try != CN && *hSession->lu.try) | |
1216 | + t += sprintf(t, "%c%s", TN3270E_OP_CONNECT, hSession->lu.try); | |
1202 | 1217 | |
1203 | 1218 | (void) sprintf(t, "%c%c", IAC, SE); |
1204 | 1219 | |
... | ... | @@ -1210,8 +1225,8 @@ static void tn3270e_request(H3270 *hSession) |
1210 | 1225 | opt(TELOPT_TN3270E), |
1211 | 1226 | (int) strlen(hSession->termtype), |
1212 | 1227 | tt_out + 5, |
1213 | - (hSession->try_lu != CN && *hSession->try_lu) ? " CONNECT " : "", | |
1214 | - (hSession->try_lu != CN && *hSession->try_lu) ? hSession->try_lu : "", | |
1228 | + (hSession->lu.try != CN && *hSession->lu.try) ? " CONNECT " : "", | |
1229 | + (hSession->lu.try != CN && *hSession->lu.try) ? hSession->lu.try : "", | |
1215 | 1230 | cmd(SE) |
1216 | 1231 | ); |
1217 | 1232 | |
... | ... | @@ -1332,14 +1347,14 @@ static int tn3270e_negotiate(H3270 *hSession) |
1332 | 1347 | } |
1333 | 1348 | |
1334 | 1349 | next_lu(hSession); |
1335 | - if (hSession->try_lu != CN) | |
1350 | + if (hSession->lu.try != CN) | |
1336 | 1351 | { |
1337 | - /* Try the next LU. */ | |
1352 | + // Try the next LU. | |
1338 | 1353 | tn3270e_request(hSession); |
1339 | 1354 | } |
1340 | - else if (hSession->lus != (char **)NULL) | |
1355 | + else if (hSession->lu.names != (char **)NULL) | |
1341 | 1356 | { |
1342 | - /* No more LUs to try. Give up. */ | |
1357 | + // No more LUs to try. Give up. | |
1343 | 1358 | backoff_tn3270e(hSession,_("Host rejected resource(s)")); |
1344 | 1359 | } |
1345 | 1360 | else |
... | ... | @@ -2096,9 +2111,9 @@ static void check_in3270(H3270 *hSession) |
2096 | 2111 | // TN3270E mode, reset the LU list so we can try again |
2097 | 2112 | // in the new mode. |
2098 | 2113 | // |
2099 | - if (hSession->lus != (char **)NULL && was_in_e != IN_E) { | |
2100 | - hSession->curr_lu = hSession->lus; | |
2101 | - hSession->try_lu = *hSession->curr_lu; | |
2114 | + if (hSession->lu.names != (char **)NULL && was_in_e != IN_E) { | |
2115 | + hSession->lu.curr = hSession->lu.names; | |
2116 | + hSession->lu.try = *hSession->lu.curr; | |
2102 | 2117 | } |
2103 | 2118 | #endif |
2104 | 2119 | ... | ... |
src/core/toggles/table.c
... | ... | @@ -239,8 +239,8 @@ const LIB3270_TOGGLE toggle_descriptor[LIB3270_TOGGLE_COUNT+1] = |
239 | 239 | .def = False, |
240 | 240 | .key = NULL, // Default keycode |
241 | 241 | .icon = NULL, // Icon name |
242 | - .label = N_( "Auto connect" ), | |
243 | - .summary = N_( "Connect on startup" ), | |
242 | + .label = N_( "Connect on startup" ), | |
243 | + .summary = N_( "Automatically connect to host on startup" ), | |
244 | 244 | .description = "" |
245 | 245 | }, |
246 | 246 | { | ... | ... |
src/include/internals.h
... | ... | @@ -508,14 +508,13 @@ struct _h3270 |
508 | 508 | */ |
509 | 509 | |
510 | 510 | /// @brief LU |
511 | - char **curr_lu; | |
512 | - char * try_lu; | |
513 | - char **lus; ///< @brief Array with the LU names to try. | |
514 | 511 | struct |
515 | 512 | { |
516 | - char reported[LIB3270_LU_MAX+1]; | |
517 | - char * associated; ///< @brief The LU name associated with the session. | |
518 | - char names[LIB3270_LUNAME_LENGTH+1]; ///< @brief The LU names to try. | |
513 | + char reported[LIB3270_LU_MAX+1]; | |
514 | + const char * associated; ///< @brief The LU name associated with the session. | |
515 | + char **names; ///< @brief Array with the LU names to try. | |
516 | + char **curr; | |
517 | + const char * try; | |
519 | 518 | |
520 | 519 | } lu; |
521 | 520 | ... | ... |
src/include/lib3270.h
... | ... | @@ -964,7 +964,7 @@ |
964 | 964 | LIB3270_EXPORT void lib3270_register_fd_handlers(void * (*add)(H3270 *session, int fd, LIB3270_IO_FLAG flag, void(*proc)(H3270 *, int, LIB3270_IO_FLAG, void *), void *userdata), void (*rm)(H3270 *, void *id)); |
965 | 965 | |
966 | 966 | /** |
967 | - * Get program message. | |
967 | + * @brief Get program message. | |
968 | 968 | * |
969 | 969 | * @see LIB3270_MESSAGE |
970 | 970 | * |
... | ... | @@ -976,7 +976,7 @@ |
976 | 976 | LIB3270_EXPORT LIB3270_MESSAGE lib3270_get_program_message(const H3270 *h); |
977 | 977 | |
978 | 978 | /** |
979 | - * Get the LU name associated with the session, if there is one. | |
979 | + * @brief Get the LU name associated with the session, if there is one. | |
980 | 980 | * |
981 | 981 | * Get the name LU associated with the session; the value is |
982 | 982 | * internal to lib3270 and should not be changed ou freed. |
... | ... | @@ -988,7 +988,21 @@ |
988 | 988 | */ |
989 | 989 | LIB3270_EXPORT const char * lib3270_get_associated_luname(const H3270 *hSession); |
990 | 990 | |
991 | - LIB3270_EXPORT int lib3270_set_luname(H3270 *hSession, const char *luname); | |
991 | + /** | |
992 | + * @brief Set the LU names. | |
993 | + * | |
994 | + * @param hSession Session handle. | |
995 | + * @param lunames Comma separated list of the LU names to set. | |
996 | + * | |
997 | + * @return 0 if the list was set, non zero if not (sets errno) | |
998 | + * | |
999 | + * @retval EISCONN The session is online. | |
1000 | + * @retval EINVAL Invalid session handle. | |
1001 | + * | |
1002 | + */ | |
1003 | + LIB3270_EXPORT int lib3270_set_lunames(H3270 *hSession, const char *luname); | |
1004 | + | |
1005 | + LIB3270_EXPORT const char ** lib3270_get_lunames(H3270 *hSession); | |
992 | 1006 | |
993 | 1007 | LIB3270_EXPORT int lib3270_is_connected(const H3270 *h); |
994 | 1008 | LIB3270_EXPORT int lib3270_is_disconnected(const H3270 *h); | ... | ... |
src/testprogram/testprogram.c
... | ... | @@ -9,6 +9,7 @@ |
9 | 9 | #include <lib3270/actions.h> |
10 | 10 | #include <lib3270/trace.h> |
11 | 11 | #include <lib3270/toggle.h> |
12 | +#include <lib3270/log.h> | |
12 | 13 | |
13 | 14 | #define MAX_ARGS 10 |
14 | 15 | |
... | ... | @@ -19,7 +20,7 @@ static void write_trace(H3270 GNUC_UNUSED(*session), void GNUC_UNUSED(*userdata) |
19 | 20 | FILE *out = fopen(trace_file,"a"); |
20 | 21 | if(out) |
21 | 22 | { |
22 | - | |
23 | + | |
23 | 24 | vfprintf(out,fmt,args); |
24 | 25 | fclose(out); |
25 | 26 | } |
... | ... | @@ -149,6 +150,21 @@ int main(int argc, char *argv[]) |
149 | 150 | |
150 | 151 | lib3270_unregister_action_group_listener(h,LIB3270_ACTION_GROUP_ONLINE,online_listener); |
151 | 152 | |
153 | + lib3270_disconnect(h); | |
154 | + | |
155 | + { | |
156 | + lib3270_set_lunames(h,"a,b,c,d,e"); | |
157 | + | |
158 | + const char ** names = lib3270_get_lunames(h); | |
159 | + | |
160 | + size_t i; | |
161 | + for(i=0;names[i];i++) | |
162 | + { | |
163 | + debug("[%s]",names[i]); | |
164 | + } | |
165 | + | |
166 | + } | |
167 | + | |
152 | 168 | lib3270_session_free(h); |
153 | 169 | |
154 | 170 | return 0; | ... | ... |