Commit a5a9276f64b9faf3a8944b840a5146084b9ab73c
1 parent
3cf573e7
Exists in
master
and in
5 other branches
Allowing customization of the session name from ./configure.
Showing
3 changed files
with
31 additions
and
16 deletions
Show diff stats
configure.ac
... | ... | @@ -190,6 +190,7 @@ AC_SUBST(PACKAGE_MAJOR_VERSION,$app_vrs_major) |
190 | 190 | AC_SUBST(PACKAGE_MINOR_VERSION,$app_vrs_minor) |
191 | 191 | |
192 | 192 | AC_ARG_WITH([release], [AS_HELP_STRING([--with-release], [Set release])], [ app_cv_release="$withval" ],[ app_cv_release="`date +%y`.`date +%m`.`date +%d`" ]) |
193 | +AC_ARG_WITH([session-name], [AS_HELP_STRING([--with-session-name], [Set default session name])], [ AC_DEFINE_UNQUOTED(DEFAULT_SESSION_NAME, $withval) ],[ AC_MSG_NOTICE([No default session name.]) ]) | |
193 | 194 | |
194 | 195 | app_rls_major=$(echo $app_cv_release.0.0 | cut -d. -f1) |
195 | 196 | app_rls_minor=$(echo $app_cv_release.0.0 | cut -d. -f2) | ... | ... |
src/include/config.h.in
src/pw3270/main.c
... | ... | @@ -232,7 +232,12 @@ static gboolean startup(GtkWidget *toplevel) |
232 | 232 | int main(int argc, char *argv[]) |
233 | 233 | { |
234 | 234 | const gchar * pluginpath = NULL; |
235 | +#ifdef DEFAULT_SESSION_NAME | |
236 | + const gchar * session_name = G_STRINGIFY(DEFAULT_SESSION_NAME); | |
237 | +#else | |
235 | 238 | const gchar * session_name = NULL; |
239 | +#endif // DEFAULT_SESSION_NAME | |
240 | + | |
236 | 241 | const gchar * host = lib3270_get_default_host(NULL); |
237 | 242 | int rc = 0; |
238 | 243 | |
... | ... | @@ -254,17 +259,22 @@ int main(int argc, char *argv[]) |
254 | 259 | { |
255 | 260 | const GOptionEntry app_options[] = |
256 | 261 | { |
257 | - { "session", 's', 0, G_OPTION_ARG_STRING, &session_name, N_( "Session name" ), PACKAGE_NAME }, | |
258 | - { "host", 'h', 0, G_OPTION_ARG_STRING, &host, N_( "Host to connect"), host }, | |
259 | - { "colors", 'c', 0, G_OPTION_ARG_CALLBACK, optcolors, N_( "Set reported colors (8/16)" ), "16" }, | |
260 | - { "systype", 't', 0, G_OPTION_ARG_STRING, &systype, N_( "Host system type" ), "S390" }, | |
261 | - { "toggleset", 'S', 0, G_OPTION_ARG_STRING, &toggleset, N_( "Set toggles ON" ), NULL }, | |
262 | - { "togglereset", 'R', 0, G_OPTION_ARG_STRING, &togglereset, N_( "Set toggles OFF" ), NULL }, | |
263 | - { "charset", 'C', 0, G_OPTION_ARG_STRING, &charset, N_( "Set host charset" ), NULL }, | |
264 | - { "remap", 'm', 0, G_OPTION_ARG_FILENAME, &remap, N_( "Remap charset from xml file" ), NULL }, | |
265 | - { "model", 'M', 0, G_OPTION_ARG_STRING, &model, N_( "The model of 3270 display to be emulated" ), NULL }, | |
266 | - { "autodisconnect", 'D', 0, G_OPTION_ARG_INT, &timer, N_( "Minutes for auto-disconnect" ), 0 }, | |
267 | - { "pluginpath", 'P', 0, G_OPTION_ARG_STRING, &pluginpath, N_( "Path for plugin files" ), NULL }, | |
262 | +#ifdef DEFAULT_SESSION_NAME | |
263 | + { "session", 's', 0, G_OPTION_ARG_STRING, &session_name, N_( "Session name" ), G_STRINGIFY(DEFAULT_SESSION_NAME) }, | |
264 | +#else | |
265 | + { "session", 's', 0, G_OPTION_ARG_STRING, &session_name, N_( "Session name" ), PACKAGE_NAME }, | |
266 | +#endif // DEFAULT_SESSION_NAME | |
267 | + | |
268 | + { "host", 'h', 0, G_OPTION_ARG_STRING, &host, N_( "Host to connect"), host }, | |
269 | + { "colors", 'c', 0, G_OPTION_ARG_CALLBACK, optcolors, N_( "Set reported colors (8/16)" ), "16" }, | |
270 | + { "systype", 't', 0, G_OPTION_ARG_STRING, &systype, N_( "Host system type" ), "S390" }, | |
271 | + { "toggleset", 'S', 0, G_OPTION_ARG_STRING, &toggleset, N_( "Set toggles ON" ), NULL }, | |
272 | + { "togglereset", 'R', 0, G_OPTION_ARG_STRING, &togglereset, N_( "Set toggles OFF" ), NULL }, | |
273 | + { "charset", 'C', 0, G_OPTION_ARG_STRING, &charset, N_( "Set host charset" ), NULL }, | |
274 | + { "remap", 'm', 0, G_OPTION_ARG_FILENAME, &remap, N_( "Remap charset from xml file" ), NULL }, | |
275 | + { "model", 'M', 0, G_OPTION_ARG_STRING, &model, N_( "The model of 3270 display to be emulated" ), NULL }, | |
276 | + { "autodisconnect", 'D', 0, G_OPTION_ARG_INT, &timer, N_( "Minutes for auto-disconnect" ), 0 }, | |
277 | + { "pluginpath", 'P', 0, G_OPTION_ARG_STRING, &pluginpath, N_( "Path for plugin files" ), NULL }, | |
268 | 278 | |
269 | 279 | #if defined( HAVE_SYSLOG ) |
270 | 280 | { "syslog", 'l', 0, G_OPTION_ARG_NONE, &log_to_syslog, N_( "Send messages to syslog" ), NULL }, |
... | ... | @@ -401,6 +411,14 @@ int main(int argc, char *argv[]) |
401 | 411 | // Just in case! |
402 | 412 | g_mkdir_with_parents(g_get_tmp_dir(),0777); |
403 | 413 | |
414 | + | |
415 | + if(!session_name) | |
416 | + session_name = PACKAGE_NAME; | |
417 | + | |
418 | +#ifdef _WIN32 | |
419 | + g_set_application_name(session_name); | |
420 | +#endif // _WIN32 | |
421 | + | |
404 | 422 | rc = initialize(); |
405 | 423 | if(!rc) |
406 | 424 | { |
... | ... | @@ -414,11 +432,6 @@ int main(int argc, char *argv[]) |
414 | 432 | |
415 | 433 | pw3270_load_plugins(pluginpath); |
416 | 434 | toplevel = pw3270_new(host,systype,syscolors); |
417 | - | |
418 | - | |
419 | - if(!session_name) | |
420 | - session_name = g_get_application_name(); | |
421 | - | |
422 | 435 | pw3270_set_session_name(toplevel,session_name); |
423 | 436 | |
424 | 437 | #if defined(_WIN32) && defined(ENABLE_WINDOWS_REGISTRY) | ... | ... |