diff options
| author | Robert Adam <dev@robert-adam.de> | 2021-03-11 21:16:08 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-03-11 12:16:08 -0800 |
| commit | 46349895741d3763224394fcfed019a894bd9afd (patch) | |
| tree | d6f46d0124c968dc8a0b0e58525658f619832859 | |
| parent | 2543be2edf60bf38511c2d477bb17b617398a108 (diff) | |
| download | vcpkg-46349895741d3763224394fcfed019a894bd9afd.tar.gz vcpkg-46349895741d3763224394fcfed019a894bd9afd.zip | |
[harfbuzz] work around upstream SameFileError (#16621)
During the configuration of harfbuzz several Python scripts are invoked
that are supposed to copy some files. For some reason however the
scripts end up being instructed to copy files to themselves at which
point a SameFileError is risen, causing the build to fail.
This is a workaround for the underlaying issue that is deemed to be
usptream. The upstream issues are
- https://github.com/mesonbuild/meson/issues/8375
- https://github.com/harfbuzz/harfbuzz/issues/2870
The workaround is to add a patch that makes sure these scripts check
whether source and target file are the same and only invoking the copy
action if they are not.
Fixes #16262
| -rwxr-xr-x | ports/harfbuzz/0001-circumvent-samefile-error.patch | 43 | ||||
| -rw-r--r-- | ports/harfbuzz/portfile.cmake | 5 | ||||
| -rw-r--r-- | ports/harfbuzz/vcpkg.json | 1 | ||||
| -rw-r--r-- | versions/baseline.json | 2 | ||||
| -rw-r--r-- | versions/h-/harfbuzz.json | 5 |
5 files changed, 55 insertions, 1 deletions
diff --git a/ports/harfbuzz/0001-circumvent-samefile-error.patch b/ports/harfbuzz/0001-circumvent-samefile-error.patch new file mode 100755 index 000000000..3db21590a --- /dev/null +++ b/ports/harfbuzz/0001-circumvent-samefile-error.patch @@ -0,0 +1,43 @@ +diff --git a/src/gen-harfbuzzcc.py b/src/gen-harfbuzzcc.py +index b25bcc7..97bf2ab 100644 +--- a/src/gen-harfbuzzcc.py ++++ b/src/gen-harfbuzzcc.py +@@ -15,4 +15,8 @@ with open (OUTPUT, "wb") as f: + f.write ("".join ('#include "{}"\n'.format (os.path.basename (x)) for x in sources if x.endswith (".cc")).encode ()) + + # copy it also to src/ +-shutil.copyfile (OUTPUT, os.path.join (CURRENT_SOURCE_DIR, os.path.basename (OUTPUT))) ++src = OUTPUT ++dst = os.path.join (CURRENT_SOURCE_DIR, os.path.basename (OUTPUT)) ++# Avoid SameFileError ++if not os.path.samefile(src, dst): ++ shutil.copyfile (src, dst) +diff --git a/src/gen-hb-version.py b/src/gen-hb-version.py +index 5ec2024..59d4754 100644 +--- a/src/gen-hb-version.py ++++ b/src/gen-hb-version.py +@@ -33,4 +33,8 @@ with open (INPUT, "r", encoding='utf-8') as template: + .encode ()) + + # copy it also to src/ +-shutil.copyfile (OUTPUT, os.path.join (CURRENT_SOURCE_DIR, os.path.basename (OUTPUT))) ++src = OUTPUT ++dst = os.path.join(CURRENT_SOURCE_DIR, os.path.basename (OUTPUT)) ++# Avoid SameFileError if src and dst is the same ++if not os.path.samefile(src, dst): ++ shutil.copyfile (src, dst) +diff --git a/src/gen-ragel-artifacts.py b/src/gen-ragel-artifacts.py +index b60ec3b..288e224 100644 +--- a/src/gen-ragel-artifacts.py ++++ b/src/gen-ragel-artifacts.py +@@ -22,4 +22,8 @@ hh = rl.replace ('.rl', '.hh') + subprocess.Popen ([ragel, '-e', '-F1', '-o', hh, rl], cwd=outdir).wait () + + # copy it also to src/ +-shutil.copyfile (os.path.join (outdir, hh), os.path.join (CURRENT_SOURCE_DIR, hh)) ++src = os.path.join (outdir, hh) ++dst = os.path.join (CURRENT_SOURCE_DIR, hh) ++# Avoid SameFileError ++if not os.path.samefile(src, dst): ++ shutil.copyfile (src, dst) + diff --git a/ports/harfbuzz/portfile.cmake b/ports/harfbuzz/portfile.cmake index 5752550b6..54cc71fba 100644 --- a/ports/harfbuzz/portfile.cmake +++ b/ports/harfbuzz/portfile.cmake @@ -5,6 +5,11 @@ vcpkg_from_github( SHA512 d231a788ea4e52231d4c363c1eca76424cb82ed0952b5c24d0b082e88b3dddbda967e7fffe67fffdcb22c7ebfbf0ec923365eb4532be772f2e61fa7d29b51998 HEAD_REF master PATCHES + # This patch is a workaround that is needed until the following issues are resolved upstream: + # - https://github.com/mesonbuild/meson/issues/8375 + # - https://github.com/harfbuzz/harfbuzz/issues/2870 + # Details: https://github.com/microsoft/vcpkg/issues/16262 + 0001-circumvent-samefile-error.patch 0002-fix-uwp-build.patch ) diff --git a/ports/harfbuzz/vcpkg.json b/ports/harfbuzz/vcpkg.json index bdb4c3420..c2e9ab742 100644 --- a/ports/harfbuzz/vcpkg.json +++ b/ports/harfbuzz/vcpkg.json @@ -1,6 +1,7 @@ { "name": "harfbuzz", "version-string": "2.7.4", + "port-version": 1, "description": "HarfBuzz OpenType text shaping engine", "homepage": "https://github.com/harfbuzz/harfbuzz", "dependencies": [ diff --git a/versions/baseline.json b/versions/baseline.json index 50f088bcd..50d298a40 100644 --- a/versions/baseline.json +++ b/versions/baseline.json @@ -2378,7 +2378,7 @@ }, "harfbuzz": { "baseline": "2.7.4", - "port-version": 0 + "port-version": 1 }, "hayai": { "baseline": "2019-08-10", diff --git a/versions/h-/harfbuzz.json b/versions/h-/harfbuzz.json index b21931e21..7bdb4e94c 100644 --- a/versions/h-/harfbuzz.json +++ b/versions/h-/harfbuzz.json @@ -1,6 +1,11 @@ { "versions": [ { + "git-tree": "e985af9b39fb57ee491c1a773c43334665ddb3d3", + "version-string": "2.7.4", + "port-version": 1 + }, + { "git-tree": "bb9ea75cd35a35e57fb0bf79ff78818c95148fcf", "version-string": "2.7.4", "port-version": 0 |
