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,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 | LIB3270_EXPORT const char * lib3270_get_associated_luname(const H3270 *hSession) | 264 | LIB3270_EXPORT const char * lib3270_get_associated_luname(const H3270 *hSession) |
272 | { | 265 | { |
273 | if(check_online_session(hSession)) | 266 | if(check_online_session(hSession)) |
src/core/properties/string.c
@@ -33,6 +33,7 @@ | @@ -33,6 +33,7 @@ | ||
33 | #include <lib3270.h> | 33 | #include <lib3270.h> |
34 | #include <lib3270/properties.h> | 34 | #include <lib3270/properties.h> |
35 | #include <lib3270/keyboard.h> | 35 | #include <lib3270/keyboard.h> |
36 | + #include <lib3270/log.h> | ||
36 | 37 | ||
37 | static const char * get_version(const H3270 GNUC_UNUSED(*hSession)) | 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,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,6 +99,14 @@ void lib3270_session_free(H3270 *h) | ||
99 | for(f=0;f<LIB3270_ACTION_GROUP_CUSTOM;f++) | 99 | for(f=0;f<LIB3270_ACTION_GROUP_CUSTOM;f++) |
100 | lib3270_linked_list_free(&h->listeners.actions[f]); | 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 | // Release memory | 110 | // Release memory |
103 | #define release_pointer(x) lib3270_free(x); x = NULL; | 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,13 +369,26 @@ void popup_a_sockerr(H3270 *hSession, char *fmt, ...) | ||
369 | // Set up the LU list. | 369 | // Set up the LU list. |
370 | static void setup_lus(H3270 *hSession) | 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 | char *lu; | 387 | char *lu; |
373 | char *comma; | 388 | char *comma; |
374 | int n_lus = 1; | 389 | int n_lus = 1; |
375 | int i; | 390 | int i; |
376 | 391 | ||
377 | - hSession->lu.associated = CN; | ||
378 | - hSession->connected_type = CN; | ||
379 | 392 | ||
380 | if (!hSession->lu.names[0]) | 393 | if (!hSession->lu.names[0]) |
381 | { | 394 | { |
@@ -419,8 +432,8 @@ static void setup_lus(H3270 *hSession) | @@ -419,8 +432,8 @@ static void setup_lus(H3270 *hSession) | ||
419 | } while (comma != CN); | 432 | } while (comma != CN); |
420 | 433 | ||
421 | hSession->lus[i] = CN; | 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 | static int net_connected(H3270 *hSession) | 439 | static int net_connected(H3270 *hSession) |
@@ -775,11 +788,13 @@ static void send_naws(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 | static void next_lu(H3270 *hSession) | 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,7 +1102,7 @@ static int telnet_fsm(H3270 *hSession, unsigned char c) | ||
1087 | 1102 | ||
1088 | trace_dsn(hSession,"%s %s\n", opt(hSession->sbbuf[0]),telquals[hSession->sbbuf[1]]); | 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 | // None of the LUs worked. | 1107 | // None of the LUs worked. |
1093 | popup_an_error(hSession, _( "Cannot connect to specified LU" ) ); | 1108 | popup_an_error(hSession, _( "Cannot connect to specified LU" ) ); |
@@ -1095,10 +1110,10 @@ static int telnet_fsm(H3270 *hSession, unsigned char c) | @@ -1095,10 +1110,10 @@ static int telnet_fsm(H3270 *hSession, unsigned char c) | ||
1095 | } | 1110 | } |
1096 | 1111 | ||
1097 | tt_len = strlen(hSession->termtype); | 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 | else | 1118 | else |
1104 | { | 1119 | { |
@@ -1112,8 +1127,8 @@ static int telnet_fsm(H3270 *hSession, unsigned char c) | @@ -1112,8 +1127,8 @@ static int telnet_fsm(H3270 *hSession, unsigned char c) | ||
1112 | (void) sprintf(tt_out, "%c%c%c%c%s%s%s%c%c", | 1127 | (void) sprintf(tt_out, "%c%c%c%c%s%s%s%c%c", |
1113 | IAC, SB, TELOPT_TTYPE, TELQUAL_IS, | 1128 | IAC, SB, TELOPT_TTYPE, TELQUAL_IS, |
1114 | hSession->termtype, | 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 | IAC, SE); | 1132 | IAC, SE); |
1118 | net_rawout(hSession, (unsigned char *)tt_out, tb_len); | 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,7 +1190,7 @@ static void continue_tls(H3270 *hSession, unsigned char *sbbuf, int len) | ||
1175 | #endif // HAVE_LIBSSL | 1190 | #endif // HAVE_LIBSSL |
1176 | 1191 | ||
1177 | #if defined(X3270_TN3270E) /*[*/ | 1192 | #if defined(X3270_TN3270E) /*[*/ |
1178 | -/* Send a TN3270E terminal type request. */ | 1193 | +/// @brief Send a TN3270E terminal type request. |
1179 | static void tn3270e_request(H3270 *hSession) | 1194 | static void tn3270e_request(H3270 *hSession) |
1180 | { | 1195 | { |
1181 | int tt_len, tb_len; | 1196 | int tt_len, tb_len; |
@@ -1183,8 +1198,8 @@ static void tn3270e_request(H3270 *hSession) | @@ -1183,8 +1198,8 @@ static void tn3270e_request(H3270 *hSession) | ||
1183 | char *t; | 1198 | char *t; |
1184 | 1199 | ||
1185 | tt_len = strlen(hSession->termtype); | 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 | tb_len = 5 + tt_len + 2; | 1204 | tb_len = 5 + tt_len + 2; |
1190 | tt_out = lib3270_malloc(tb_len + 1); | 1205 | tt_out = lib3270_malloc(tb_len + 1); |
@@ -1197,8 +1212,8 @@ static void tn3270e_request(H3270 *hSession) | @@ -1197,8 +1212,8 @@ static void tn3270e_request(H3270 *hSession) | ||
1197 | if (tt_out[12] == '9') | 1212 | if (tt_out[12] == '9') |
1198 | tt_out[12] = '8'; | 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 | (void) sprintf(t, "%c%c", IAC, SE); | 1218 | (void) sprintf(t, "%c%c", IAC, SE); |
1204 | 1219 | ||
@@ -1210,8 +1225,8 @@ static void tn3270e_request(H3270 *hSession) | @@ -1210,8 +1225,8 @@ static void tn3270e_request(H3270 *hSession) | ||
1210 | opt(TELOPT_TN3270E), | 1225 | opt(TELOPT_TN3270E), |
1211 | (int) strlen(hSession->termtype), | 1226 | (int) strlen(hSession->termtype), |
1212 | tt_out + 5, | 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 | cmd(SE) | 1230 | cmd(SE) |
1216 | ); | 1231 | ); |
1217 | 1232 | ||
@@ -1332,14 +1347,14 @@ static int tn3270e_negotiate(H3270 *hSession) | @@ -1332,14 +1347,14 @@ static int tn3270e_negotiate(H3270 *hSession) | ||
1332 | } | 1347 | } |
1333 | 1348 | ||
1334 | next_lu(hSession); | 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 | tn3270e_request(hSession); | 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 | backoff_tn3270e(hSession,_("Host rejected resource(s)")); | 1358 | backoff_tn3270e(hSession,_("Host rejected resource(s)")); |
1344 | } | 1359 | } |
1345 | else | 1360 | else |
@@ -2096,9 +2111,9 @@ static void check_in3270(H3270 *hSession) | @@ -2096,9 +2111,9 @@ static void check_in3270(H3270 *hSession) | ||
2096 | // TN3270E mode, reset the LU list so we can try again | 2111 | // TN3270E mode, reset the LU list so we can try again |
2097 | // in the new mode. | 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 | #endif | 2118 | #endif |
2104 | 2119 |
src/core/toggles/table.c
@@ -239,8 +239,8 @@ const LIB3270_TOGGLE toggle_descriptor[LIB3270_TOGGLE_COUNT+1] = | @@ -239,8 +239,8 @@ const LIB3270_TOGGLE toggle_descriptor[LIB3270_TOGGLE_COUNT+1] = | ||
239 | .def = False, | 239 | .def = False, |
240 | .key = NULL, // Default keycode | 240 | .key = NULL, // Default keycode |
241 | .icon = NULL, // Icon name | 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 | .description = "" | 244 | .description = "" |
245 | }, | 245 | }, |
246 | { | 246 | { |
src/include/internals.h
@@ -508,14 +508,13 @@ struct _h3270 | @@ -508,14 +508,13 @@ struct _h3270 | ||
508 | */ | 508 | */ |
509 | 509 | ||
510 | /// @brief LU | 510 | /// @brief LU |
511 | - char **curr_lu; | ||
512 | - char * try_lu; | ||
513 | - char **lus; ///< @brief Array with the LU names to try. | ||
514 | struct | 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 | } lu; | 519 | } lu; |
521 | 520 |
src/include/lib3270.h
@@ -964,7 +964,7 @@ | @@ -964,7 +964,7 @@ | ||
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)); | 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 | * @see LIB3270_MESSAGE | 969 | * @see LIB3270_MESSAGE |
970 | * | 970 | * |
@@ -976,7 +976,7 @@ | @@ -976,7 +976,7 @@ | ||
976 | LIB3270_EXPORT LIB3270_MESSAGE lib3270_get_program_message(const H3270 *h); | 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 | * Get the name LU associated with the session; the value is | 981 | * Get the name LU associated with the session; the value is |
982 | * internal to lib3270 and should not be changed ou freed. | 982 | * internal to lib3270 and should not be changed ou freed. |
@@ -988,7 +988,21 @@ | @@ -988,7 +988,21 @@ | ||
988 | */ | 988 | */ |
989 | LIB3270_EXPORT const char * lib3270_get_associated_luname(const H3270 *hSession); | 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 | LIB3270_EXPORT int lib3270_is_connected(const H3270 *h); | 1007 | LIB3270_EXPORT int lib3270_is_connected(const H3270 *h); |
994 | LIB3270_EXPORT int lib3270_is_disconnected(const H3270 *h); | 1008 | LIB3270_EXPORT int lib3270_is_disconnected(const H3270 *h); |
src/testprogram/testprogram.c
@@ -9,6 +9,7 @@ | @@ -9,6 +9,7 @@ | ||
9 | #include <lib3270/actions.h> | 9 | #include <lib3270/actions.h> |
10 | #include <lib3270/trace.h> | 10 | #include <lib3270/trace.h> |
11 | #include <lib3270/toggle.h> | 11 | #include <lib3270/toggle.h> |
12 | +#include <lib3270/log.h> | ||
12 | 13 | ||
13 | #define MAX_ARGS 10 | 14 | #define MAX_ARGS 10 |
14 | 15 | ||
@@ -19,7 +20,7 @@ static void write_trace(H3270 GNUC_UNUSED(*session), void GNUC_UNUSED(*userdata) | @@ -19,7 +20,7 @@ static void write_trace(H3270 GNUC_UNUSED(*session), void GNUC_UNUSED(*userdata) | ||
19 | FILE *out = fopen(trace_file,"a"); | 20 | FILE *out = fopen(trace_file,"a"); |
20 | if(out) | 21 | if(out) |
21 | { | 22 | { |
22 | - | 23 | + |
23 | vfprintf(out,fmt,args); | 24 | vfprintf(out,fmt,args); |
24 | fclose(out); | 25 | fclose(out); |
25 | } | 26 | } |
@@ -149,6 +150,21 @@ int main(int argc, char *argv[]) | @@ -149,6 +150,21 @@ int main(int argc, char *argv[]) | ||
149 | 150 | ||
150 | lib3270_unregister_action_group_listener(h,LIB3270_ACTION_GROUP_ONLINE,online_listener); | 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 | lib3270_session_free(h); | 168 | lib3270_session_free(h); |
153 | 169 | ||
154 | return 0; | 170 | return 0; |