1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-07-03 04:22:47 -05:00

Change the semantics of 'FontSpec' so that it's a dynamically

allocated type.

The main reason for this is to stop it from taking up a fixed large
amount of space in every 'struct value' subunion in conf.c, although
that makes little difference so far because Filename is still doing
the same thing (and is therefore next on my list). However, the
removal of its arbitrary length limit is not to be sneezed at.

[originally from svn r9314]
This commit is contained in:
Simon Tatham
2011-10-01 17:38:59 +00:00
parent f69591412c
commit 9c75fe9a3f
19 changed files with 220 additions and 139 deletions

View File

@ -151,14 +151,12 @@ void connection_fatal(void *frontend, char *p, ...)
/*
* Default settings that are specific to pterm.
*/
FontSpec platform_default_fontspec(const char *name)
FontSpec *platform_default_fontspec(const char *name)
{
FontSpec ret;
if (!strcmp(name, "Font"))
strcpy(ret.name, "server:fixed");
return fontspec_new("server:fixed");
else
*ret.name = '\0';
return ret;
return fontspec_new("");
}
Filename platform_default_filename(const char *name)
@ -2541,36 +2539,36 @@ int do_cmdline(int argc, char **argv, int do_everything, int *allow_launch,
}
if (!strcmp(p, "-fn") || !strcmp(p, "-font")) {
FontSpec fs;
FontSpec *fs;
EXPECTS_ARG;
SECOND_PASS_ONLY;
strncpy(fs.name, val, sizeof(fs.name));
fs.name[sizeof(fs.name)-1] = '\0';
conf_set_fontspec(conf, CONF_font, &fs);
fs = fontspec_new(val);
conf_set_fontspec(conf, CONF_font, fs);
fontspec_free(fs);
} else if (!strcmp(p, "-fb")) {
FontSpec fs;
FontSpec *fs;
EXPECTS_ARG;
SECOND_PASS_ONLY;
strncpy(fs.name, val, sizeof(fs.name));
fs.name[sizeof(fs.name)-1] = '\0';
conf_set_fontspec(conf, CONF_boldfont, &fs);
fs = fontspec_new(val);
conf_set_fontspec(conf, CONF_font, fs);
fontspec_free(fs);
} else if (!strcmp(p, "-fw")) {
FontSpec fs;
FontSpec *fs;
EXPECTS_ARG;
SECOND_PASS_ONLY;
strncpy(fs.name, val, sizeof(fs.name));
fs.name[sizeof(fs.name)-1] = '\0';
conf_set_fontspec(conf, CONF_widefont, &fs);
fs = fontspec_new(val);
conf_set_fontspec(conf, CONF_font, fs);
fontspec_free(fs);
} else if (!strcmp(p, "-fwb")) {
FontSpec fs;
FontSpec *fs;
EXPECTS_ARG;
SECOND_PASS_ONLY;
strncpy(fs.name, val, sizeof(fs.name));
fs.name[sizeof(fs.name)-1] = '\0';
conf_set_fontspec(conf, CONF_wideboldfont, &fs);
fs = fontspec_new(val);
conf_set_fontspec(conf, CONF_font, fs);
fontspec_free(fs);
} else if (!strcmp(p, "-cs")) {
EXPECTS_ARG;