diff --git a/pdns/recursordist/meson.build b/pdns/recursordist/meson.build index 2cb4799708e4..b443795567d3 100644 --- a/pdns/recursordist/meson.build +++ b/pdns/recursordist/meson.build @@ -274,7 +274,7 @@ py = import('python') python = py.find_installation('python3', required: true) metricfiles = custom_target( - command: [python, '@INPUT0@', '@SOURCE_ROOT@'], + command: [python, '@INPUT0@', '@SOURCE_ROOT@', '@BUILD_ROOT@'], input: metric_sources, output: [ 'rec-metrics-gen.h', diff --git a/pdns/recursordist/metrics.py b/pdns/recursordist/metrics.py index 469ecebad026..3d11b68973df 100644 --- a/pdns/recursordist/metrics.py +++ b/pdns/recursordist/metrics.py @@ -1,17 +1,21 @@ import os import sys +import shutil # default: 'type': uint64 # ptype: "'counter' (vs gauge') srcdir = '.' -if len(sys.argv) == 2: - print("metrics.py: using srcdir from arguments") +builddir = '.' +if len(sys.argv) == 3: + print("metrics.py: using srcdir and builddir from arguments") srcdir = sys.argv[1] + builddir = sys.argv[2] print("Generating metrics related files") print("metrics.py cwd: " + os.getcwd()) print("metrics.py srcdir: " + srcdir + " = " + os.path.realpath(srcdir)) +print("metrics.py builddir: " + builddir + " = " + os.path.realpath(builddir)) def dedashForSNMP(name): cap = False @@ -31,6 +35,10 @@ def dedashForSNMP(name): with open(srcdir + '/metrics_table.py', mode='r', encoding="utf-8") as file: table = eval(file.read()) +# +# We create various files in the srcdir but copy them into the builddir if needed to satisfy meson +# FIXME: only generate in builddir once autotools have been dropped +# with open(srcdir + '/rec-oids-gen.h', 'w', encoding='utf-8') as file: file.write('// THIS IS A GENERATED FILE. DO NOT EDIT. SOURCE metrics.py AND metrics_table.py\n') for entry in table: @@ -44,6 +52,8 @@ def dedashForSNMP(name): file.write(f'static const oid10 {name}OID = {{RECURSOR_STATS_OID, {snmp}}};\n') if 'ifdef' in entry: file.write(f'#endif\n') +if srcdir != builddir: + shutil.copy(srcdir + '/rec-oids-gen.h', builddir) with open(srcdir + '/rec-snmp-gen.h', 'w', encoding='utf-8') as file: file.write('// THIS IS A GENERATED FILE. DO NOT EDIT. SOURCE metrics.py AND metrics_table.py\n') @@ -58,6 +68,8 @@ def dedashForSNMP(name): file.write(f'registerCounter64Stat("{name}", {dname}OID);\n') if 'ifdef' in entry: file.write(f'#endif\n') +if srcdir != builddir: + shutil.copy(srcdir + '/rec-snmp-gen.h', builddir) with open(srcdir + '/rec-prometheus-gen.h', 'w', encoding='utf-8') as file: file.write('// THIS IS A GENERATED FILE. DO NOT EDIT. SOURCE metrics.py AND metrics_table.py\n') @@ -75,6 +87,8 @@ def dedashForSNMP(name): if 'ptype' in entry: ptype = entry['ptype'] file.write(f'{{"{name}", MetricDefinition(PrometheusMetricType::{ptype}, "{desc}")}},\n') +if srcdir != builddir: + shutil.copy(srcdir + '/rec-prometheus-gen.h', builddir) with open(srcdir + '/rec-metrics-gen.h', 'w', encoding='utf-8') as file: file.write('// THIS IS A GENERATED FILE. DO NOT EDIT. SOURCE metrics.py AND metrics_table.py\n') @@ -94,6 +108,8 @@ def dedashForSNMP(name): file.write(f'}}\n') if 'ifdef' in entry: file.write(f'#endif\n') +if srcdir != builddir: + shutil.copy(srcdir + '/rec-metrics-gen.h', builddir) if os.path.isdir(srcdir + '/docs'): with open(srcdir + '/docs/rec-metrics-gen.rst', 'w', encoding='utf-8') as file: @@ -155,9 +171,11 @@ def dedashForSNMP(name): str2 += f',\n {name}' -with open(srcdir + '/RECURSOR-MIB.in', mode='r', encoding='UTF-8') as file: +with open(srcdir + '/RECURSOR-MIB.in', mode='r', encoding='utf-8') as file: text = file.read() text = text.replace('REPL_OBJECTS1', str1) text = text.replace('REPL_OBJECTS2', str2) with open(srcdir + '/RECURSOR-MIB.txt', 'w', encoding='utf-8') as file2: file2.write(text) +if srcdir != builddir: + shutil.copy(srcdir + '/RECURSOR-MIB.txt', builddir)