1 # SPDX-License-Identifier: LGPL-2.1+
3 #if 0 /// elogind has a shorter list
4 # basic_sources = files('''
177 # socket-protocol-list.c
178 # socket-protocol-list.h
226 basic_sources = files('''
302 parse-printf-format.c
303 parse-printf-format.h
372 missing_h = files('missing.h')
374 generate_gperfs = find_program('generate-gperfs.py')
376 #if 0 /// elogind has only the cap and errno list.
377 # generate_af_list = find_program('generate-af-list.sh')
378 # af_list_txt = custom_target(
380 # output : 'af-list.txt',
381 # command : [generate_af_list, cpp],
384 # generate_arphrd_list = find_program('generate-arphrd-list.sh')
385 # arphrd_list_txt = custom_target(
387 # output : 'arphrd-list.txt',
388 # command : [generate_arphrd_list, cpp],
392 generate_cap_list = find_program('generate-cap-list.sh')
393 cap_list_txt = custom_target(
395 output : 'cap-list.txt',
396 #if 0 /// elogind needs musl_missing.h, so generate_cap_list must know the source root
397 # command : [generate_cap_list, cpp, config_h, missing_h],
399 command : [generate_cap_list, cpp, meson.source_root(), config_h, missing_h],
403 generate_errno_list = find_program('generate-errno-list.sh')
404 errno_list_txt = custom_target(
406 output : 'errno-list.txt',
407 command : [generate_errno_list, cpp],
410 generate_socket_protocol_list = find_program('generate-socket-protocol-list.sh')
411 socket_protocol_list_txt = custom_target(
412 'socket-protocol-list.txt',
413 output : 'socket-protocol-list.txt',
414 command : [generate_socket_protocol_list, cpp],
417 generated_gperf_headers = []
418 #if 0 /// elogind has only the cap and errno list.
419 # foreach item : [['af', af_list_txt, 'af', ''],
420 # ['arphrd', arphrd_list_txt, 'arphrd', 'ARPHRD_'],
421 # ['cap', cap_list_txt, 'capability', ''],
422 # ['errno', errno_list_txt, 'errno', ''],
423 # ['socket-protocol', socket_protocol_list_txt, 'socket_protocol', 'IPPROTO_']]
425 foreach item : [['cap', cap_list_txt, 'capability', ''],
426 ['errno', errno_list_txt, 'errno', '']]
429 fname = '@0@-from-name.gperf'.format(item[0])
430 gperf_file = custom_target(
434 command : [generate_gperfs, item[2], item[3], '@INPUT@'],
437 fname = '@0@-from-name.h'.format(item[0])
438 target1 = custom_target(
443 '-L', 'ANSI-C', '-t', '--ignore-case',
444 '-N', 'lookup_@0@'.format(item[2]),
445 '-H', 'hash_@0@_name'.format(item[2]),
450 fname = '@0@-to-name.h'.format(item[0])
451 awkscript = '@0@-to-name.awk'.format(item[0])
452 target2 = custom_target(
454 input : [awkscript, item[1]],
456 command : [awk, '-f', '@INPUT0@', '@INPUT1@'],
459 generated_gperf_headers += [target1, target2]
462 basic_sources += [missing_h] + generated_gperf_headers
463 #if 0 /// elogind does not need gcrypt
464 # basic_gcrypt_sources = files(
469 libbasic = static_library(
472 include_directories : includes,
473 dependencies : [threads,
475 #if 0 /// Neither blkid nor libmount in elogind
480 c_args : ['-fvisibility=default'],
483 #if 0 /// elogind does not need gcrypt
484 # # A convenience library that is separate from libbasic to avoid
485 # # unnecessary linking to libgcrypt.
486 # libbasic_gcrypt = static_library(
488 # basic_gcrypt_sources,
489 # include_directories : includes,
490 # dependencies : [libgcrypt],
491 # c_args : ['-fvisibility=default'])