1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 09:58:01 +00:00
putty-source/utils/sessprep.c
Simon Tatham 3396c97da9 New library-style 'utils' subdirectories.
Now that the new CMake build system is encouraging us to lay out the
code like a set of libraries, it seems like a good idea to make them
look more _like_ libraries, by putting things into separate modules as
far as possible.

This fixes several previous annoyances in which you had to link
against some object in order to get a function you needed, but that
object also contained other functions you didn't need which included
link-time symbol references you didn't want to have to deal with. The
usual offender was subsidiary supporting programs including misc.c for
some innocuous function and then finding they had to deal with the
requirements of buildinfo().

This big reorganisation introduces three new subdirectories called
'utils', one at the top level and one in each platform subdir. In each
case, the directory contains basically the same files that were
previously placed in the 'utils' build-time library, except that the
ones that were extremely miscellaneous (misc.c, utils.c, uxmisc.c,
winmisc.c, winmiscs.c, winutils.c) have been split up into much
smaller pieces.
2021-04-18 08:18:27 +01:00

85 lines
2.6 KiB
C

/*
* sessprep.c: centralise some preprocessing done on Conf objects
* before launching them.
*/
#include "putty.h"
void prepare_session(Conf *conf)
{
char *hostbuf = dupstr(conf_get_str(conf, CONF_host));
char *host = hostbuf;
char *p, *q;
/*
* Trim leading whitespace from the hostname.
*/
host += strspn(host, " \t");
/*
* See if host is of the form user@host, and separate out the
* username if so.
*/
if (host[0] != '\0') {
/*
* Use strrchr, in case the _username_ in turn is of the form
* user@host, which has been known.
*/
char *atsign = strrchr(host, '@');
if (atsign) {
*atsign = '\0';
conf_set_str(conf, CONF_username, host);
host = atsign + 1;
}
}
/*
* Trim a colon suffix off the hostname if it's there, and discard
* the text after it.
*
* The exact reason why we _ignore_ this text, rather than
* treating it as a port number, is unfortunately lost in the
* mists of history: the commit which originally introduced this
* change on 2001-05-06 was clear on _what_ it was doing but
* didn't bother to explain _why_. But I [SGT, 2017-12-03] suspect
* it has to do with priority order: what should a saved session
* do if its CONF_host contains 'server.example.com:123' and its
* CONF_port contains 456? If CONF_port contained the _default_
* port number then it might be a good guess that the colon suffix
* on the host name was intended to override that, but you don't
* really want to get into making heuristic judgments on that
* basis.
*
* (Then again, you could just as easily make the same argument
* about whether a 'user@' prefix on the host name should override
* CONF_username, which this code _does_ do. I don't have a good
* answer, sadly. Both these pieces of behaviour have been around
* for years and it would probably cause subtle breakage in all
* sorts of long-forgotten scripting to go changing things around
* now.)
*
* In order to protect unbracketed IPv6 address literals against
* this treatment, we do not make this change at all if there's
* _more_ than one (un-IPv6-bracketed) colon.
*/
p = host_strchr(host, ':');
if (p && p == host_strrchr(host, ':')) {
*p = '\0';
}
/*
* Remove any remaining whitespace.
*/
p = hostbuf;
q = host;
while (*q) {
if (*q != ' ' && *q != '\t')
*p++ = *q;
q++;
}
*p = '\0';
conf_set_str(conf, CONF_host, hostbuf);
sfree(hostbuf);
}