[meson] use the recommended way to generate ragel headers
As described in https://github.com/mesonbuild/meson/issues/7156#issuecomment-629622827
This commit is contained in:
parent
5c07c291c7
commit
785a9a8f8a
|
@ -12,7 +12,7 @@ if len (sys.argv) < 3:
|
||||||
output_file = sys.argv[1]
|
output_file = sys.argv[1]
|
||||||
source_paths = sys.argv[2:]
|
source_paths = sys.argv[2:]
|
||||||
|
|
||||||
result = "".join ('#include "{}"\n'.format (x) for x in source_paths if x.endswith (".cc")).encode ()
|
result = "".join ('#include "{}"\n'.format (os.path.basename (x)) for x in source_paths if x.endswith (".cc")).encode ()
|
||||||
|
|
||||||
with open (output_file, "rb") as f:
|
with open (output_file, "rb") as f:
|
||||||
current = f.read()
|
current = f.read()
|
||||||
|
|
|
@ -1,40 +1,23 @@
|
||||||
#!/usr/bin/env python3
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
import os, sys, subprocess, shutil, tempfile
|
import os, os.path, sys, subprocess, shutil, tempfile
|
||||||
|
|
||||||
os.chdir (os.path.dirname (__file__))
|
|
||||||
|
|
||||||
if len (sys.argv) < 2:
|
|
||||||
ragel_sources = [x for x in os.listdir ('.') if x.endswith ('.rl')]
|
|
||||||
else:
|
|
||||||
ragel_sources = sys.argv[2:]
|
|
||||||
|
|
||||||
ragel = shutil.which ('ragel')
|
ragel = shutil.which ('ragel')
|
||||||
|
|
||||||
if not ragel:
|
if not ragel:
|
||||||
print ('You have to install ragel if you are going to develop HarfBuzz itself')
|
exit ('You have to install ragel if you are going to develop HarfBuzz itself')
|
||||||
exit (1)
|
|
||||||
|
|
||||||
if not len (ragel_sources):
|
if len (sys.argv) < 4:
|
||||||
exit (77)
|
exit ('This tool is intended to be used from meson')
|
||||||
|
|
||||||
tempdir = tempfile.mkdtemp ()
|
OUTPUT = sys.argv[1]
|
||||||
|
CURRENT_SOURCE_DIR = sys.argv[2]
|
||||||
|
INPUT = sys.argv[3]
|
||||||
|
|
||||||
for rl in ragel_sources:
|
outdir = os.path.dirname (OUTPUT)
|
||||||
hh = rl.replace ('.rl', '.hh')
|
shutil.copy (INPUT, outdir)
|
||||||
shutil.copy (rl, tempdir)
|
rl = os.path.basename (INPUT)
|
||||||
# writing to stdout has some complication on Windows
|
hh = rl.replace ('.rl', '.hh')
|
||||||
subprocess.Popen ([ragel, '-e', '-F1', '-o', hh, rl], cwd=tempdir).wait ()
|
subprocess.Popen ([ragel, '-e', '-F1', '-o', hh, rl], cwd=outdir).wait ()
|
||||||
|
|
||||||
generated_path = os.path.join (tempdir, hh)
|
# copy it also to src/
|
||||||
with open (generated_path, "rb") as temp_file:
|
shutil.copyfile (os.path.join (outdir, hh), os.path.join (CURRENT_SOURCE_DIR, hh))
|
||||||
generated = temp_file.read()
|
|
||||||
|
|
||||||
with open (hh, "rb") as current_file:
|
|
||||||
current = current_file.read()
|
|
||||||
|
|
||||||
# overwrite only if is changed
|
|
||||||
if generated != current:
|
|
||||||
shutil.copyfile (generated_path, hh)
|
|
||||||
|
|
||||||
shutil.rmtree (tempdir)
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
# Base and default-included sources and headers
|
# Base and default-included sources and headers
|
||||||
hb_base_sources = [
|
hb_base_sources = files(
|
||||||
'hb-aat-fdsc-table.hh',
|
'hb-aat-fdsc-table.hh',
|
||||||
'hb-aat-layout-ankr-table.hh',
|
'hb-aat-layout-ankr-table.hh',
|
||||||
'hb-aat-layout-bsln-table.hh',
|
'hb-aat-layout-bsln-table.hh',
|
||||||
|
@ -167,9 +167,9 @@ hb_base_sources = [
|
||||||
'hb-utf.hh',
|
'hb-utf.hh',
|
||||||
'hb-vector.hh',
|
'hb-vector.hh',
|
||||||
'hb.hh',
|
'hb.hh',
|
||||||
]
|
)
|
||||||
|
|
||||||
hb_base_ragel_generated_sources = [
|
hb_base_ragel_generated_sources = files(
|
||||||
'hb-buffer-deserialize-json.hh',
|
'hb-buffer-deserialize-json.hh',
|
||||||
'hb-buffer-deserialize-text.hh',
|
'hb-buffer-deserialize-text.hh',
|
||||||
'hb-number-parser.hh',
|
'hb-number-parser.hh',
|
||||||
|
@ -177,7 +177,7 @@ hb_base_ragel_generated_sources = [
|
||||||
'hb-ot-shape-complex-khmer-machine.hh',
|
'hb-ot-shape-complex-khmer-machine.hh',
|
||||||
'hb-ot-shape-complex-myanmar-machine.hh',
|
'hb-ot-shape-complex-myanmar-machine.hh',
|
||||||
'hb-ot-shape-complex-use-machine.hh',
|
'hb-ot-shape-complex-use-machine.hh',
|
||||||
]
|
)
|
||||||
hb_base_ragel_sources = [
|
hb_base_ragel_sources = [
|
||||||
'hb-buffer-deserialize-json.rl',
|
'hb-buffer-deserialize-json.rl',
|
||||||
'hb-buffer-deserialize-text.rl',
|
'hb-buffer-deserialize-text.rl',
|
||||||
|
@ -188,7 +188,7 @@ hb_base_ragel_sources = [
|
||||||
'hb-ot-shape-complex-use-machine.rl',
|
'hb-ot-shape-complex-use-machine.rl',
|
||||||
]
|
]
|
||||||
|
|
||||||
hb_base_headers = [
|
hb_base_headers = files(
|
||||||
'hb-aat-layout.h',
|
'hb-aat-layout.h',
|
||||||
'hb-aat.h',
|
'hb-aat.h',
|
||||||
'hb-blob.h',
|
'hb-blob.h',
|
||||||
|
@ -217,39 +217,39 @@ hb_base_headers = [
|
||||||
'hb-unicode.h',
|
'hb-unicode.h',
|
||||||
'hb-version.h',
|
'hb-version.h',
|
||||||
'hb.h',
|
'hb.h',
|
||||||
]
|
)
|
||||||
|
|
||||||
# Optional Sources and Headers with external deps
|
# Optional Sources and Headers with external deps
|
||||||
|
|
||||||
hb_ft_sources = ['hb-ft.cc']
|
hb_ft_sources = files('hb-ft.cc')
|
||||||
hb_ft_headers = ['hb-ft.h']
|
hb_ft_headers = files('hb-ft.h')
|
||||||
|
|
||||||
hb_glib_sources = ['hb-glib.cc']
|
hb_glib_sources = files('hb-glib.cc')
|
||||||
hb_glib_headers = ['hb-glib.h']
|
hb_glib_headers = files('hb-glib.h')
|
||||||
|
|
||||||
hb_graphite2_sources = ['hb-graphite2.cc']
|
hb_graphite2_sources = files('hb-graphite2.cc')
|
||||||
hb_graphite2_headers = ['hb-graphite2.h']
|
hb_graphite2_headers = files('hb-graphite2.h')
|
||||||
|
|
||||||
# System-dependent sources and headers
|
# System-dependent sources and headers
|
||||||
|
|
||||||
hb_coretext_sources = ['hb-coretext.cc']
|
hb_coretext_sources = files('hb-coretext.cc')
|
||||||
hb_coretext_headers = ['hb-coretext.h']
|
hb_coretext_headers = files('hb-coretext.h')
|
||||||
|
|
||||||
hb_directwrite_sources = ['hb-directwrite.cc']
|
hb_directwrite_sources = files('hb-directwrite.cc')
|
||||||
hb_directwrite_headers = ['hb-directwrite.h']
|
hb_directwrite_headers = files('hb-directwrite.h')
|
||||||
|
|
||||||
hb_gdi_sources = ['hb-gdi.cc']
|
hb_gdi_sources = files('hb-gdi.cc')
|
||||||
hb_gdi_headers = ['hb-gdi.h']
|
hb_gdi_headers = files('hb-gdi.h')
|
||||||
|
|
||||||
hb_uniscribe_sources = ['hb-uniscribe.cc']
|
hb_uniscribe_sources = files('hb-uniscribe.cc')
|
||||||
hb_uniscribe_headers = ['hb-uniscribe.h']
|
hb_uniscribe_headers = files('hb-uniscribe.h')
|
||||||
|
|
||||||
# Sources for libharfbuzz-gobject and libharfbuzz-icu
|
# Sources for libharfbuzz-gobject and libharfbuzz-icu
|
||||||
hb_icu_sources = ['hb-icu.cc']
|
hb_icu_sources = files('hb-icu.cc')
|
||||||
hb_icu_headers = ['hb-icu.h']
|
hb_icu_headers = files('hb-icu.h')
|
||||||
|
|
||||||
# Sources for libharfbuzz-subset
|
# Sources for libharfbuzz-subset
|
||||||
hb_subset_sources = [
|
hb_subset_sources = files(
|
||||||
'hb-number.cc',
|
'hb-number.cc',
|
||||||
'hb-number.hh',
|
'hb-number.hh',
|
||||||
'hb-ot-cff1-table.cc',
|
'hb-ot-cff1-table.cc',
|
||||||
|
@ -269,18 +269,18 @@ hb_subset_sources = [
|
||||||
'hb-subset.cc',
|
'hb-subset.cc',
|
||||||
'hb-subset.hh',
|
'hb-subset.hh',
|
||||||
'hb-subset.hh',
|
'hb-subset.hh',
|
||||||
]
|
)
|
||||||
|
|
||||||
hb_subset_headers = ['hb-subset.h']
|
hb_subset_headers = files('hb-subset.h')
|
||||||
|
|
||||||
hb_gobject_sources = [
|
hb_gobject_sources = files(
|
||||||
'hb-gobject-structs.cc'
|
'hb-gobject-structs.cc'
|
||||||
]
|
)
|
||||||
|
|
||||||
hb_gobject_headers = [
|
hb_gobject_headers = files(
|
||||||
'hb-gobject.h',
|
'hb-gobject.h',
|
||||||
'hb-gobject-structs.h',
|
'hb-gobject-structs.h',
|
||||||
]
|
)
|
||||||
|
|
||||||
custom_target('hb-version.h',
|
custom_target('hb-version.h',
|
||||||
build_by_default: true,
|
build_by_default: true,
|
||||||
|
@ -293,11 +293,18 @@ ragel = find_program('ragel', required: false)
|
||||||
if not ragel.found()
|
if not ragel.found()
|
||||||
warning('You have to install ragel if you are going to develop HarfBuzz itself')
|
warning('You have to install ragel if you are going to develop HarfBuzz itself')
|
||||||
else
|
else
|
||||||
custom_target('ragel header files',
|
foreach rl : hb_base_ragel_sources
|
||||||
|
hh = rl.split('.')[0] + '.hh'
|
||||||
|
custom_target('@0@'.format(hh),
|
||||||
build_by_default: true,
|
build_by_default: true,
|
||||||
input: hb_base_ragel_sources,
|
input: rl,
|
||||||
output: '.ragel-artifacts',
|
output: hh,
|
||||||
command: [find_program('gen-ragel-artifacts.py')] + hb_base_ragel_sources)
|
command: [find_program('gen-ragel-artifacts.py'),
|
||||||
|
'@OUTPUT@',
|
||||||
|
'@CURRENT_SOURCE_DIR@',
|
||||||
|
'@INPUT@'],
|
||||||
|
)
|
||||||
|
endforeach
|
||||||
endif
|
endif
|
||||||
|
|
||||||
custom_target('harfbuzz.cc',
|
custom_target('harfbuzz.cc',
|
||||||
|
@ -667,8 +674,16 @@ if get_option('tests').enabled()
|
||||||
env.set('srcdir', meson.current_source_dir())
|
env.set('srcdir', meson.current_source_dir())
|
||||||
env.set('builddir', meson.current_build_dir())
|
env.set('builddir', meson.current_build_dir())
|
||||||
env.set('libs', meson.current_build_dir()) # TODO: Merge this with builddir after autotools removal
|
env.set('libs', meson.current_build_dir()) # TODO: Merge this with builddir after autotools removal
|
||||||
env.set('HBSOURCES', ' '.join(hb_sources))
|
HBSOURCES = []
|
||||||
env.set('HBHEADERS', ' '.join(hb_headers))
|
foreach f : hb_sources
|
||||||
|
HBSOURCES += '@0@'.format(f).split ('/')[1]
|
||||||
|
endforeach
|
||||||
|
env.set('HBSOURCES', ' '.join(HBSOURCES))
|
||||||
|
HBHEADERS = []
|
||||||
|
foreach f : hb_headers
|
||||||
|
HBHEADERS += '@0@'.format(f).split ('/')[1]
|
||||||
|
endforeach
|
||||||
|
env.set('HBHEADERS', ' '.join(HBHEADERS))
|
||||||
|
|
||||||
if cpp.get_id() != 'msvc' and not meson.is_cross_build() # ensure the local tools are usable
|
if cpp.get_id() != 'msvc' and not meson.is_cross_build() # ensure the local tools are usable
|
||||||
dist_check_script += ['check-libstdc++', 'check-static-inits', 'check-symbols']
|
dist_check_script += ['check-libstdc++', 'check-static-inits', 'check-symbols']
|
||||||
|
|
Loading…
Reference in New Issue