2003-03-29 22:52:50 +03:00
|
|
|
/*
|
|
|
|
* Unix PuTTY main program.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2003-03-31 16:10:53 +04:00
|
|
|
#include <ctype.h>
|
2003-03-31 15:21:07 +04:00
|
|
|
#include <stdlib.h>
|
2003-03-29 22:52:50 +03:00
|
|
|
#include <assert.h>
|
|
|
|
#include <unistd.h>
|
2004-10-07 02:31:07 +04:00
|
|
|
#include <gdk/gdk.h>
|
2003-03-29 22:52:50 +03:00
|
|
|
|
|
|
|
#include "putty.h"
|
|
|
|
#include "storage.h"
|
|
|
|
|
2005-02-06 18:52:00 +03:00
|
|
|
/*
|
|
|
|
* Stubs to avoid uxpty.c needing to be linked in.
|
|
|
|
*/
|
|
|
|
const int use_pty_argv = FALSE;
|
|
|
|
char **pty_argv; /* never used */
|
|
|
|
|
2003-03-29 22:52:50 +03:00
|
|
|
/*
|
|
|
|
* Clean up and exit.
|
|
|
|
*/
|
|
|
|
void cleanup_exit(int code)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* Clean up.
|
|
|
|
*/
|
|
|
|
sk_cleanup();
|
|
|
|
random_save_seed();
|
|
|
|
exit(code);
|
|
|
|
}
|
|
|
|
|
|
|
|
Backend *select_backend(Config *cfg)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
Backend *back = NULL;
|
|
|
|
for (i = 0; backends[i].backend != NULL; i++)
|
|
|
|
if (backends[i].protocol == cfg->protocol) {
|
|
|
|
back = backends[i].backend;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
assert(back != NULL);
|
|
|
|
return back;
|
|
|
|
}
|
|
|
|
|
|
|
|
int cfgbox(Config *cfg)
|
|
|
|
{
|
2004-12-29 15:32:25 +03:00
|
|
|
return do_config_box("PuTTY Configuration", cfg, 0, 0);
|
2003-03-29 22:52:50 +03:00
|
|
|
}
|
|
|
|
|
2003-03-31 16:10:53 +04:00
|
|
|
static int got_host = 0;
|
|
|
|
|
2003-04-12 21:37:15 +04:00
|
|
|
const int use_event_log = 1, new_session = 1, saved_sessions = 1;
|
2003-04-09 22:46:45 +04:00
|
|
|
|
2003-03-31 16:10:53 +04:00
|
|
|
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.
|
|
|
|
*/
|
2003-03-31 16:57:36 +04:00
|
|
|
p = arg;
|
2003-03-31 16:10:53 +04:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2003-03-31 15:42:45 +04:00
|
|
|
char *make_default_wintitle(char *hostname)
|
|
|
|
{
|
|
|
|
return dupcat(hostname, " - PuTTY", NULL);
|
|
|
|
}
|
|
|
|
|
2004-10-07 02:31:07 +04:00
|
|
|
/*
|
|
|
|
* X11-forwarding-related things suitable for Gtk app.
|
|
|
|
*/
|
|
|
|
|
|
|
|
const char platform_x11_best_transport[] = "unix";
|
|
|
|
|
|
|
|
char *platform_get_x_display(void) {
|
|
|
|
const char *display;
|
|
|
|
/* Try to take account of --display and what have you. */
|
|
|
|
if (!(display = gdk_get_display()))
|
|
|
|
/* fall back to traditional method */
|
|
|
|
display = getenv("DISPLAY");
|
|
|
|
return dupstr(display);
|
|
|
|
}
|
|
|
|
|
2003-03-29 22:52:50 +03:00
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
extern int pt_main(int argc, char **argv);
|
|
|
|
sk_init();
|
|
|
|
flags = FLAG_VERBOSE | FLAG_INTERACTIVE;
|
|
|
|
default_protocol = be_default_protocol;
|
|
|
|
/* Find the appropriate default port. */
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
default_port = 0; /* illegal */
|
|
|
|
for (i = 0; backends[i].backend != NULL; i++)
|
|
|
|
if (backends[i].protocol == default_protocol) {
|
|
|
|
default_port = backends[i].backend->default_port;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return pt_main(argc, argv);
|
|
|
|
}
|