2007-01-06 18:15:35 +00:00
|
|
|
# Makefile for the PuTTY icon suite.
|
|
|
|
|
2007-02-06 22:39:15 +00:00
|
|
|
ICONS = putty puttycfg puttygen pscp pageant pterm ptermcfg puttyins
|
2015-09-06 08:50:09 +00:00
|
|
|
SIZES = 16 32 48 128
|
2007-01-06 18:15:35 +00:00
|
|
|
|
|
|
|
MODE = # override to -it on command line for opaque testing
|
|
|
|
|
2016-03-23 06:41:27 +00:00
|
|
|
PAMS = $(foreach I,$(ICONS),$(foreach S,$(SIZES),$(I)-$(S).pam))
|
|
|
|
MONOPAMS = $(foreach I,$(ICONS),$(foreach S,$(SIZES),$(I)-$(S)-mono.pam))
|
|
|
|
TRUEPAMS = $(foreach I,$(ICONS),$(foreach S,$(SIZES),$(I)-$(S)-true.pam))
|
|
|
|
|
|
|
|
PNGS = $(patsubst %.pam,%.png,$(PAMS))
|
|
|
|
MONOPNGS = $(patsubst %.pam,%.png,$(MONOPAMS))
|
|
|
|
TRUEPNGS = $(patsubst %.pam,%.png,$(TRUEPAMS))
|
2007-01-06 18:15:35 +00:00
|
|
|
|
New script to draw the icons as SVG.
This gets us scalable icons that will go to extremely large sizes
without the problems that arise from scaling up the output of
mkicon.py, in which outlines become too thin because the script was
mostly concerned with trying to squeeze all the desired detail into
_tiny_ sizes.
The SVG icons are generated by mksvg.py, which is a conversion of the
existing mkicon.py. So the SVG files themselves are not committed in
this repo; 'make svg' in the icons subdir will generate them.
(I haven't decided yet whether this state of affairs should be
permanent. Perhaps _having_ generated the SVGs via a similar program
to the bitmap icons, we should regard the script as a discardable
booster stage and redesignate the SVGs themselves as the source format
for future modifications, so that they can be edited in Inkscape or
similar rather than by tinkering with Python. On the other hand,
perhaps keeping the script will make it easier to keep the icon family
consistent, e.g. if changing the style of one of the shared visual
components.)
My plan is that we should stick with the output of the previous
bitmap-generating script for all the _small_ icons, up to and
including 48 pixels, because it does a better job at low resolution.
(That was really what it was for in the first place: you can think of
it as an analogue of a scalable-font hinting system, to tune the
scaling for very low res so that all the important features are still
visible.)
I think probably I want to switch the 128-pixel icons used in the Mac
icon file over to being rendered from the SVG (though in this commit I
haven't gone that far, not least because I'll also need to prepare a
corresponding black and white version). I haven't done extensive
research yet to decide where I think the crossover point in between
is.
2022-03-18 07:11:11 +00:00
|
|
|
SVGS = $(patsubst %,%.svg,$(ICONS))
|
|
|
|
|
2007-01-22 18:02:06 +00:00
|
|
|
ICOS = putty.ico puttygen.ico pscp.ico pageant.ico pageants.ico puttycfg.ico \
|
2021-05-08 16:22:19 +00:00
|
|
|
puttyins.ico pterm.ico ptermcfg.ico
|
2016-03-23 22:02:46 +00:00
|
|
|
ICNS = PuTTY.icns Pterm.icns
|
2007-01-06 18:15:35 +00:00
|
|
|
CICONS = xpmputty.c xpmpucfg.c xpmpterm.c xpmptcfg.c
|
|
|
|
|
|
|
|
base: icos cicons
|
|
|
|
|
New script to draw the icons as SVG.
This gets us scalable icons that will go to extremely large sizes
without the problems that arise from scaling up the output of
mkicon.py, in which outlines become too thin because the script was
mostly concerned with trying to squeeze all the desired detail into
_tiny_ sizes.
The SVG icons are generated by mksvg.py, which is a conversion of the
existing mkicon.py. So the SVG files themselves are not committed in
this repo; 'make svg' in the icons subdir will generate them.
(I haven't decided yet whether this state of affairs should be
permanent. Perhaps _having_ generated the SVGs via a similar program
to the bitmap icons, we should regard the script as a discardable
booster stage and redesignate the SVGs themselves as the source format
for future modifications, so that they can be edited in Inkscape or
similar rather than by tinkering with Python. On the other hand,
perhaps keeping the script will make it easier to keep the icon family
consistent, e.g. if changing the style of one of the shared visual
components.)
My plan is that we should stick with the output of the previous
bitmap-generating script for all the _small_ icons, up to and
including 48 pixels, because it does a better job at low resolution.
(That was really what it was for in the first place: you can think of
it as an analogue of a scalable-font hinting system, to tune the
scaling for very low res so that all the important features are still
visible.)
I think probably I want to switch the 128-pixel icons used in the Mac
icon file over to being rendered from the SVG (though in this commit I
haven't gone that far, not least because I'll also need to prepare a
corresponding black and white version). I haven't done extensive
research yet to decide where I think the crossover point in between
is.
2022-03-18 07:11:11 +00:00
|
|
|
all: pngs monopngs base icns svgs # truepngs currently disabled by default
|
2007-01-06 18:15:35 +00:00
|
|
|
|
|
|
|
pngs: $(PNGS)
|
|
|
|
monopngs: $(MONOPNGS)
|
|
|
|
truepngs: $(TRUEPNGS)
|
New script to draw the icons as SVG.
This gets us scalable icons that will go to extremely large sizes
without the problems that arise from scaling up the output of
mkicon.py, in which outlines become too thin because the script was
mostly concerned with trying to squeeze all the desired detail into
_tiny_ sizes.
The SVG icons are generated by mksvg.py, which is a conversion of the
existing mkicon.py. So the SVG files themselves are not committed in
this repo; 'make svg' in the icons subdir will generate them.
(I haven't decided yet whether this state of affairs should be
permanent. Perhaps _having_ generated the SVGs via a similar program
to the bitmap icons, we should regard the script as a discardable
booster stage and redesignate the SVGs themselves as the source format
for future modifications, so that they can be edited in Inkscape or
similar rather than by tinkering with Python. On the other hand,
perhaps keeping the script will make it easier to keep the icon family
consistent, e.g. if changing the style of one of the shared visual
components.)
My plan is that we should stick with the output of the previous
bitmap-generating script for all the _small_ icons, up to and
including 48 pixels, because it does a better job at low resolution.
(That was really what it was for in the first place: you can think of
it as an analogue of a scalable-font hinting system, to tune the
scaling for very low res so that all the important features are still
visible.)
I think probably I want to switch the 128-pixel icons used in the Mac
icon file over to being rendered from the SVG (though in this commit I
haven't gone that far, not least because I'll also need to prepare a
corresponding black and white version). I haven't done extensive
research yet to decide where I think the crossover point in between
is.
2022-03-18 07:11:11 +00:00
|
|
|
svgs: $(SVGS)
|
2007-01-06 18:15:35 +00:00
|
|
|
|
|
|
|
icos: $(ICOS)
|
2015-09-06 08:50:09 +00:00
|
|
|
icns: $(ICNS)
|
2007-01-06 18:15:35 +00:00
|
|
|
cicons: $(CICONS)
|
|
|
|
|
2007-01-07 10:17:12 +00:00
|
|
|
install: icos cicons
|
|
|
|
cp $(ICOS) ../windows
|
|
|
|
cp $(CICONS) ../unix
|
|
|
|
|
2016-03-23 06:41:27 +00:00
|
|
|
$(PAMS): %.pam: mkicon.py
|
2007-01-06 18:15:35 +00:00
|
|
|
./mkicon.py $(MODE) $(join $(subst -, ,$(basename $@)),_icon) $@
|
|
|
|
|
2016-03-23 06:41:27 +00:00
|
|
|
$(PNGS) $(MONOPNGS) $(TRUEPNGS): %.png: %.pam
|
|
|
|
convert $< $@
|
|
|
|
|
|
|
|
$(MONOPAMS): %.pam: mkicon.py
|
2007-01-06 18:15:35 +00:00
|
|
|
./mkicon.py -2 $(MODE) $(join $(subst -, ,$(subst -mono,,$(basename $@))),_icon) $@
|
|
|
|
|
2016-03-23 06:41:27 +00:00
|
|
|
$(TRUEPAMS): %.pam: mkicon.py
|
2007-01-06 18:15:35 +00:00
|
|
|
./mkicon.py -T $(MODE) $(join $(subst -, ,$(subst -true,,$(basename $@))),_icon) $@
|
|
|
|
|
New script to draw the icons as SVG.
This gets us scalable icons that will go to extremely large sizes
without the problems that arise from scaling up the output of
mkicon.py, in which outlines become too thin because the script was
mostly concerned with trying to squeeze all the desired detail into
_tiny_ sizes.
The SVG icons are generated by mksvg.py, which is a conversion of the
existing mkicon.py. So the SVG files themselves are not committed in
this repo; 'make svg' in the icons subdir will generate them.
(I haven't decided yet whether this state of affairs should be
permanent. Perhaps _having_ generated the SVGs via a similar program
to the bitmap icons, we should regard the script as a discardable
booster stage and redesignate the SVGs themselves as the source format
for future modifications, so that they can be edited in Inkscape or
similar rather than by tinkering with Python. On the other hand,
perhaps keeping the script will make it easier to keep the icon family
consistent, e.g. if changing the style of one of the shared visual
components.)
My plan is that we should stick with the output of the previous
bitmap-generating script for all the _small_ icons, up to and
including 48 pixels, because it does a better job at low resolution.
(That was really what it was for in the first place: you can think of
it as an analogue of a scalable-font hinting system, to tune the
scaling for very low res so that all the important features are still
visible.)
I think probably I want to switch the 128-pixel icons used in the Mac
icon file over to being rendered from the SVG (though in this commit I
haven't gone that far, not least because I'll also need to prepare a
corresponding black and white version). I haven't done extensive
research yet to decide where I think the crossover point in between
is.
2022-03-18 07:11:11 +00:00
|
|
|
$(SVGS): %.svg: mksvg.py
|
|
|
|
./mksvg.py $(patsubst %.svg,%_icon,$@) -o $@
|
|
|
|
|
2007-01-06 18:15:35 +00:00
|
|
|
putty.ico: putty-16.png putty-32.png putty-48.png \
|
|
|
|
putty-16-mono.png putty-32-mono.png putty-48-mono.png
|
|
|
|
./icon.pl -4 $(filter-out %-mono.png, $^) -1 $(filter %-mono.png, $^) > $@
|
|
|
|
|
|
|
|
puttycfg.ico: puttycfg-16.png puttycfg-32.png puttycfg-48.png \
|
|
|
|
puttycfg-16-mono.png puttycfg-32-mono.png puttycfg-48-mono.png
|
|
|
|
./icon.pl -4 $(filter-out %-mono.png, $^) -1 $(filter %-mono.png, $^) > $@
|
|
|
|
|
|
|
|
puttygen.ico: puttygen-16.png puttygen-32.png puttygen-48.png \
|
|
|
|
puttygen-16-mono.png puttygen-32-mono.png puttygen-48-mono.png
|
|
|
|
./icon.pl -4 $(filter-out %-mono.png, $^) -1 $(filter %-mono.png, $^) > $@
|
|
|
|
|
|
|
|
pageant.ico: pageant-16.png pageant-32.png pageant-48.png \
|
|
|
|
pageant-16-mono.png pageant-32-mono.png pageant-48-mono.png
|
|
|
|
./icon.pl -4 $(filter-out %-mono.png, $^) -1 $(filter %-mono.png, $^) > $@
|
|
|
|
|
|
|
|
pageants.ico: pageant-16.png pageant-16-mono.png
|
|
|
|
./icon.pl -4 $(filter-out %-mono.png, $^) -1 $(filter %-mono.png, $^) > $@
|
|
|
|
|
|
|
|
pscp.ico: pscp-16.png pscp-32.png pscp-48.png \
|
|
|
|
pscp-16-mono.png pscp-32-mono.png pscp-48-mono.png
|
|
|
|
./icon.pl -4 $(filter-out %-mono.png, $^) -1 $(filter %-mono.png, $^) > $@
|
|
|
|
|
2021-05-08 16:22:19 +00:00
|
|
|
pterm.ico: pterm-16.png pterm-32.png pterm-48.png \
|
|
|
|
pterm-16-mono.png pterm-32-mono.png pterm-48-mono.png
|
|
|
|
./icon.pl -4 $(filter-out %-mono.png, $^) -1 $(filter %-mono.png, $^) > $@
|
|
|
|
|
|
|
|
ptermcfg.ico: ptermcfg-16.png ptermcfg-32.png ptermcfg-48.png \
|
|
|
|
ptermcfg-16-mono.png ptermcfg-32-mono.png ptermcfg-48-mono.png
|
|
|
|
./icon.pl -4 $(filter-out %-mono.png, $^) -1 $(filter %-mono.png, $^) > $@
|
|
|
|
|
2007-01-22 18:02:06 +00:00
|
|
|
# Because the installer icon makes heavy use of brown when drawing
|
|
|
|
# the cardboard box, it's worth having 8-bit versions of it in
|
|
|
|
# addition to the 4- and 1-bit ones.
|
2007-02-06 22:39:15 +00:00
|
|
|
puttyins.ico: puttyins-16.png puttyins-32.png puttyins-48.png \
|
|
|
|
puttyins-16-mono.png puttyins-32-mono.png \
|
|
|
|
puttyins-48-mono.png \
|
|
|
|
puttyins-16-true.png puttyins-32-true.png \
|
|
|
|
puttyins-48-true.png
|
2007-01-22 18:02:06 +00:00
|
|
|
./icon.pl -8 $(filter %-true.png, $^) \
|
|
|
|
-4 $(filter-out %-true.png, $(filter-out %-mono.png, $^)) \
|
|
|
|
-1 $(filter %-mono.png, $^) > $@
|
|
|
|
|
2007-01-25 00:14:01 +00:00
|
|
|
# Icon for the website. (This isn't linked into "make all".)
|
|
|
|
website.ico: putty-16.png
|
|
|
|
./icon.pl -4 $^ >$@
|
|
|
|
|
2007-01-06 18:15:35 +00:00
|
|
|
xpmputty.c: putty-16.png putty-32.png putty-48.png
|
|
|
|
./cicon.pl main_icon $^ > $@
|
|
|
|
|
|
|
|
xpmpucfg.c: puttycfg-16.png puttycfg-32.png puttycfg-48.png
|
|
|
|
./cicon.pl cfg_icon $^ > $@
|
|
|
|
|
|
|
|
xpmpterm.c: pterm-16.png pterm-32.png pterm-48.png
|
|
|
|
./cicon.pl main_icon $^ > $@
|
|
|
|
|
|
|
|
xpmptcfg.c: ptermcfg-16.png ptermcfg-32.png ptermcfg-48.png
|
|
|
|
./cicon.pl cfg_icon $^ > $@
|
|
|
|
|
2016-03-23 06:41:27 +00:00
|
|
|
PuTTY.icns: putty-16-mono.pam putty-16.pam \
|
|
|
|
putty-32-mono.pam putty-32.pam \
|
|
|
|
putty-48-mono.pam putty-48.pam \
|
|
|
|
putty-128.pam
|
|
|
|
./macicon.py mono:putty-16-mono.pam colour:putty-16.pam \
|
|
|
|
mono:putty-32-mono.pam colour:putty-32.pam \
|
|
|
|
mono:putty-48-mono.pam colour:putty-48.pam \
|
|
|
|
colour:putty-128.pam \
|
2015-09-06 08:50:09 +00:00
|
|
|
output:$@
|
|
|
|
|
2016-03-23 22:02:46 +00:00
|
|
|
Pterm.icns: pterm-16-mono.pam pterm-16.pam \
|
|
|
|
pterm-32-mono.pam pterm-32.pam \
|
|
|
|
pterm-48-mono.pam pterm-48.pam \
|
|
|
|
pterm-128.pam
|
|
|
|
./macicon.py mono:pterm-16-mono.pam colour:pterm-16.pam \
|
|
|
|
mono:pterm-32-mono.pam colour:pterm-32.pam \
|
|
|
|
mono:pterm-48-mono.pam colour:pterm-48.pam \
|
|
|
|
colour:pterm-128.pam \
|
|
|
|
output:$@
|
|
|
|
|
2007-01-06 18:15:35 +00:00
|
|
|
clean:
|
2016-03-23 06:41:27 +00:00
|
|
|
rm -f *.pam *.png *.ico *.icns *.c
|