Merge pull request #4335 from googlefonts/bug_fixes
[instancer] support avar table, fix issues in STAT/fvar tables
diff --git a/.ci/requirements-fonttools.txt b/.ci/requirements-fonttools.txt
index 96e56a0..345c41b 100644
--- a/.ci/requirements-fonttools.txt
+++ b/.ci/requirements-fonttools.txt
@@ -4,39 +4,39 @@
#
# pip-compile --generate-hashes .ci/requirements-fonttools.in
#
-fonttools==4.41.0 \
- --hash=sha256:0614b6348866092d00df3dfb37e037fc06412ca67087de361a2777ea5ed62c16 \
- --hash=sha256:06eac087ea55b3ebb2207d93b5ac56c847163899f05f5a77e1910f688fe10030 \
- --hash=sha256:19d461c801b8904d201c6c38a99bfcfef673bfdfe0c7f026f582ef78896434e0 \
- --hash=sha256:381558eafffc1432d08ca58063e71c7376ecaae48e9318354a90a1049a644845 \
- --hash=sha256:3ee75b8ca48f6c48af25e967dce995ef94e46872b35c7d454b983c62c9c7006d \
- --hash=sha256:415cf7c806a3f56fb280dadcf3c92c85c0415e75665ca957b4a2a2e39c17a5c9 \
- --hash=sha256:465d0f24bf4f75160f441793b55076b7a080a57d3a1f738390af2c20bee24fbb \
- --hash=sha256:4c654b1facf1f3b742e4d9b2dcdf0fa867b1f007b1b4981cc58a75ef5dca2a3c \
- --hash=sha256:50f8bdb421270f71b54695c62785e300fab4bb6127be40bf9f3084962a0c3adb \
- --hash=sha256:5448a87f6ed57ed844b64a05d3792827af584a8584613f6289867f4e77eb603b \
- --hash=sha256:560ea1a604c927399f36742abf342a4c5f3fee8e8e8a484b774dfe9630bd9a91 \
- --hash=sha256:5b1c2b21b40229166a864f2b0aec06d37f0a204066deb1734c93370e0c76339d \
- --hash=sha256:69178674505ec81adf4af2a3bbacd0cb9a37ba7831bc3fca307f80e48ab2767b \
- --hash=sha256:69dbe0154e15b68dd671441ea8f23dad87488b24a6e650d45958f4722819a443 \
- --hash=sha256:6faff25991dec48f8cac882055a09ae1a29fd15bc160bc3d663e789e994664c2 \
- --hash=sha256:72d40a32d6443871ea0d147813caad58394b48729dfa4fbc45dcaac54f9506f2 \
- --hash=sha256:7e22d0144d735f6c7df770509b8c0c33414bf460df0d5dddc98a159e5dbb10eb \
- --hash=sha256:841c491fa3e9c54e8f9cd5dae059e88f45e086aea090c28be9d42f59c8b99e01 \
- --hash=sha256:86edb95c4d1fe4fae2111d7e0c10c6e42b7790b377bcf1952303469eee5b52bb \
- --hash=sha256:8f602dd5bcde7e4241419924f23c6f0d66723dd5408a58c3a2f781745c693f45 \
- --hash=sha256:9387b09694fbf8ac7dcf887069068f81fb4124d05e09557ac7daabfbec1744bd \
- --hash=sha256:b329ae7ce971b5c4148d6cdb8119c0ce4587265b2330d4f2f3776ef851bee020 \
- --hash=sha256:ba2a367ff478cd108d5319c0dc4fd4eb4ea3476dbfc45b00c45718e889cd9463 \
- --hash=sha256:bc9e7b1e268be7a23fc66471b615c324e99c5db39ce8c49dd6dd8e962c7bc1b8 \
- --hash=sha256:c890061915e95b619c1d3cc3c107c6fb021406b701c0c24b03e74830d522f210 \
- --hash=sha256:cc3324e4159e6d1f55c3615b4c1c211f87cc96cc0cc7c946c8447dc1319f2e9d \
- --hash=sha256:d2dae84a3d0f76884a6102c62f2795b2d6602c2c95cfcce74c8a590b6200e533 \
- --hash=sha256:d45f28c20bb67dee0f4a4caae709f40b0693d764b7b2bf2d58890f36b1bfcef0 \
- --hash=sha256:e38bd91eae257f36c2b7245c0278e9cd9d754f3a66b8d2b548c623ba66e387b6 \
- --hash=sha256:e43f6c7f9ba4f9d29edee530e45f9aa162872ec9549398b85971477a99f2a806 \
- --hash=sha256:ea879afd1d6189fca02a85a7868560c9bb8415dccff6b7ae6d81e4f06b3ab30d \
- --hash=sha256:eb9dfa87152bd97019adc387b2f29ef6af601de4386f36570ca537ace96d96ed \
- --hash=sha256:efd59e83223cb77952997fb850c7a7c2a958c9af0642060f536722c2a9e9d53b \
- --hash=sha256:f3fe90dfb297bd8265238c06787911cd81c2cb89ac5b13e1c911928bdabfce0f
+fonttools==4.41.1 \
+ --hash=sha256:1df1b6f4c7c4bc8201eb47f3b268adbf2539943aa43c400f84556557e3e109c0 \
+ --hash=sha256:2a22b2c425c698dcd5d6b0ff0b566e8e9663172118db6fd5f1941f9b8063da9b \
+ --hash=sha256:33191f062549e6bb1a4782c22a04ebd37009c09360e2d6686ac5083774d06d95 \
+ --hash=sha256:38cdecd8f1fd4bf4daae7fed1b3170dfc1b523388d6664b2204b351820aa78a7 \
+ --hash=sha256:3ae64303ba670f8959fdaaa30ba0c2dabe75364fdec1caeee596c45d51ca3425 \
+ --hash=sha256:3d1f9471134affc1e3b1b806db6e3e2ad3fa99439e332f1881a474c825101096 \
+ --hash=sha256:4e3334d51f0e37e2c6056e67141b2adabc92613a968797e2571ca8a03bd64773 \
+ --hash=sha256:4edc795533421e98f60acee7d28fc8d941ff5ac10f44668c9c3635ad72ae9045 \
+ --hash=sha256:547ab36a799dded58a46fa647266c24d0ed43a66028cd1cd4370b246ad426cac \
+ --hash=sha256:59eba8b2e749a1de85760da22333f3d17c42b66e03758855a12a2a542723c6e7 \
+ --hash=sha256:704bccd69b0abb6fab9f5e4d2b75896afa48b427caa2c7988792a2ffce35b441 \
+ --hash=sha256:73ef0bb5d60eb02ba4d3a7d23ada32184bd86007cb2de3657cfcb1175325fc83 \
+ --hash=sha256:7763316111df7b5165529f4183a334aa24c13cdb5375ffa1dc8ce309c8bf4e5c \
+ --hash=sha256:849ec722bbf7d3501a0e879e57dec1fc54919d31bff3f690af30bb87970f9784 \
+ --hash=sha256:891cfc5a83b0307688f78b9bb446f03a7a1ad981690ac8362f50518bc6153975 \
+ --hash=sha256:952cb405f78734cf6466252fec42e206450d1a6715746013f64df9cbd4f896fa \
+ --hash=sha256:a7bbb290d13c6dd718ec2c3db46fe6c5f6811e7ea1e07f145fd8468176398224 \
+ --hash=sha256:a9b3cc10dc9e0834b6665fd63ae0c6964c6bc3d7166e9bc84772e0edd09f9fa2 \
+ --hash=sha256:aaaef294d8e411f0ecb778a0aefd11bb5884c9b8333cc1011bdaf3b58ca4bd75 \
+ --hash=sha256:afce2aeb80be72b4da7dd114f10f04873ff512793d13ce0b19d12b2a4c44c0f0 \
+ --hash=sha256:b0938ebbeccf7c80bb9a15e31645cf831572c3a33d5cc69abe436e7000c61b14 \
+ --hash=sha256:b2d1ee95be42b80d1f002d1ee0a51d7a435ea90d36f1a5ae331be9962ee5a3f1 \
+ --hash=sha256:b927e5f466d99c03e6e20961946314b81d6e3490d95865ef88061144d9f62e38 \
+ --hash=sha256:bdd729744ae7ecd7f7311ad25d99da4999003dcfe43b436cf3c333d4e68de73d \
+ --hash=sha256:c2071267deaa6d93cb16288613419679c77220543551cbe61da02c93d92df72f \
+ --hash=sha256:cac73bbef7734e78c60949da11c4903ee5837168e58772371bd42a75872f4f82 \
+ --hash=sha256:da2c2964bdc827ba6b8a91dc6de792620be4da3922c4cf0599f36a488c07e2b2 \
+ --hash=sha256:e16a9449f21a93909c5be2f5ed5246420f2316e94195dbfccb5238aaa38f9751 \
+ --hash=sha256:e5c2b0a95a221838991e2f0e455dec1ca3a8cc9cd54febd68cc64d40fdb83669 \
+ --hash=sha256:ec453a45778524f925a8f20fd26a3326f398bfc55d534e37bab470c5e415caa1 \
+ --hash=sha256:edee0900cf0eedb29d17c7876102d6e5a91ee333882b1f5abc83e85b934cadb5 \
+ --hash=sha256:f14f3ccea4cc7dd1b277385adf3c3bf18f9860f87eab9c2fb650b0af16800f55 \
+ --hash=sha256:f240d9adf0583ac8fc1646afe7f4ac039022b6f8fa4f1575a2cfa53675360b69 \
+ --hash=sha256:f48602c0b3fd79cd83a34c40af565fe6db7ac9085c8823b552e6e751e3a5b8be
# via -r requirements-fonttools.in
diff --git a/.ci/requirements.txt b/.ci/requirements.txt
index e585a58..00c4437 100644
--- a/.ci/requirements.txt
+++ b/.ci/requirements.txt
@@ -4,41 +4,41 @@
#
# pip-compile --generate-hashes .ci/requirements.in
#
-fonttools==4.41.0 \
- --hash=sha256:0614b6348866092d00df3dfb37e037fc06412ca67087de361a2777ea5ed62c16 \
- --hash=sha256:06eac087ea55b3ebb2207d93b5ac56c847163899f05f5a77e1910f688fe10030 \
- --hash=sha256:19d461c801b8904d201c6c38a99bfcfef673bfdfe0c7f026f582ef78896434e0 \
- --hash=sha256:381558eafffc1432d08ca58063e71c7376ecaae48e9318354a90a1049a644845 \
- --hash=sha256:3ee75b8ca48f6c48af25e967dce995ef94e46872b35c7d454b983c62c9c7006d \
- --hash=sha256:415cf7c806a3f56fb280dadcf3c92c85c0415e75665ca957b4a2a2e39c17a5c9 \
- --hash=sha256:465d0f24bf4f75160f441793b55076b7a080a57d3a1f738390af2c20bee24fbb \
- --hash=sha256:4c654b1facf1f3b742e4d9b2dcdf0fa867b1f007b1b4981cc58a75ef5dca2a3c \
- --hash=sha256:50f8bdb421270f71b54695c62785e300fab4bb6127be40bf9f3084962a0c3adb \
- --hash=sha256:5448a87f6ed57ed844b64a05d3792827af584a8584613f6289867f4e77eb603b \
- --hash=sha256:560ea1a604c927399f36742abf342a4c5f3fee8e8e8a484b774dfe9630bd9a91 \
- --hash=sha256:5b1c2b21b40229166a864f2b0aec06d37f0a204066deb1734c93370e0c76339d \
- --hash=sha256:69178674505ec81adf4af2a3bbacd0cb9a37ba7831bc3fca307f80e48ab2767b \
- --hash=sha256:69dbe0154e15b68dd671441ea8f23dad87488b24a6e650d45958f4722819a443 \
- --hash=sha256:6faff25991dec48f8cac882055a09ae1a29fd15bc160bc3d663e789e994664c2 \
- --hash=sha256:72d40a32d6443871ea0d147813caad58394b48729dfa4fbc45dcaac54f9506f2 \
- --hash=sha256:7e22d0144d735f6c7df770509b8c0c33414bf460df0d5dddc98a159e5dbb10eb \
- --hash=sha256:841c491fa3e9c54e8f9cd5dae059e88f45e086aea090c28be9d42f59c8b99e01 \
- --hash=sha256:86edb95c4d1fe4fae2111d7e0c10c6e42b7790b377bcf1952303469eee5b52bb \
- --hash=sha256:8f602dd5bcde7e4241419924f23c6f0d66723dd5408a58c3a2f781745c693f45 \
- --hash=sha256:9387b09694fbf8ac7dcf887069068f81fb4124d05e09557ac7daabfbec1744bd \
- --hash=sha256:b329ae7ce971b5c4148d6cdb8119c0ce4587265b2330d4f2f3776ef851bee020 \
- --hash=sha256:ba2a367ff478cd108d5319c0dc4fd4eb4ea3476dbfc45b00c45718e889cd9463 \
- --hash=sha256:bc9e7b1e268be7a23fc66471b615c324e99c5db39ce8c49dd6dd8e962c7bc1b8 \
- --hash=sha256:c890061915e95b619c1d3cc3c107c6fb021406b701c0c24b03e74830d522f210 \
- --hash=sha256:cc3324e4159e6d1f55c3615b4c1c211f87cc96cc0cc7c946c8447dc1319f2e9d \
- --hash=sha256:d2dae84a3d0f76884a6102c62f2795b2d6602c2c95cfcce74c8a590b6200e533 \
- --hash=sha256:d45f28c20bb67dee0f4a4caae709f40b0693d764b7b2bf2d58890f36b1bfcef0 \
- --hash=sha256:e38bd91eae257f36c2b7245c0278e9cd9d754f3a66b8d2b548c623ba66e387b6 \
- --hash=sha256:e43f6c7f9ba4f9d29edee530e45f9aa162872ec9549398b85971477a99f2a806 \
- --hash=sha256:ea879afd1d6189fca02a85a7868560c9bb8415dccff6b7ae6d81e4f06b3ab30d \
- --hash=sha256:eb9dfa87152bd97019adc387b2f29ef6af601de4386f36570ca537ace96d96ed \
- --hash=sha256:efd59e83223cb77952997fb850c7a7c2a958c9af0642060f536722c2a9e9d53b \
- --hash=sha256:f3fe90dfb297bd8265238c06787911cd81c2cb89ac5b13e1c911928bdabfce0f
+fonttools==4.41.1 \
+ --hash=sha256:1df1b6f4c7c4bc8201eb47f3b268adbf2539943aa43c400f84556557e3e109c0 \
+ --hash=sha256:2a22b2c425c698dcd5d6b0ff0b566e8e9663172118db6fd5f1941f9b8063da9b \
+ --hash=sha256:33191f062549e6bb1a4782c22a04ebd37009c09360e2d6686ac5083774d06d95 \
+ --hash=sha256:38cdecd8f1fd4bf4daae7fed1b3170dfc1b523388d6664b2204b351820aa78a7 \
+ --hash=sha256:3ae64303ba670f8959fdaaa30ba0c2dabe75364fdec1caeee596c45d51ca3425 \
+ --hash=sha256:3d1f9471134affc1e3b1b806db6e3e2ad3fa99439e332f1881a474c825101096 \
+ --hash=sha256:4e3334d51f0e37e2c6056e67141b2adabc92613a968797e2571ca8a03bd64773 \
+ --hash=sha256:4edc795533421e98f60acee7d28fc8d941ff5ac10f44668c9c3635ad72ae9045 \
+ --hash=sha256:547ab36a799dded58a46fa647266c24d0ed43a66028cd1cd4370b246ad426cac \
+ --hash=sha256:59eba8b2e749a1de85760da22333f3d17c42b66e03758855a12a2a542723c6e7 \
+ --hash=sha256:704bccd69b0abb6fab9f5e4d2b75896afa48b427caa2c7988792a2ffce35b441 \
+ --hash=sha256:73ef0bb5d60eb02ba4d3a7d23ada32184bd86007cb2de3657cfcb1175325fc83 \
+ --hash=sha256:7763316111df7b5165529f4183a334aa24c13cdb5375ffa1dc8ce309c8bf4e5c \
+ --hash=sha256:849ec722bbf7d3501a0e879e57dec1fc54919d31bff3f690af30bb87970f9784 \
+ --hash=sha256:891cfc5a83b0307688f78b9bb446f03a7a1ad981690ac8362f50518bc6153975 \
+ --hash=sha256:952cb405f78734cf6466252fec42e206450d1a6715746013f64df9cbd4f896fa \
+ --hash=sha256:a7bbb290d13c6dd718ec2c3db46fe6c5f6811e7ea1e07f145fd8468176398224 \
+ --hash=sha256:a9b3cc10dc9e0834b6665fd63ae0c6964c6bc3d7166e9bc84772e0edd09f9fa2 \
+ --hash=sha256:aaaef294d8e411f0ecb778a0aefd11bb5884c9b8333cc1011bdaf3b58ca4bd75 \
+ --hash=sha256:afce2aeb80be72b4da7dd114f10f04873ff512793d13ce0b19d12b2a4c44c0f0 \
+ --hash=sha256:b0938ebbeccf7c80bb9a15e31645cf831572c3a33d5cc69abe436e7000c61b14 \
+ --hash=sha256:b2d1ee95be42b80d1f002d1ee0a51d7a435ea90d36f1a5ae331be9962ee5a3f1 \
+ --hash=sha256:b927e5f466d99c03e6e20961946314b81d6e3490d95865ef88061144d9f62e38 \
+ --hash=sha256:bdd729744ae7ecd7f7311ad25d99da4999003dcfe43b436cf3c333d4e68de73d \
+ --hash=sha256:c2071267deaa6d93cb16288613419679c77220543551cbe61da02c93d92df72f \
+ --hash=sha256:cac73bbef7734e78c60949da11c4903ee5837168e58772371bd42a75872f4f82 \
+ --hash=sha256:da2c2964bdc827ba6b8a91dc6de792620be4da3922c4cf0599f36a488c07e2b2 \
+ --hash=sha256:e16a9449f21a93909c5be2f5ed5246420f2316e94195dbfccb5238aaa38f9751 \
+ --hash=sha256:e5c2b0a95a221838991e2f0e455dec1ca3a8cc9cd54febd68cc64d40fdb83669 \
+ --hash=sha256:ec453a45778524f925a8f20fd26a3326f398bfc55d534e37bab470c5e415caa1 \
+ --hash=sha256:edee0900cf0eedb29d17c7876102d6e5a91ee333882b1f5abc83e85b934cadb5 \
+ --hash=sha256:f14f3ccea4cc7dd1b277385adf3c3bf18f9860f87eab9c2fb650b0af16800f55 \
+ --hash=sha256:f240d9adf0583ac8fc1646afe7f4ac039022b6f8fa4f1575a2cfa53675360b69 \
+ --hash=sha256:f48602c0b3fd79cd83a34c40af565fe6db7ac9085c8823b552e6e751e3a5b8be
# via -r requirements-fonttools.in
gcovr==5.0 \
--hash=sha256:1d80264cbaadff356b3dda71b8c62b3aa803e5b3eb6d526a24932cd6660a2576 \
diff --git a/.github/workflows/scorecard.yml b/.github/workflows/scorecard.yml
index b422048..6aaae1c 100644
--- a/.github/workflows/scorecard.yml
+++ b/.github/workflows/scorecard.yml
@@ -59,6 +59,6 @@
# Upload the results to GitHub's code scanning dashboard.
- name: "Upload to code-scanning"
- uses: github/codeql-action/upload-sarif@489225d82a57396c6f426a40e66d461b16b3461d # v2.20.4
+ uses: github/codeql-action/upload-sarif@1813ca74c3faaa3a2da2070b9b8a0b3e7373a0d8 # v2.21.0
with:
sarif_file: results.sarif
diff --git a/docs/wasm-shaper.md b/docs/wasm-shaper.md
index bc37400..58a1d64 100644
--- a/docs/wasm-shaper.md
+++ b/docs/wasm-shaper.md
@@ -370,17 +370,14 @@
## Enabling the WASM shaper when building Harfbuzz
-First, you will need the `wasm-micro-runtime` library installed on your computer. Download `wasm-micro-runtime` from [its GitHub repository](https://github.com/bytecodealliance/wasm-micro-runtime/tree/main); then follow [the instructions for building](https://github.com/bytecodealliance/wasm-micro-runtime/blob/main/product-mini/README.md), except add the `-DWAMR_BUILD_REF_TYPES=1` flag to the `cmake` line. (You may want to enable "fast JIT".) Follow this with a `make install`.
+First, you will need the `wasm-micro-runtime` library installed on your computer. Download `wasm-micro-runtime` from [its GitHub repository](https://github.com/bytecodealliance/wasm-micro-runtime/tree/main); then follow [the instructions for building](https://github.com/bytecodealliance/wasm-micro-runtime/blob/main/product-mini/README.md), except run the cmake command from the repository root directory and add the `-DWAMR_BUILD_REF_TYPES=1` flag to the `cmake` line. (You may want to enable "fast JIT".) Then, install it.
So, for example:
```
-$ cd product-mini/platforms/darwin
-$ mkdir build
-$ cd build
-$ cmake .. -DWAMR_BUILD_REF_TYPES=1 -DWAMR_BUILD_FAST_JIT=1
-$ make
-$ make install
+$ cmake -B build -DWAMR_BUILD_REF_TYPES=1 -DWAMR_BUILD_FAST_JIT=1
+$ cmake --build build --parallel
+$ sudo cmake --build build --target install
```
(If you don't want to install `wasm-micro-runtime` globally, you can copy `libiwasm.*` and `libvmlib.a` into a directory that your compiler can see when building Harfbuzz.)
@@ -506,9 +503,9 @@
let mut buffer = GlyphBuffer::from_ref(buf_ref);
for mut item in buffer.glyphs.iter_mut() {
// Map character to glyph
- item.codepoint = font.get_glyph(codepoint, 0);
+ item.codepoint = font.get_glyph(item.codepoint, 0);
// Set advance width
- item.h_advance = font.get_glyph_h_advance(item.codepoint);
+ item.x_advance = font.get_glyph_h_advance(item.codepoint);
}
1
}
diff --git a/perf/texts/duployan.txt b/perf/texts/duployan.txt
new file mode 100644
index 0000000..f330fc9
--- /dev/null
+++ b/perf/texts/duployan.txt
@@ -0,0 +1,27 @@
+𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰅𛱄𛰂𛱁 𛱛𛰆𛰑𛱁𛰋 𛰃𛱚𛰚
+
+𛱇𛰣 𛰂𛱆 𛰆𛱄𛰉𛰅𛰋𛱁𛰄𛰃
+
+𛱁𛰆𛱇𛰅𛰜 𛰅𛱄𛰈 𛱊𛱁𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛱛𛰅𛱛𛰅 𛰜𛱇𛱇𛰜𛱇𛰙 𛰅𛱄𛰂𛱁 𛰣𛱇𛰚𛱛𛰅
+
+𛰅𛰆𛱁𛰜𛰅𛱁 𛱜𛱜 𛰅𛱄𛰂𛱁 𛱛𛰆𛰑𛱁𛰋 𛰃𛱚𛰚 𛱆𛰚𛱁𛰃𛱁𛱆 𛰅𛱄𛰂𛱁 𛰜𛰅𛱂𛱆 𛰜𛰃𛱂𛰆𛱄͏͏͏, 𛱞𛰅 𛰃𛰆𛱛𛰜 𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱁𛰅𛰜𛰃𛱂 𛰙𛱁𛰙𛱛𛰅 𛰙𛱇𛰙𛰆𛱛𛰜 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜; 𛰂𛱆 𛰚𛱁𛱋𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛰚𛱁𛱞𛰃𛰅𛱁, 𛰂𛱛͏͏͏𛰜 𛰚𛱁𛱋𛰅𛱁 𛰚𛱁𛰚𛱇𛰣 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛱇𛰆𛱇𛰂 𛰅𛱄𛰂𛱁 𛰂𛱁𛱊𛱁 𛰂𛱆 𛱜𛱜 𛰅𛱁𛰅𛱜 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜. 𛰅𛱁𛰅𛱜 𛰂𛱛͏͏͏𛰜 𛱆𛰂𛰜𛱛𛰃 𛱛𛰅𛱛𛰅 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜. 𛰅𛱁𛰚𛱁𛱞 𛱆𛰅𛰃𛱂 𛰀𛰆𛱄𛱆𛰙𛱁 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱄𛰙𛰃𛱁𛰅𛰜: 𛱛𛰅𛱛𛰅 𛰚𛰜𛱁𛱆𛰅𛱁 𛱇𛰆𛱄͏͏͏ 𛰚𛱁𛰚𛱇𛰣. 𛱁𛱊𛱁𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰚𛱇𛰙 𛰅𛱄𛰂𛱁 𛱇𛰛𛱇𛰂𛰃 𛱇𛰆𛱇𛰀𛱇. 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛰅𛱁𛰃𛱂 𛱛𛰅𛱛𛰅 𛱁𛰚𛰅𛱁𛰃𛱇 𛰃𛱚𛰚 𛰙𛱇𛰋𛱄𛱆 𛰂𛱆 𛱄͏͏͏𛰄𛱆𛰋. 𛱛𛰅𛱛𛰅 𛰃𛱂𛱇𛱇 𛰅𛱄𛰂𛱁 𛰜𛰃𛱇𛰅, 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙, 𛰂𛱆 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛰅𛱁𛰚𛱁𛱞 𛱆𛰅𛰃𛱂 𛱆𛰂𛰜𛱛𛰃 𛰅𛱄𛰂𛱁 𛱂𛰄𛰋𛱇𛰅𛱁. 𛱞𛰀𛰃 𛰜𛰄𛱆𛰚𛰅𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙, 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛱊𛱁𛰅𛱁 𛱜𛱜; 𛰂𛱆 𛱇𛰆𛱇𛰂 𛰅𛱄𛰂𛱁 𛰜𛰄𛱆𛰚𛰅𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛱇𛰆𛱇𛰀𛱇, 𛰂𛱆 𛱇𛰆𛱄͏͏͏ 𛰅𛰆𛱁𛰜𛰅𛱁 𛰙𛱁𛰛 𛰃𛱄𛰙𛰃𛱄𛰙 𛱆𛰅𛰃𛱂 𛱁𛰚𛰅𛱁𛰃𛱇 𛰜𛰄𛱆𛰚𛰅𛰜 𛰙𛱁𛰛 𛰃𛱄𛰙𛰃𛱄𛰙.
+
+𛰅𛱄𛰂𛱁 𛱛𛰆𛰑𛱁𛰋 𛰃𛱚𛰚 𛱇𛰆𛱇𛰂 𛰂𛱛͏͏͏𛰜 𛰃𛱂𛱇𛱇 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛱄𛰂𛱁 𛱛𛰆𛰑𛱁𛰋 𛰙𛱁𛰙𛱛𛰅 𛰆𛱄͏͏͏ 𛰂𛱛͏͏͏𛰜 𛱇𛰆𛱄͏͏͏ 𛰅𛰆𛱁𛰜𛰅𛰜𛰃𛱂 𛰙𛱁𛰙𛱛𛰅 𛰙𛱇𛰙𛰆𛱛𛰜 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜, 𛱆𛰀𛰃 𛱄𛰆𛰙𛱁𛰚 𛰂𛱆 𛱊𛱁𛰅𛱁 𛰅𛰆𛱛𛰣𛰙𛱇𛰚 𛱁𛱊𛱁𛰜 𛰃𛱇𛰅𛱆 𛱇𛰜𛰅𛱄𛰙 𛰂𛱆 𛰙𛱁𛰙𛱛𛰅 𛰙𛱇𛰙𛰆𛱛𛰜 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜. 𛱇𛰆𛱄͏͏͏ 𛰚𛱁𛱋𛰅𛱁 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛱆𛰅𛰃𛱂 𛰙𛱁𛰙𛱛𛰅 𛰅𛰆𛱁𛰜𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛰅𛱁𛰅𛱜; 𛰅𛱄𛰂𛱆𛰃 𛰚𛱁𛱋𛰅𛱁 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛰂𛱛͏͏͏𛰜 𛱁𛱑 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛱇𛰆𛱄͏͏͏ 𛰃𛱇𛰅𛱆 𛱛𛰅𛱛𛰅 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛱜𛱜 𛰅𛱄𛰂𛱁 𛰂𛱛𛰆𛱂𛰅𛰆𛱇 𛰂𛱆 𛱆𛰂𛰜𛱛𛰃 𛰅𛱛𛰆𛱇 𛰅𛱄𛰂𛱁 𛰅𛰆𛱁𛰜𛰅𛱁 𛰊𛱁𛰋𛰈𛱇𛰚 𛰂𛱆 𛱇𛰆𛱇𛰀𛱇. 𛰅𛱁𛰆𛰃𛱁𛰛 𛰂𛱛͏͏͏𛰜 𛰅𛱁𛰅𛱜, 𛱛𛰅𛱛𛰅 𛰙𛱁𛰚 𛰂𛱆 𛰅𛰆𛱛𛰣𛰙𛱇𛰚 𛱁𛱊𛱁𛰜 𛰃𛱇𛰅𛱆 𛱇𛰜𛰅𛱄𛰙 𛰂𛱆 𛰙𛱁𛰙𛱛𛰅 𛰙𛱇𛰙𛰆𛱛𛰜 𛰅𛱁𛰚𛱁𛱞 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛱞𛰅 𛰜𛱁𛱊𛱁 𛰅𛱄𛰂𛱁 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛱂𛰚𛱁𛰜 𛰀𛱚𛰜. 𛰂𛱛𛰆𛱂𛰅𛰆𛱇 𛰈𛰋𛱇𛰃 𛰀𛰆𛱄𛱆𛰙𛱁 𛱜𛱜 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰔𛱄𛰆𛱁𛰚 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰃𛱂𛰚𛱁𛰜 𛰀𛱚𛰜: 𛱇𛰆𛱄͏͏͏ 𛰅𛰆𛱁𛰅𛰜𛰃𛱂 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛰅𛱁𛰃𛱂 𛰂𛱛͏͏͏𛰜 𛱛𛰅𛱛𛰅 𛰙𛱁𛰚 𛰂𛱆 𛰅𛰆𛱛𛰣𛰙𛱇𛰚 𛰙𛱁𛰙𛱛𛰅 𛰙𛱇𛰙𛰆𛱛𛰜 𛱛𛰅𛱛𛰅 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜. 𛰂𛱆 𛱇𛰆𛱄͏͏͏ 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛱜𛱜 𛱆𛰅𛰃𛱂 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰙𛱁𛰚 𛰂𛱆 𛰅𛰆𛱛𛰣𛰙𛱇𛰚. 𛱞𛰅 𛰃𛰆𛱛𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰜𛱇𛱂𛰀𛱛𛰜 𛱛𛰅𛱛𛰅 𛰙𛱁𛰚 𛰂𛱆 𛰅𛰆𛱛𛰣𛰙𛱇𛰚 𛰂𛱆 𛰅𛱁𛰅𛱜 𛰂𛱛͏͏͏𛰜 𛱆𛰂𛰜𛱛𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛱂𛰚𛱁𛰜 𛰀𛱚𛰜 𛰅𛱆𛰅𛱛𛰆𛱇 𛰅𛱄𛰂𛱁 𛱁𛱊𛱁𛰜 𛰜𛰃𛱇𛰅 𛰅𛱄𛰂𛱁 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱁𛰆𛰃𛱁𛰛 𛱇𛰆𛱇𛰀𛱇. 𛱇𛰆𛱄͏͏͏ 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰃𛱇𛰅𛱆 𛱛𛰅𛱛𛰅 𛰙𛱄𛰅𛰜𛰃 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙. 𛰂𛱆 𛱇𛰆𛱇𛰂 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱜͏͏͏𛰛 𛰅𛰆𛱁𛰜𛰅𛱁. 𛱇𛰆𛱄͏͏͏ 𛱆𛰅𛰃𛱂 𛰜𛱁𛰆𛱇𛰅𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛱜𛱜 𛰅𛱄𛰂𛱁 𛰅𛰆𛱁𛰜𛰅𛱁. 𛰅𛱄𛰂𛱆𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛰆𛱛𛰜 𛰚𛱁𛰚𛱇𛰣 𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛰜𛱁𛱊𛱁 𛰅𛱄𛰂𛱁 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛱂𛰚𛱁𛰜 𛰀𛱚𛰜 𛰅𛱆𛰅𛱛𛰆𛱇 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛰜𛰃𛱇𛰅. 𛰂𛱛͏͏͏𛰜 𛱆𛰀𛰃 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱂𛰃𛱜͏͏͏ 𛰅𛱄𛰂𛱁 𛱊𛱁𛱜 𛰂𛱆 𛰅𛰆𛱁𛰜𛰅𛱁 𛰔𛱄𛰆𛱁𛰚 𛱛𛰅𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛱜𛱜 𛰅𛱄𛰂𛱁 𛰀𛱚𛰜, 𛰅𛱄𛰂𛱆𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛱁𛱑 𛱜𛱜. 𛰂𛱆 𛰅𛱄𛰂𛱁 𛰅𛱁𛰆𛰃𛱁𛰛 𛱛𛰅𛱛𛰅. 𛰅𛱄𛰂𛱆𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛱜𛱜 𛰙𛱇𛰋𛰜𛱇 𛰂𛱛͏͏͏𛰜 𛱇𛰆𛱄͏͏͏ 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛱂𛰚𛱁𛰜 𛰅𛰆𛱂𛰃𛱜͏͏͏ 𛰅𛱄𛰂𛱁 𛱊𛱁𛱜 𛰂𛱆 𛰣𛱁𛰅𛱄 𛱇𛰆𛱄͏͏͏. 𛱇𛰆𛱄͏͏͏ 𛱁𛱑 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛱄𛰙𛰃𛱁𛰅𛰜. 𛱇𛰆𛱄͏͏͏ 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛰅𛱄𛰂𛱁 𛰅𛱁𛰀 𛰣𛱁𛰅𛱄 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜.
+
+𛱆𛰀𛰃 𛰜𛱄𛰚 𛱁𛱑 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰔𛱄 𛰅𛱄𛰂𛱁 𛱛𛰆𛰑𛱁𛰋 𛰃𛱚𛰚 𛱊𛱁𛰅𛱁 𛰜𛰃𛱄𛰚 𛱄𛱇𛰀𛱁𛰃. 𛱇𛰆𛱄͏͏͏ 𛰅𛱁𛰅𛱜 𛱛𛰅𛱛𛰅 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛱜𛰚𛱇𛰜𛱇𛰙 𛰚𛱁𛰚𛱇𛰣 𛰅𛱄𛰂𛱁 𛱄𛱇𛰀𛱁𛰃 𛰅𛰆𛱁𛰜𛰅𛱁. 𛰅𛱄𛰂𛱁 𛰙𛱁𛰅𛱛𛰅 𛰀𛱚𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱂𛰙𛱁𛰚𛱜͏͏𛰜: 𛰅𛰆𛱁𛰜𛰅𛱁 𛱜𛱜 𛱆𛰅𛰃𛱂 𛱁𛰆𛰅𛱆 𛰣𛱁𛰅𛱄 𛰂𛱆 𛰙𛱁𛰅𛱛𛰅 𛰃𛰆𛱛𛰜 𛰅𛱁𛰙𛱄𛰜𛱁𛰅. 𛱇𛰆𛱄͏͏͏ 𛰅𛰆𛱁𛰅𛰜𛰃𛱂 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛱆𛰅𛰃𛱂 𛰅𛰆𛱁𛰜𛰅𛱁 𛱇𛰆𛱇𛰀𛱇. 𛰅𛰆𛱁𛰜𛰅𛱁 𛰜𛰅𛱛𛰅𛱛𛰙 𛰃𛱄𛰙𛰃𛱄𛰙 𛰅𛱄𛰂𛱁 𛰀𛰆𛱄𛱆𛰙𛱁 𛰜𛰃𛱒𛱇𛰆 𛱛𛰅𛱛𛰅 𛰃𛱇𛰆𛱇𛰅𛱄𛰙, 𛰂𛱆 𛰅𛰆𛱁𛰜𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛰂𛱆𛰚𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛰥𛱇𛰅𛰥𛱇𛰅 𛰅𛱄𛰂𛱁 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰂𛱆 𛰙𛱛𛰜𛰙𛱛𛰜 𛰆𛱂𛰃𛱇𛰃, 𛰅𛱁𛰆𛱂𛰅𛱁𛰆𛱂, 𛰙𛱁𛰚 𛰆𛱂𛰙𛱛𛰃𛱄͏͏͏, 𛰂𛱆 𛰆𛱁𛱆𛰚𛰜. 𛰃𛱂𛱇𛱇 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰆𛱄͏͏͏𛰆𛱄͏͏͏ 𛰀𛰆𛱄𛱆𛰙𛱁 𛰜𛱇𛱂𛰂𛱛𛰃𛰆 𛰅𛱄𛰂𛱁 𛰙𛱄𛰅𛰜𛰃 𛰀𛱄𛰋𛰚 𛰂𛱆 𛱆𛰀𛰃 𛰅𛱄𛱑𛰅𛱄𛱑 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛰅𛱁𛰚𛱁𛰙𛱄𛰅𛰜𛰃 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰀𛱄𛰋𛰚.
+
+𛰅𛱁𛰚𛱁𛰙𛱄𛰅𛰜𛰃 𛱛𛰅𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛱆𛰀𛰃 𛰃𛱂𛰚𛱁𛰜 𛰙𛱁𛰚; 𛱇𛰆𛱄͏͏͏ 𛱊𛱁𛰅𛱁 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛰙𛱁𛰙𛱁 𛰂𛱆 𛰂𛱁𛰂𛱁, 𛰅𛱄𛰂𛱆𛰃 𛱆𛰀𛰃 𛰃𛱂𛰚𛱁𛰜 𛰃𛰆𛱇𛰆 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛱊𛱁𛰅𛱁 𛰙𛱆𛰃𛰆𛱂𛱆𛰃. 𛰂𛱆 𛱊𛱁𛰅𛱁 𛱁𛱊𛱁𛰜 𛰃𛱇𛰅𛱆 𛱛𛰅𛱛𛰅 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜. 𛱁𛱊𛱁𛰜 𛰜𛱇𛰅 𛰙𛱁𛰙𛱛𛰅 𛰙𛱇𛰙𛰆𛱛𛰜 𛱊𛱁𛰅𛱁 𛰙𛱁𛰙𛱁 𛰂𛱆 𛰂𛱁𛰂𛱁, 𛰂𛱆 𛰅𛱄𛰂𛱆𛰃 𛱛𛰅𛱛𛰅 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰙𛱁𛰙𛱛𛰅 𛰃𛰆𛱛𛰜 𛱊𛱁𛰅𛱁 𛰃𛱄𛰙𛰃𛱄𛰙 𛱁𛰆𛰃𛱂. 𛰅𛱁𛰚𛱁𛱞 𛰃𛱂𛰚𛱁𛰜 𛱁𛱊𛱁𛰜 𛰃𛱇𛰅𛱆 𛰅𛰆𛱁𛰜𛰅𛱁 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰂𛱆 𛰃𛱇𛰅𛱆 𛰚𛱁𛰚𛱇𛰣 𛰅𛰆𛱁𛰜𛰅𛱁 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰂𛰆𛱇. 𛰅𛱁𛰅𛱜, 𛱇𛰆𛱄͏͏͏ 𛱁𛱑 𛱊𛱁𛰅𛱁 𛰅𛰋𛱁𛱆. 𛱛𛰅𛱛𛰅 𛰃𛱂𛰚𛱁𛰜 𛰙𛱁𛰚 𛱊𛱁𛰅𛱁 𛰚𛱇𛰙 𛰙𛱇𛰚𛱇𛰜 𛰃𛰆𛱛𛰜 𛰃𛱄𛰙𛰃𛱄𛰙 𛰂𛱛͏͏͏𛰜 𛱊𛱁𛰅𛱁 𛰂𛰆𛱇 𛰅𛱄𛰂𛱁 𛱊𛱁𛰅𛱁 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛱞𛰅 𛰜𛱁𛱊𛱁 𛰅𛰆𛱁𛰜𛰅𛱁 𛰥𛱇𛰅𛰥𛱇𛰅.
+
+𛰣𛱁𛰅𛱄 𛰃𛰆𛱛𛰚 𛰃𛱂𛰚𛱁𛰜 𛰜𛱄𛰚 𛰅𛱁𛰀 𛱛𛰅𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛱛𛰆𛰑𛱁𛰋 𛰃𛱚𛰚, 𛰂𛱆 𛱞𛰅 𛰅𛱁𛰃𛱂 𛰙𛱇𛰚𛱇𛰜 𛰃𛰆𛱁𛰂 𛱊𛱁𛰅𛱁 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜. 𛰂𛱛͏͏͏𛰜 𛱊𛱁𛰅𛱁 𛰅𛰋𛱁𛱆 𛰅𛱄𛰂𛱁 𛰙𛱁𛰅𛱛𛰅 𛰀𛱚𛰜, 𛰅𛱁𛰚𛰜𛱇𛰀 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰙𛱁𛰙𛱛𛰅 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛰅𛱄𛰂𛱁 𛱊𛱁𛰅𛱁 𛰅𛱁𛰃𛱂 𛱛𛰅𛱛𛰅 𛱄𛰆𛰙𛱁𛰚 𛰂𛱆 𛱊𛱁𛰅𛱁 𛰅𛰆𛱛𛰣𛰙𛱇𛰚, 𛰂𛱆 𛱞𛰀𛰃 𛰅𛱁𛰃𛱂 𛱛𛰅𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛱜𛱜 𛰅𛱄𛰂𛱁 𛰅𛰆𛱁𛰜𛰅𛱁 𛰀𛱚𛰜 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰔𛱄𛰆𛱁𛰚 𛱛𛰅𛱛𛰅 𛰂𛱛𛰆𛱂𛰅𛰆𛱇. 𛰂𛱛͏͏͏𛰜 𛰙𛱇𛰚𛱇𛰜 𛰔𛱄𛰆𛱁𛰚 𛱛𛰅𛱛𛰅 𛰜𛱇𛱇𛰜𛱇𛰙, 𛱊𛱁𛰅𛱁 𛰅𛱄𛰂𛱆𛰃 𛰅𛰋𛱁𛱆. 𛰣𛱇 𛱊𛱁𛰅𛱁 𛰜𛰃𛱒𛱇𛰆. 𛱊𛱁𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛰜𛱁𛰀𛱁𛰆𛱇 𛱊𛱁𛰅𛱁 𛰆𛱇𛰙𛱁 𛰅𛱄𛰂𛱁 𛰜𛰅𛱂𛱆 𛰂𛱆 𛱜𛱜 𛰀𛰆𛱄𛱆𛰙𛱁 𛰆𛱂𛰆𛱁𛰚𛰊 𛰜𛰃𛱒𛱇𛰆: 𛱇𛰆𛱄͏͏͏ 𛱛𛰅𛱛𛰅 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛱆𛰅𛰃𛱂 𛱊𛱁𛰅𛱁 𛱜𛱜. 𛰂𛱆 𛱇𛰆𛱄͏͏͏ 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛱇𛰅𛱆 𛰅𛱄𛰙𛰃𛱁𛰅𛰜. 𛰅𛱄𛰂𛱆𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛰚𛱁𛰚𛱇𛰣 𛰜𛱁𛰀𛱁𛰆𛱇: 𛱛𛰅𛱛𛰅 𛰜𛰅𛱂𛱆 𛰂𛱆 𛰅𛰆𛱚𛰈𛰜 𛰣𛱁𛰅𛱄 𛰀𛰆𛱄𛱆𛰙𛱁. 𛱁𛱊𛱁𛰜 𛰀𛰆𛱄𛱆𛰙𛱁 𛱛𛰅𛱛𛰅. 𛰂𛱛͏͏͏𛰜 𛱛𛰅𛱛𛰅 𛰃𛱂𛰚𛱁𛰜 𛰙𛱁𛰚 𛰜𛰃𛱒𛱇𛰆, 𛱛𛰅𛱛𛰅 𛰅𛰆𛱚𛰈𛰜 𛰣𛱁𛰅𛱄 𛰅𛱁𛰅𛱜 𛰀𛰆𛱄𛱆𛰙𛱁 𛰙𛱁𛱞𛰣: 𛰅𛱁𛰅𛱜 𛱁𛱑 𛰙𛱁𛱞𛰣 𛰣𛱁𛰅𛱄 𛰙𛱇𛰅𛰜𛰃 𛰅𛱁𛰚𛱁𛰙𛱄𛰅𛰜𛰃. 𛰂𛱆 𛰅𛱜𛰚𛱇𛰜𛱇𛰙 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰚𛱁𛰚𛱇𛰣 𛱆𛰅𛰃𛱂 𛰅𛱁𛰅𛱜 𛰂𛱛͏͏͏𛰜 𛰃𛱛͏͏͏𛰙𛱁𛰣 𛰚𛱁𛱞𛰃𛰅𛱁 𛰃𛱄𛰙𛰃𛱄𛰙 𛰅𛰆𛱁𛰜𛰅𛱁…
+
+𛱛𛰅𛱛𛰅 𛰂𛱛𛰆𛱂𛰅𛰆𛱇 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰙𛱁𛰛 𛱛𛰆𛰑𛱁𛰋 𛰃𛱚𛰚 𛰂𛱆 𛱞𛰅 𛰅𛱁𛰚𛰜𛱇𛰀 𛱞𛰀𛰃 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰚𛱁𛰚𛱇𛰣 𛰅𛰆𛱁𛰜𛰅𛱁. 𛰂𛱆 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰣𛱁𛰅𛱄 𛰅𛱜͏͏͏𛰛: 𛱇𛰆𛱄͏͏͏ 𛱆𛰀𛰃 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰚𛱁𛰚𛱇𛰣 𛰅𛱄𛰂𛱁 𛰃𛱚𛰚. 𛰅𛱄𛰂𛱁 𛰅𛱁𛰚𛱁𛱞 𛰀𛱚𛰜 𛱛𛰅𛱛𛰅 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰣𛱁𛰅𛱄 𛱇𛰆𛱄͏͏͏: 𛱁𛱊𛱁𛰜 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰂𛱆 𛰃𛱂𛰚𛱁𛰜, 𛰃𛰆𛱇𛰆, 𛰆𛱇𛰊𛰆𛱇, 𛰆𛱇𛰅𛰋𛱇𛰙, 𛰃𛰆𛱇𛰆. 𛱄𛰆𛰙𛱁𛰚 𛰅𛰋𛱁𛰚𛱄𛰚, 𛰃𛱂𛱇𛱇 𛰅𛱄𛰂𛱁 𛰃𛱚𛰚, 𛱊𛱁𛰅𛱁 𛱜𛱜 𛰂𛱛͏͏͏𛰜 𛱛𛰅𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛱁𛰂𛰛𛱜𛰆𛱂 𛱛𛰅𛱛𛰅 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜. 𛰅𛰆𛱛͏͏͏𛰚𛱁𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛱇𛰅𛱆 𛰂𛱁𛰃𛰆𛱁𛰣 𛰆𛱂𛰂𛱆𛰆𛱇𛰃𛱁𛰜 𛰅𛱄𛰂𛱁 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙. 𛱊𛱁𛰅𛱁 𛰙𛱁𛰜𛱁𛰣𛱇 𛱜𛱜 𛱛𛰅𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰂𛱆 𛰅𛰆𛱁𛰜𛰅𛱁 𛰥𛱇𛰅𛰥𛱇𛰅. 𛰂𛱆 𛱆𛰀𛰃 𛰙𛱁𛰚, 𛱊𛱁𛰅𛱁 𛰚𛱇𛰙 𛰚𛱇𛰑 𛰂𛱆 𛱊𛱁𛰅𛱁 𛰃𛰆𛱛𛰜 𛰚𛱁𛰚𛱇𛰣 𛰂𛱆𛰂𛱁, 𛱊𛱁𛰅𛱁 𛱜𛱜 “𛰃𛰆𛱛𛰜 𛱛𛰅𛱛𛰅 𛰙𛱁𛰜𛱁𛰣𛱇 𛰙𛱁𛰚 𛰂𛱆 𛰅𛰆𛱛𛰣𛰙𛱇𛰚 𛰃𛰆𛱁𛰂 𛱛𛰅𛱛𛰅 𛰆𛱂𛰂𛱆𛰆𛱇𛰃𛱁𛰜”. 𛰂𛱆 𛰚𛱁𛱞𛰃𛰅𛱁 𛱛𛰅𛱛𛰅 𛰙𛱁𛰚 𛰂𛱆 𛰅𛰆𛱛𛰣𛰙𛱇𛰚 𛰅𛱜𛰚𛱇𛰜𛱇𛰙 𛰙𛱁𛰙𛱛𛰅 𛰙𛱇𛰙𛰆𛱛𛰜 𛱇𛰆𛱇𛰂 𛱁𛱑 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜. 𛰂𛱆 𛱇𛰆𛱄͏͏͏ 𛰅𛰆𛱁𛰅𛰜𛰃𛱂 𛰃𛱇𛰅𛱆 𛰙𛱁𛰙𛱛𛰅 𛰅𛱄𛰋𛰃 𛰀𛱚𛰜 𛰅𛰆𛱁𛰜𛰅𛱁. 𛱞𛰀𛰃 𛰇𛱁𛰋𛰅𛱆𛰂 𛱊𛱁𛰅𛱁 𛰃𛱂𛰚𛱁𛰜 𛰙𛱁𛰚 𛱁𛰃𛱁𛰆 𛱜𛱜 𛰂𛱛͏͏͏𛰜 𛰆𛱁𛰜𛰃 𛰂𛱛𛰆𛱂𛰅𛰆𛱇 𛱊𛱁𛰅𛱁 𛰚𛱁𛰚𛱇𛰣 𛰅𛱁𛰚𛱁𛱞 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛰅𛰆𛱂𛰀𛱁𛰚𛱇 𛰅𛱄𛰂𛱁 𛰙𛱁𛰜𛱁𛰣𛱇 𛰙𛱁𛰚 𛱊𛱁𛰅𛱁 𛰀𛱚𛰜, 𛰅𛱆𛰅𛱛𛰆𛱇 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰜𛰃𛱇𛰅. 𛰃𛰆𛱂𛱜 𛱛𛰅𛱛𛰅 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱂𛰃𛱜͏͏͏ 𛰋𛱚𛰚 𛱛𛰅𛱛𛰅 𛰀𛱚𛰜. 𛰙𛱄𛰅𛰜𛰃 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰅𛱆𛰙𛰃𛱂 𛰅𛱄𛰂𛱁 𛰙𛱄𛰅𛰜𛰃 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜, 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛰆𛱂𛰃𛱜͏͏͏ 𛰋𛱚𛰚. 𛰅𛱁𛰅𛱜 𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛰙𛱁𛱞𛰣 𛰃𛱂𛰙𛱁𛰚𛱜͏͏𛰜. 𛱇𛰆𛱄͏͏͏ 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛱄𛰙𛰃𛱁𛰅𛰜 𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛰚𛱁𛱞𛰃𛰅𛱁 𛱛𛰅𛱛𛰅 𛰃𛱂𛰚𛱁𛰜 𛰙𛱁𛰚. 𛰈𛰋𛱇𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱜͏͏͏𛰛 𛱛𛰅𛱛𛰅 𛱄𛰆𛰙𛱁𛰚 𛰂𛱆 𛰅𛱄𛰂𛱆𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛱇𛰅𛱆 𛰙𛱁𛰙𛱛𛰅 𛰅𛱄𛰋𛰃 𛰀𛱚𛰜 𛱊𛱁𛰅𛱁 𛰂𛱛͏͏͏𛰜 𛱊𛱁𛰅𛱁 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛰅𛰆𛱂𛰀𛱁𛰚𛱇 𛰅𛱄𛰂𛱁 𛱊𛱁𛰅𛱁 𛰀𛱚𛰜 𛰂𛱆 𛰜𛱁𛱊𛱁 𛰅𛱄𛰂𛱁 𛱊𛱁𛰅𛱁 𛰅𛱁𛰆𛰃𛱁𛰛 𛱇𛰆𛱇𛰀𛱇.
+
+𛰅𛱁𛰅𛱜, 𛰅𛱁𛰆𛰃𛱁𛰛 𛱛𛰅𛱛𛰅 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰣𛱁𛰅𛱄 𛰜𛱁𛰆𛱇𛰅𛰜, 𛰂𛱆 𛰅𛰆𛱂𛰃𛱜͏͏͏ 𛰜𛰆𛱇𛰂. 𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰊𛱆𛰃𛱄͏͏͏𛰂 𛰃𛱂𛰚𛱁𛰜 𛰜𛱄𛰚: 𛰀𛱜! 𛱞𛰀𛰃 𛰅𛱁𛰚𛱁𛱞 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛰅𛱄𛰂𛱁 𛰅𛰆𛱁𛰜𛰅𛱁 𛰀𛱚𛰜! 𛱁𛱊𛱁𛰜 𛰂𛱆 𛰃𛱂𛰚𛱁𛰜, 𛰃𛰆𛱇𛰆, 𛰆𛱇𛰊𛰆𛱇, 𛰆𛱇𛰅𛰋𛱇𛰙, 𛰂𛱆 𛰃𛰅𛱄𛰂. 𛱇𛰆𛱄͏͏͏ 𛱆𛰀𛰃 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰣𛱁𛰅𛱄 𛱇𛰆𛱄͏͏͏. 𛰂𛱆 𛱁𛱊𛱁𛰜 𛰊𛰋𛱇𛰜 𛱛𛰅𛱛𛰅 𛰂𛱛𛰂𛱛͏͏͏𛰜, 𛰂𛱆 𛱁𛱊𛱁𛰜 𛰃𛰆𛱛𛰜 𛰃𛱄𛰙𛰃𛱄𛰙 𛰅𛰆𛱁𛰜𛰅𛱁. 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛱁𛱑 𛱜𛱜 𛰅𛱁𛰚𛱁𛰙𛱄𛰅𛰜𛰃 𛰅𛱁𛰃𛱂 𛱛𛰅𛱛𛰅, 𛰂𛱆 𛰃𛰆𛱁𛰂 𛰜𛰅𛱛𛰅𛱛𛰙 𛰃𛱄𛰙𛰃𛱄𛰙. 𛱄𛰆𛰙𛱁𛰚 𛰅𛰋𛱁𛰚𛱄𛰚 𛱞𛰀𛰃 𛱊𛱁𛰅𛱁 𛱜𛱜 𛰂𛱛͏͏͏𛰜 𛱛𛰅𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛱁𛰂𛰛𛱜𛰆𛱂 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜. 𛱞𛰅 𛰅𛱁𛰚𛰜𛱇𛰀 𛱁𛰚𛰅𛱁𛰃𛱇 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰅𛱆𛰆𛱂𛰂𛱂𛱆 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰙𛱁𛰜𛱁𛰣𛱇 𛰙𛱁𛰚 𛱊𛱁𛰅𛱁 𛰀𛱚𛰜. 𛰂𛱆 𛰅𛱁𛰚𛱁𛱞 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛱆𛰀𛰃 𛰃𛱄𛰙𛰃𛱄𛰙 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅: 𛱇𛰆𛱄͏͏͏ 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰃𛱇𛰅𛱆 𛰙𛱁𛰅𛰙𛱁𛰅 𛱛𛰅𛱛𛰅 𛰃𛱂𛰚𛱁𛰜 𛰜𛱄𛰚, 𛰂𛱆 𛱁𛱊𛱁𛰜 𛰀𛰆𛱄𛱆𛰙𛱁 𛱛𛰅𛱛𛰅. 𛰙𛱄𛰅𛰜𛰃 𛰜𛱄𛰚 𛱛𛰅𛱛𛰅 𛰊𛰋𛱇𛰜 𛰂𛱆 𛰆𛱇𛰜𛱇 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛱇𛰆𛱄͏͏͏ 𛰃𛱇𛰅𛱆 𛰙𛱁𛰅𛰙𛱁𛰅: 𛰅𛱄𛰂𛱆𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱁𛰆𛰃𛱁𛰛 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛱞𛰅 𛰜𛱁𛱊𛱁 𛰅𛱄𛰂𛱁 𛰂𛱁𛱊𛱁 𛰂𛱆 𛰅𛱄𛰂𛱁 𛰜𛱄𛰚.
+
+𛰅𛱄𛰂𛱆𛰃 𛰅𛱁𛰚𛱁𛱞 𛱆𛰀𛰃 𛰜𛱄𛰚𛰈𛱇 𛰂𛱆 𛱛𛰆𛰑𛱁𛰋 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰚𛱁𛰚𛱇𛰣 𛱇𛰆𛱄͏͏͏ 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛰆𛱂𛱆𛰃 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰙𛱁𛰜𛱁𛰣𛱇 𛰙𛱁𛰚 𛱊𛱁𛰅𛱁 𛰀𛱚𛰜 𛰅𛱆𛰅𛱛𛰆𛱇 𛰅𛱄𛰂𛱁 𛰜𛰃𛱇𛰅. 𛰃𛱂𛰚𛱁𛰜 𛰚𛱇𛰑 𛱜𛱜 𛰂𛱛͏͏͏𛰜, 𛰅𛱄𛰂𛱆𛰃 𛱛𛰅𛱛𛰅 𛰂𛱛𛰆𛱂𛰅𛰆𛱇 𛰅𛱁𛰀 𛰣𛱁𛰅𛱄 𛱇𛰆𛱄͏͏͏ 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜, 𛱇𛰆𛱄͏͏͏ 𛰅𛰆𛱁𛰅𛰜𛰃𛱂 𛰚𛱁𛰚𛱇𛰣 𛱛𛰅𛱛𛰅 𛱄𛰆𛰙𛱁𛰚 𛰂𛱆 𛱊𛱁𛰅𛱁 𛰅𛰆𛱛𛰣𛰙𛱇𛰚. 𛰅𛱄𛰂𛱆𛰃 𛱆𛰀𛰃 𛱞𛰀𛰃 𛰜𛱄𛰚𛰈𛱇 𛰂𛱆 𛰃𛱂𛱇𛱇 𛰅𛱄𛰂𛱁 𛰃𛱚𛰚 𛰙𛱁𛰙𛱛𛰅 𛰃𛱄𛰙𛰃𛱄𛰙 𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱂𛰃𛱜͏͏͏ 𛱜𛱜 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰙𛱄𛰅𛰜𛰃 𛰙𛱁𛰜𛱁𛰣𛱇 𛰃𛱇𛰆𛱇𛰅𛱄𛰙. 𛱊𛱁𛰅𛱁 𛰅𛰆𛱂𛰃𛱜͏͏͏ 𛰅𛱁𛰚𛱁𛰙𛱄𛰅𛰜𛰃 𛰛𛱁𛰚𛰊 𛰂𛱆 𛰑𛱛𛰆 𛰂𛱛͏͏͏𛰜 𛱞𛰀𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛰚𛱁𛰚𛱇𛰣. 𛰛𛱁𛰚𛰊 𛰙𛱁𛰙𛱛𛰅 𛰣𛱇𛰅𛰙𛱇𛰚 𛱆𛰅𛰃𛱁𛰜 𛰂𛱆 𛰑𛱛𛰆 𛱊𛱁𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛰅𛱑𛰃 𛰜𛰃𛱄𛰚. 𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱁𛰜𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛰀𛱁𛰆𛱁𛰅 𛱛𛰅𛱛𛰅 𛰀𛱚𛰜 𛱊𛱁𛰅𛱁 𛰆𛱂𛰂𛱄𛰋𛰃, 𛰅𛱄𛰂𛱆𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛰚𛱁𛰚𛱇𛰣 𛱛𛰅𛱛𛰅: 𛰙𛱄𛰅𛰜𛰃 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛰆𛱁𛰜𛰅𛱁 𛰇𛱄𛰚 𛰙𛱆𛰃𛰆𛱂𛱆𛰃 𛰅𛱄𛰂𛱁 𛱇𛰆𛱇𛰀𛱇, 𛰂𛱆 𛰅𛱄𛰂𛱁 𛰂𛱛𛰆𛱂𛰅𛰆𛱇 𛰃𛱂𛰚𛱁𛰜 𛱁𛱑 𛰇𛱆𛰃𛱇𛰆 𛰅𛱛𛰆𛱇 𛰋𛱚𛰚.
+
+𛱊𛱁𛱜 𛰃𛱂𛱇𛱇 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛱄𛰂𛱁 𛱛𛰆𛰑𛱁𛰋 𛰃𛱚𛰚 𛱁𛱑 𛱜𛱜 𛰅𛱁𛰚𛱁𛰙𛱄𛰅𛰜𛰃. 𛰜𛱁𛰑, 𛱛𛰅𛱛𛰅 𛰙𛱁𛰚 𛱊𛱁𛰅𛱁 𛰃𛰆𛱛𛰜 𛰚𛱁𛰚𛱇𛰣 𛰙𛱇𛰙𛰆𛱛𛰜 𛰃𛱇𛰆𛱇𛰅𛱛𛰙, 𛱁𛱑 𛱜𛱜 𛰅𛱁𛰚𛱁𛰙𛱄𛰅𛰜𛰃 𛰚𛱇𛰑, 𛱛𛰅𛱛𛰅 𛰙𛱁𛰚 𛱊𛱁𛰅𛱁 𛰃𛰆𛱛𛰜 𛰚𛱁𛰚𛱇𛰣 𛰂𛱆𛰂𛱁; 𛰅𛱁𛰚𛱁𛱞 𛰅𛰆𛱁𛰜𛰅𛱁 𛱁𛱑 𛱁𛰜𛰅 𛱄𛰆𛰙𛱁𛰚 𛰅𛰋𛱁𛰚𛱄𛰚 𛰂𛱆 𛰛𛱁𛰚𛰊 𛰂𛱆 𛰑𛱛𛰆. 𛱞𛰀𛰃 𛰅𛰆𛱁𛰜𛰅𛱁 𛱁𛱑 𛱁𛰜𛰅 𛰃𛱂𛰚𛱁𛰜 𛱁𛰃𛱁𛰆, 𛰇𛱁𛰋𛰅𛱆𛰂 𛱊𛱁𛰅𛱁 𛰃𛱂𛰚𛱁𛰜 𛰙𛱁𛰚, 𛰂𛱆 𛰂𛱁𛰃𛰆𛱁𛰣 𛰅𛱁𛰚𛰈𛱇 𛰅𛱄𛰂𛱁 𛱊𛱁𛰅𛱁. 𛰅𛰆𛱁𛰜𛰅𛱁 𛱁𛱑 𛱜𛱜 𛰅𛱁𛰃𛱂 𛱛𛰅𛱛𛰅 𛰙𛱁𛰜𛱁𛰣𛱇 𛱄𛰆𛰙𛱁𛰚 𛰂𛱆 𛱊𛱁𛰅𛱁 𛰅𛰆𛱛𛰣𛰙𛱇𛰚, 𛰅𛱁𛰃𛱂 𛱛𛰅𛱛𛰅 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙, 𛰅𛱁𛰃𛱂 𛱛𛰅𛱛𛰅 𛰃𛱂𛰚𛱁𛰜 𛰙𛱇𛰚𛱇𛰜 𛰂𛱆 𛱊𛱁𛰅𛱁 𛰃𛰆𛱇𛰆 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜, 𛰅𛱁𛰃𛱂 𛰙𛱇𛰚𛱇𛰜 𛱊𛱁𛰅𛱁 𛰜𛰃𛱒𛱇𛰆, 𛰅𛱁𛰃𛱂 𛰜𛰅𛱂𛱆 𛰂𛱛͏͏͏𛰜 𛱊𛱁𛰅𛱁 𛰜𛰃𛱒𛱇𛰆, 𛱆𛰅𛰃𛱂 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜 𛰙𛱁𛰙𛱛𛰅 𛱛𛰅𛱛𛰅 𛰂𛱛𛰆𛱂𛰅𛰆𛱇 𛰅𛱁𛰀 𛰀𛰆𛱄𛱆𛰙𛱁 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰙𛱁𛰛 𛱛𛰆𛰑𛱁𛰋 𛰃𛱚𛰚, 𛰂𛱆 𛱆𛰅𛰃𛱂 𛰅𛰆𛱁𛰜𛰅𛱁 𛰃𛰆𛱁𛰂 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰃𛱂𛰚𛱁𛰜 𛰀𛱚𛰜 𛰅𛱆𛰅𛱛𛰆𛱇 𛰅𛱄𛰂𛱁 𛰜𛰃𛱇𛰅 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰅𛱁𛰆𛰃𛱁𛰛 𛱇𛰆𛱇𛰀𛱇.
+
+𛰅𛱄𛰂𛱆𛰃 𛱛𛰅𛱛𛰅, 𛰃𛱂𛱇𛱇 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰙𛱁𛰙𛱛𛰅 𛱁𛱊𛱁𛰜 𛰀𛰆𛱄𛱆𛰙𛱁 𛰆𛱄͏͏͏: 𛰅𛱁𛰚𛱁𛱞 𛰅𛱄𛰂𛱁 𛰀𛱁𛰑𛱇𛰊 𛰙𛱁𛰅𛱛𛰅 𛰀𛱚𛰜 𛰂𛱆 𛱛𛰅𛱛𛰅 𛰃𛱇𛰆𛱇𛰅𛱄𛰙 𛰅𛰆𛱁𛰜𛰅𛱁 𛰅𛱛𛰆𛱇 𛰅𛱄𛰂𛱁 𛰚𛱇𛰋 𛱇𛰆𛱇𛰀𛱇 𛰅𛱜𛰚𛱇𛰜𛱇𛰙 𛱁𛱑 𛱜𛱜 𛰅𛱄𛰂𛱁 𛱛𛰅𛱛𛰅 𛰆𛱄͏͏͏. 𛰅𛰆𛱁𛰜𛰅𛱁 𛰙𛱁𛰙𛱛𛰅 𛱛𛰅𛱛𛰅 𛰆𛱄͏͏͏: 𛱞𛰅 𛰃𛰆𛱛𛰜 𛰂𛱛͏͏͏𛰜 𛰅𛰆𛱁𛰅𛰜𛰃𛱂 𛰙𛱁𛰙𛱛𛰅 𛰙𛱇𛰙𛰆𛱛𛰜 𛰂𛱛͏͏͏𛰜𛰂𛱛͏͏͏𛰜.
+
+𛰅𛱄𛰂𛱆𛰃 𛰅𛱁𛰅𛱜 𛱛𛰅𛱛𛰅 𛰜𛱇𛱇𛰜𛱇𛰙
diff --git a/src/OT/Layout/GDEF/GDEF.hh b/src/OT/Layout/GDEF/GDEF.hh
index d995ba0..4f85d3c 100644
--- a/src/OT/Layout/GDEF/GDEF.hh
+++ b/src/OT/Layout/GDEF/GDEF.hh
@@ -439,6 +439,16 @@
bool covers (unsigned int set_index, hb_codepoint_t glyph_id) const
{ return (this+coverage[set_index]).get_coverage (glyph_id) != NOT_COVERED; }
+ template <typename set_t>
+ void collect_coverage (hb_vector_t<set_t> &sets) const
+ {
+ for (const auto &offset : coverage)
+ {
+ const auto &cov = this+offset;
+ cov.collect_coverage (sets.push ());
+ }
+ }
+
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
@@ -492,6 +502,15 @@
}
}
+ template <typename set_t>
+ void collect_coverage (hb_vector_t<set_t> &sets) const
+ {
+ switch (u.format) {
+ case 1: u.format1.collect_coverage (sets); return;
+ default:return;
+ }
+ }
+
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
@@ -856,6 +875,10 @@
hb_blob_destroy (table.get_blob ());
table = hb_blob_get_empty ();
}
+
+#ifndef HB_NO_GDEF_CACHE
+ table->get_mark_glyph_sets ().collect_coverage (mark_glyph_set_digests);
+#endif
}
~accelerator_t () { table.destroy (); }
@@ -879,8 +902,18 @@
}
+ bool mark_set_covers (unsigned int set_index, hb_codepoint_t glyph_id) const
+ {
+ return
+#ifndef HB_NO_GDEF_CACHE
+ mark_glyph_set_digests[set_index].may_have (glyph_id) &&
+#endif
+ table->mark_set_covers (set_index, glyph_id);
+ }
+
hb_blob_ptr_t<GDEF> table;
#ifndef HB_NO_GDEF_CACHE
+ hb_vector_t<hb_set_digest_t> mark_glyph_set_digests;
mutable hb_cache_t<21, 3, 8> glyph_props_cache;
#endif
};
diff --git a/src/OT/Layout/GPOS/CursivePosFormat1.hh b/src/OT/Layout/GPOS/CursivePosFormat1.hh
index a459124..675bb83 100644
--- a/src/OT/Layout/GPOS/CursivePosFormat1.hh
+++ b/src/OT/Layout/GPOS/CursivePosFormat1.hh
@@ -200,8 +200,8 @@
* Arabic. */
unsigned int child = i;
unsigned int parent = j;
- hb_position_t x_offset = entry_x - exit_x;
- hb_position_t y_offset = entry_y - exit_y;
+ hb_position_t x_offset = roundf (entry_x - exit_x);
+ hb_position_t y_offset = roundf (entry_y - exit_y);
if (!(c->lookup_props & LookupFlag::RightToLeft))
{
unsigned int k = child;
diff --git a/src/OT/Layout/GPOS/PairValueRecord.hh b/src/OT/Layout/GPOS/PairValueRecord.hh
index c99a386..72bf0e9 100644
--- a/src/OT/Layout/GPOS/PairValueRecord.hh
+++ b/src/OT/Layout/GPOS/PairValueRecord.hh
@@ -23,7 +23,6 @@
* followed by for second glyph */
public:
DEFINE_SIZE_ARRAY (Types::HBGlyphID::static_size, values);
- DEFINE_SIZE_MAX (Types::HBGlyphID::static_size + 2 * Value::static_size * 8 * sizeof (ValueFormat));
int cmp (hb_codepoint_t k) const
{ return secondGlyph.cmp (k); }
diff --git a/src/OT/Layout/GSUB/Ligature.hh b/src/OT/Layout/GSUB/Ligature.hh
index db3fc55..402ed12 100644
--- a/src/OT/Layout/GSUB/Ligature.hh
+++ b/src/OT/Layout/GSUB/Ligature.hh
@@ -19,7 +19,6 @@
* in writing direction */
public:
DEFINE_SIZE_ARRAY (Types::size + 2, component);
- DEFINE_SIZE_MAX (65536 * Types::HBGlyphID::static_size);
bool sanitize (hb_sanitize_context_t *c) const
{
diff --git a/src/hb-aat-layout-trak-table.hh b/src/hb-aat-layout-trak-table.hh
index 2ba9355..c72c086 100644
--- a/src/hb-aat-layout-trak-table.hh
+++ b/src/hb-aat-layout-trak-table.hh
@@ -111,13 +111,13 @@
break;
}
}
- if (!trackTableEntry) return 0.;
+ if (!trackTableEntry) return 0;
/*
* Choose size.
*/
unsigned int sizes = nSizes;
- if (!sizes) return 0.;
+ if (!sizes) return 0;
if (sizes == 1) return trackTableEntry->get_value (base, 0, sizes);
hb_array_t<const F16DOT16> size_table ((base+sizeTable).arrayZ, sizes);
diff --git a/src/hb-bit-set.hh b/src/hb-bit-set.hh
index 17eb065..9e60cb9 100644
--- a/src/hb-bit-set.hh
+++ b/src/hb-bit-set.hh
@@ -30,7 +30,6 @@
#include "hb.hh"
#include "hb-bit-page.hh"
-#include "hb-machinery.hh"
struct hb_bit_set_t
@@ -183,6 +182,16 @@
return true;
}
+ /* Duplicated here from hb-machinery.hh to avoid including it. */
+ template<typename Type>
+ static inline const Type& StructAtOffsetUnaligned(const void *P, unsigned int offset)
+ {
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wcast-align"
+ return * reinterpret_cast<const Type*> ((const char *) P + offset);
+#pragma GCC diagnostic pop
+ }
+
template <typename T>
void set_array (bool v, const T *array, unsigned int count, unsigned int stride=sizeof(T))
{
diff --git a/src/hb-machinery.hh b/src/hb-machinery.hh
index cde1e99..ecff94f 100644
--- a/src/hb-machinery.hh
+++ b/src/hb-machinery.hh
@@ -131,10 +131,6 @@
unsigned int get_size () const { return (size - (array).min_size + (array).get_size ()); } \
DEFINE_SIZE_ARRAY(size, array)
-#define DEFINE_SIZE_MAX(size) \
- DEFINE_INSTANCE_ASSERTION (sizeof (*this) <= (size)) \
- static constexpr unsigned max_size = (size)
-
/*
diff --git a/src/hb-map.hh b/src/hb-map.hh
index e8abeec..42604ef 100644
--- a/src/hb-map.hh
+++ b/src/hb-map.hh
@@ -78,6 +78,10 @@
hash (0),
value () {}
+ // Needed for https://github.com/harfbuzz/harfbuzz/issues/4138
+ K& get_key () { return key; }
+ V& get_value () { return value; }
+
bool is_used () const { return is_used_; }
void set_used (bool is_used) { is_used_ = is_used; }
void set_real (bool is_real) { is_real_ = is_real; }
@@ -405,23 +409,21 @@
auto keys_ref () const HB_AUTO_RETURN
(
+ iter_items ()
- | hb_map (&item_t::key)
+ | hb_map (&item_t::get_key)
)
auto keys () const HB_AUTO_RETURN
(
- + iter_items ()
- | hb_map (&item_t::key)
+ + keys_ref ()
| hb_map (hb_ridentity)
)
auto values_ref () const HB_AUTO_RETURN
(
+ iter_items ()
- | hb_map (&item_t::value)
+ | hb_map (&item_t::get_value)
)
auto values () const HB_AUTO_RETURN
(
- + iter_items ()
- | hb_map (&item_t::value)
+ + values_ref ()
| hb_map (hb_ridentity)
)
diff --git a/src/hb-null.hh b/src/hb-null.hh
index 2982516..6796906 100644
--- a/src/hb-null.hh
+++ b/src/hb-null.hh
@@ -37,7 +37,7 @@
/* Global nul-content Null pool. Enlarge as necessary. */
-#define HB_NULL_POOL_SIZE 520
+#define HB_NULL_POOL_SIZE 640
template <typename T, typename>
struct _hb_has_min_size : hb_false_type {};
@@ -49,15 +49,6 @@
#define hb_has_min_size(T) hb_has_min_size<T>::value
template <typename T, typename>
-struct _hb_has_max_size : hb_false_type {};
-template <typename T>
-struct _hb_has_max_size<T, hb_void_t<decltype (T::max_size)>>
- : hb_true_type {};
-template <typename T>
-using hb_has_max_size = _hb_has_max_size<T, void>;
-#define hb_has_max_size(T) hb_has_max_size<T>::value
-
-template <typename T, typename>
struct _hb_has_null_size : hb_false_type {};
template <typename T>
struct _hb_has_null_size<T, hb_void_t<decltype (T::null_size)>>
diff --git a/src/hb-open-type.hh b/src/hb-open-type.hh
index 6d464a3..d3fdd1c 100644
--- a/src/hb-open-type.hh
+++ b/src/hb-open-type.hh
@@ -718,30 +718,6 @@
return_trace (out);
}
- /* Special-case ArrayOf Offset16To structs with a maximum size. */
- template <typename T = Type,
- typename Base = void,
- hb_enable_if (hb_has_max_size (typename T::target_t) &&
- sizeof (T) == 2)>
- HB_ALWAYS_INLINE
- bool sanitize (hb_sanitize_context_t *c, const Base *base) const
- {
- TRACE_SANITIZE (this);
-
- if (unlikely (!sanitize_shallow (c))) return_trace (false);
-
- unsigned max_len = 65536 + Type::target_t::max_size;
-
- if (unlikely (c->check_range_fast (base, max_len)))
- return_trace (true);
-
- unsigned int count = len;
- for (unsigned int i = 0; i < count; i++)
- if (unlikely (!c->dispatch (arrayZ[i], base)))
- return_trace (false);
- return_trace (true);
- }
-
template <typename ...Ts>
HB_ALWAYS_INLINE
bool sanitize (hb_sanitize_context_t *c, Ts&&... ds) const
diff --git a/src/hb-ot-layout-gsubgpos.hh b/src/hb-ot-layout-gsubgpos.hh
index 95e8fb8..136e088 100644
--- a/src/hb-ot-layout-gsubgpos.hh
+++ b/src/hb-ot-layout-gsubgpos.hh
@@ -818,7 +818,7 @@
* match_props has the set index.
*/
if (match_props & LookupFlag::UseMarkFilteringSet)
- return gdef.mark_set_covers (match_props >> 16, glyph);
+ return gdef_accel.mark_set_covers (match_props >> 16, glyph);
/* The second byte of match_props has the meaning
* "ignore marks of attachment type different than
@@ -2087,7 +2087,6 @@
* design order */
public:
DEFINE_SIZE_ARRAY (4, inputZ);
- DEFINE_SIZE_MAX (65536 * (Types::HBUINT::static_size + LookupRecord::static_size));
};
template <typename Types>
@@ -2170,18 +2169,18 @@
;
}
- /* This version is optimized for speed by matching the first component
- * of the rule here, instead of calling into the matching code.
+ /* This version is optimized for speed by matching the first & second
+ * components of the rule here, instead of calling into the matching code.
*
* Replicated from LigatureSet::apply(). */
hb_ot_apply_context_t::skipping_iterator_t &skippy_iter = c->iter_input;
- skippy_iter.reset (c->buffer->idx, 1);
+ skippy_iter.reset (c->buffer->idx, 2);
skippy_iter.set_match_func (match_always, nullptr);
skippy_iter.set_glyph_data ((HBUINT16 *) nullptr);
- unsigned unsafe_to;
- hb_glyph_info_t *first = nullptr;
- bool matched = skippy_iter.next (&unsafe_to);
+ unsigned unsafe_to = (unsigned) -1, unsafe_to1 = 0, unsafe_to2 = 0;
+ hb_glyph_info_t *first = nullptr, *second = nullptr;
+ bool matched = skippy_iter.next ();
if (likely (matched))
{
first = &c->buffer->info[skippy_iter.idx];
@@ -2207,9 +2206,15 @@
)
;
}
+ matched = skippy_iter.next ();
+ if (likely (matched && !skippy_iter.may_skip (c->buffer->info[skippy_iter.idx])))
+ {
+ second = &c->buffer->info[skippy_iter.idx];
+ unsafe_to2 = skippy_iter.idx + 1;
+ }
- bool unsafe_to_concat = false;
-
+ auto match_input = lookup_context.funcs.match;
+ auto *input_data = lookup_context.match_data;
for (unsigned int i = 0; i < num_rules; i++)
{
const auto &r = this+rule.arrayZ[i];
@@ -2217,20 +2222,32 @@
const auto &input = r.inputZ;
if (r.inputCount <= 1 ||
- (!lookup_context.funcs.match ||
- lookup_context.funcs.match (*first, input.arrayZ[0], lookup_context.match_data)))
+ (!match_input ||
+ match_input (*first, input.arrayZ[0], input_data)))
{
- if (r.apply (c, lookup_context))
+ if (!second ||
+ (r.inputCount <= 2 ||
+ (!match_input ||
+ match_input (*second, input.arrayZ[1], input_data)))
+ )
{
- if (unsafe_to_concat)
- c->buffer->unsafe_to_concat (c->buffer->idx, unsafe_to);
- return_trace (true);
+ if (r.apply (c, lookup_context))
+ {
+ if (unsafe_to != (unsigned) -1)
+ c->buffer->unsafe_to_concat (c->buffer->idx, unsafe_to);
+ return_trace (true);
+ }
}
+ else
+ unsafe_to = unsafe_to2;
}
else
- unsafe_to_concat = true;
+ {
+ if (unsafe_to == (unsigned) -1)
+ unsafe_to = unsafe_to1;
+ }
}
- if (likely (unsafe_to_concat))
+ if (likely (unsafe_to != (unsigned) -1))
c->buffer->unsafe_to_concat (c->buffer->idx, unsafe_to);
return_trace (false);
@@ -3244,7 +3261,6 @@
* design order) */
public:
DEFINE_SIZE_MIN (8);
- DEFINE_SIZE_MAX (65536 * (3 * Types::HBUINT::static_size + LookupRecord::static_size));
};
template <typename Types>
@@ -3324,22 +3340,22 @@
;
}
- /* This version is optimized for speed by matching the first component
- * of the rule here, instead of calling into the matching code.
+ /* This version is optimized for speed by matching the first & second
+ * components of the rule here, instead of calling into the matching code.
*
* Replicated from LigatureSet::apply(). */
hb_ot_apply_context_t::skipping_iterator_t &skippy_iter = c->iter_input;
- skippy_iter.reset (c->buffer->idx, 1);
+ skippy_iter.reset (c->buffer->idx, 2);
skippy_iter.set_match_func (match_always, nullptr);
skippy_iter.set_glyph_data ((HBUINT16 *) nullptr);
- unsigned unsafe_to;
- hb_glyph_info_t *first = nullptr;
- bool matched = skippy_iter.next (&unsafe_to);
+ unsigned unsafe_to = (unsigned) -1, unsafe_to1 = 0, unsafe_to2 = 0;
+ hb_glyph_info_t *first = nullptr, *second = nullptr;
+ bool matched = skippy_iter.next ();
if (likely (matched))
{
first = &c->buffer->info[skippy_iter.idx];
- unsafe_to = skippy_iter.idx + 1;
+ unsafe_to1 = skippy_iter.idx + 1;
if (skippy_iter.may_skip (c->buffer->info[skippy_iter.idx]))
{
@@ -3355,15 +3371,28 @@
return_trace (
+ hb_iter (rule)
| hb_map (hb_add (this))
- | hb_filter ([&] (const ChainRule &_) { return _.inputX.lenP1 <= 1 && _.lookaheadX.len == 0; })
+ | hb_filter ([&] (const ChainRule &_)
+ {
+ const auto &input = StructAfter<decltype (_.inputX)> (_.backtrack);
+ const auto &lookahead = StructAfter<decltype (_.lookaheadX)> (input);
+ return input.lenP1 <= 1 && lookahead.len == 0;
+ })
| hb_map ([&] (const ChainRule &_) { return _.apply (c, lookup_context); })
| hb_any
)
;
}
+ matched = skippy_iter.next ();
+ if (likely (matched && !skippy_iter.may_skip (c->buffer->info[skippy_iter.idx])))
+ {
+ second = &c->buffer->info[skippy_iter.idx];
+ unsafe_to2 = skippy_iter.idx + 1;
+ }
- bool unsafe_to_concat = false;
-
+ auto match_input = lookup_context.funcs.match[1];
+ auto match_lookahead = lookup_context.funcs.match[2];
+ auto *input_data = lookup_context.match_data[1];
+ auto *lookahead_data = lookup_context.match_data[2];
for (unsigned int i = 0; i < num_rules; i++)
{
const auto &r = this+rule.arrayZ[i];
@@ -3371,24 +3400,39 @@
const auto &input = StructAfter<decltype (r.inputX)> (r.backtrack);
const auto &lookahead = StructAfter<decltype (r.lookaheadX)> (input);
- if (input.lenP1 > 1 ?
- (!lookup_context.funcs.match[1] ||
- lookup_context.funcs.match[1] (*first, input.arrayZ[0], lookup_context.match_data[1]))
+ unsigned lenP1 = hb_max ((unsigned) input.lenP1, 1u);
+ if (lenP1 > 1 ?
+ (!match_input ||
+ match_input (*first, input.arrayZ[0], input_data))
:
- (!lookahead.len || !lookup_context.funcs.match[2] ||
- lookup_context.funcs.match[2] (*first, lookahead.arrayZ[0], lookup_context.match_data[2])))
+ (!lookahead.len || !match_lookahead ||
+ match_lookahead (*first, lookahead.arrayZ[0], lookahead_data)))
{
- if (r.apply (c, lookup_context))
+ if (!second ||
+ (lenP1 > 2 ?
+ (!match_input ||
+ match_input (*second, input.arrayZ[1], input_data))
+ :
+ (lookahead.len <= 2 - lenP1 || !match_lookahead ||
+ match_lookahead (*second, lookahead.arrayZ[2 - lenP1], lookahead_data))))
{
- if (unsafe_to_concat)
- c->buffer->unsafe_to_concat (c->buffer->idx, unsafe_to);
- return_trace (true);
+ if (r.apply (c, lookup_context))
+ {
+ if (unsafe_to != (unsigned) -1)
+ c->buffer->unsafe_to_concat (c->buffer->idx, unsafe_to);
+ return_trace (true);
+ }
}
+ else
+ unsafe_to = unsafe_to2;
}
else
- unsafe_to_concat = true;
+ {
+ if (unsafe_to == (unsigned) -1)
+ unsafe_to = unsafe_to1;
+ }
}
- if (likely (unsafe_to_concat))
+ if (likely (unsafe_to != (unsigned) -1))
c->buffer->unsafe_to_concat (c->buffer->idx, unsafe_to);
return_trace (false);
diff --git a/src/hb-sanitize.hh b/src/hb-sanitize.hh
index 2d338c5..8d9ecce 100644
--- a/src/hb-sanitize.hh
+++ b/src/hb-sanitize.hh
@@ -258,7 +258,8 @@
this->max_ops = -1;
return false;
}
- return (this->max_ops -= (int) count) > 0;
+ this->max_ops -= (int) count;
+ return true;
}
#ifndef HB_OPTIMIZE_SIZE