forked from yasusho/linmarn_font_project
-
Notifications
You must be signed in to change notification settings - Fork 0
/
to_font.ts
78 lines (74 loc) · 2.82 KB
/
to_font.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
import { generateFonts, FontAssetType, OtherAssetType } from 'fantasticon';
import * as fs from 'fs';
(async function() {
const style_name = process.argv[2] ?? (() => { throw new Error("スタイル名およびフォルダを node fix_glyphs.js rounded rounded/fixed のような形で指定して実行してください。") })()
const fix_path = process.argv[3] ?? (() => { throw new Error("スタイル名およびフォルダを node fix_glyphs.js rounded rounded/fixed のような形で指定して実行してください。") })()
const out_path = `fonts/${style_name}`;
const glyph_map: { [key: string]: number } = {};
const files = fs.readdirSync(`${fix_path}/`);
files.forEach((file, index) => {
if (file.slice(-4) !== ".svg") return;
if (file.slice(0, 2).toUpperCase() === "U+") {
// U+002F.svg
// ^^^^
const codepoint = file.slice(2, -4);
glyph_map[file.slice(0, -4)] = parseInt(codepoint, 16);
console.log(file.slice(0, -4), codepoint);
} else {
glyph_map[file[0]] = file.codePointAt(0)!;
console.log(file[0], file.codePointAt(0)!.toString(16))
}
});
if (!fs.existsSync(out_path)) {
fs.mkdirSync(out_path);
}
generateFonts({
inputDir: `${fix_path}/`,
outputDir: `${out_path}/`,
name: `linzklar_${style_name}`,
fontTypes: [FontAssetType.TTF, FontAssetType.WOFF],
assetTypes: [
OtherAssetType.CSS,
OtherAssetType.HTML,
OtherAssetType.JSON,
/* OtherAssetType.TS */ // The TS asset is buggy; remove
],
fontHeight: 480,
codepoints: glyph_map
}).then(results => {
console.log(results);
fs.readFile(`${out_path}/linzklar_${style_name}.html`, 'utf8', function (err,data) {
if (err) {
return console.log(err);
}
const result = replace_problematic_css(data);
fs.writeFile(`${out_path}/linzklar_${style_name}.html`, result, 'utf8', function (err) {
if (err) return console.log(err);
});
});
fs.readFile(`${out_path}/linzklar_${style_name}.css`, 'utf8', function (err,data) {
if (err) {
return console.log(err);
}
const result = replace_problematic_css(data);
fs.writeFile(`${out_path}/linzklar_${style_name}.css`, result, 'utf8', function (err) {
if (err) return console.log(err);
});
});
});
})();
// CSS が壊れたり HTML でワーニングが出たりするやつを CSS と HTML から除く
function replace_problematic_css(data: string) {
return data
.replaceAll('U+', 'U-')
.replaceAll('icon-!', 'icon-exclamation')
.replaceAll('icon-,', 'icon-comma')
.replaceAll('icon-(', 'icon-left-paren')
.replaceAll('icon-)', 'icon-right-paren')
.replaceAll('icon-[', 'icon-left-square-bracket')
.replaceAll('icon-]', 'icon-right-square-bracket')
.replaceAll('icon-{', 'icon-left-curly-brace')
.replaceAll('icon-}', 'icon-right-curly-brace')
.replaceAll("class='label'", `class="label"`)
;
}