X-Git-Url: https://git.distorted.org.uk/~mdw/sgt/putty/blobdiff_plain/10705014ce38c846c2314823550beb0371c5fc6c..125105d16c788398562ac03e91ce7a0dc0292492:/unix/uxputty.c diff --git a/unix/uxputty.c b/unix/uxputty.c index c2047879..dcfbd200 100644 --- a/unix/uxputty.c +++ b/unix/uxputty.c @@ -3,6 +3,7 @@ */ #include +#include #include #include #include @@ -13,10 +14,6 @@ /* * TODO: * - * - Fix command-line parsing to be more PuTTYlike and not so - * ptermy - in particular non-option arguments should be - * hostname and port in the obvious way. - * * - libcharset enumeration. * * - fix the printer enum (I think the sensible thing is simply to @@ -72,17 +69,6 @@ * - About (and uxcfg.c must also supply the about box) */ -void cmdline_error(char *p, ...) -{ - va_list ap; - fprintf(stderr, "plink: "); - va_start(ap, p); - vfprintf(stderr, p, ap); - va_end(ap); - fputc('\n', stderr); - exit(1); -} - /* * Clean up and exit. */ @@ -144,6 +130,62 @@ int cfgbox(Config *cfg) return do_config_box("PuTTY Configuration", cfg); } +static int got_host = 0; + +int process_nonoption_arg(char *arg, Config *cfg) +{ + char *p, *q = arg; + + if (got_host) { + /* + * If we already have a host name, treat this argument as a + * port number. NB we have to treat this as a saved -P + * argument, so that it will be deferred until it's a good + * moment to run it. + */ + int ret = cmdline_process_param("-P", arg, 1, cfg); + assert(ret == 2); + } else if (!strncmp(q, "telnet:", 7)) { + /* + * If the hostname starts with "telnet:", + * set the protocol to Telnet and process + * the string as a Telnet URL. + */ + char c; + + q += 7; + if (q[0] == '/' && q[1] == '/') + q += 2; + cfg->protocol = PROT_TELNET; + p = q; + while (*p && *p != ':' && *p != '/') + p++; + c = *p; + if (*p) + *p++ = '\0'; + if (c == ':') + cfg->port = atoi(p); + else + cfg->port = -1; + strncpy(cfg->host, q, sizeof(cfg->host) - 1); + cfg->host[sizeof(cfg->host) - 1] = '\0'; + got_host = 1; + } else { + /* + * Otherwise, treat this argument as a host name. + */ + p = arg; + while (*p && !isspace((unsigned char)*p)) + p++; + if (*p) + *p++ = '\0'; + strncpy(cfg->host, q, sizeof(cfg->host) - 1); + cfg->host[sizeof(cfg->host) - 1] = '\0'; + got_host = 1; + } + return 1; +} + char *make_default_wintitle(char *hostname) { return dupcat(hostname, " - PuTTY", NULL);