Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/neverpanic/google-font-download
Locally host Google's web fonts
https://github.com/neverpanic/google-font-download
command-line css fonts shell webfonts
Last synced: 2 days ago
JSON representation
Locally host Google's web fonts
- Host: GitHub
- URL: https://github.com/neverpanic/google-font-download
- Owner: neverpanic
- License: bsd-2-clause
- Created: 2015-06-13T22:47:52.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2020-06-21T20:39:27.000Z (over 4 years ago)
- Last Synced: 2025-01-10T02:25:47.738Z (4 days ago)
- Topics: command-line, css, fonts, shell, webfonts
- Language: Shell
- Homepage: https://neverpanic.de/blog/2014/03/19/downloading-google-web-fonts-for-local-hosting/
- Size: 63.5 KB
- Stars: 706
- Watchers: 23
- Forks: 72
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# google-font-download
This is a small shell script that allows you to download Google's web fonts to
your local file system. Additionally, a CSS file that uses your local copy of
the fonts is generated. You may want to use this if you want to avoid
requesting resources from 3rd party servers (for example for privacy reasons or
because you do not have a connection to the public internet).## Requirements
To run this script, you will need:
- Bash (>= 4.x)
- curl
- getopt, preferrably a version that preserves quoted whitespace and supports long options
- tput
- fmt
- sed, in a version that has extended regex support using either `-E` (BSD) or `-r` (GNU)
- awk
- tr
- grep## License
The script is released under the 2-clause BSD license. The SPDX identifier of
this license is BSD-2-Clause. See the [`LICENSE`](LICENSE) file for
the terms.## Usage
### Synopsis
`google-font-download [OPTION...] [FONT...]`### Options
-
-u URL
,--url=URL
- Dowload the fonts specified in the URL. Note: You can mix it with normal arguments (See below).
-
-f FORMAT
,--format=FORMAT
- Download the specified set of webfont formats from Google's servers.
FORMAT
is a comma-separated list of identifiers for
webfont formats. Supported identifiers areeot
,
woff
,woff2
,svg
, and
ttf
. Additionally, the special valueall
expands to all supported formats in the orderwoff2
,
woff
,eot
,svg
,
ttf
. The default isall
. The generated CSS
file will contain the font formats in the given order, which browsers
will process in-order. Note that you probably do not need all formats.
In most cases, a combination of WOFF2 and WOFF is enough. See
http://caniuse.com/#search=woff for a current status. -
-h
,--help
- Display this message and exit.
-
-l LANGSPEC
,--languages=LANGSPEC
- Download the specified subset of languages from Google's webfonts.
LANGSPEC
is a comma-separated list of idenfitiers for font
subsets. Common identifiers arelatin
,
latin-ext
,cyrillic
,
cyrillic-ext
,greek
,greek-ext
,
etc. An undocumented language isall
which means the full
(non-subset) files are served. The default islatin
. -
-o OUTPUT
,--output=OUTPUT
- Write the generated CSS into
OUTPUT
. The file will be
overwritten and will be created if it doesn't exist. The default is
font.css
.
### Positional Arguments
This script accepts an arbitrary number of font specs. A font spec consists
of a font name as accepted by Google's servers, optionally followed by
a colon, an optional font weight in numbers or the string "bold" and an
optional font style of "italic" (or "i") for italics. In [EBNF](https://en.wikipedia.org/wiki/Extended_Backus%E2%80%93Naur_form):
```ebnf
fontspec = fontname, [ ":", [ fontweight ], [ fontstyle ] ]
fontweight = number | "bold"
number = { digit }
digit = "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9"
fontstyle = "italic" | "i"
```
While Google's servers will accept other inputs and abbreviations for font
weight and font style, they are not supported by this script.
Note: if you don't use the URL argument, your font spec should *not* be URL-encoded and only one font weight
is supported per font specification. If you want to download multiple font
weights or styles, provide multiple font specs.
For example, to download Open Sans in
- light (300),
- normal (400),
- normal italic (400italic),
- bold (700), and
- bold italic (700italic),
run:
```bash
google-font-download \
"Open Sans:300" "Open Sans:400" "Open Sans:400italic" \
"Open Sans:700" "Open Sans:700italic"
```
or in URL format:
```bash
google-font-download --url="https://fonts.google.com/?selection.family=Open+Sans:300,400,400i,700,700i"
```
You can also mix the arguments:
```bash
google-font-download --url="https://fonts.google.com/?selection.family=Open+Sans:300,400,400i" \
"Open Sans:700" "Open Sans:700i"
```