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('''
300 parse-printf-format.c
301 parse-printf-format.h
371 missing_h = files('missing.h')
373 generate_gperfs = find_program('generate-gperfs.py')
375 #if 0 /// elogind has only the cap and errno list.
376 # generate_af_list = find_program('generate-af-list.sh')
377 # af_list_txt = custom_target(
379 # output : 'af-list.txt',
380 # command : [generate_af_list, cpp],
383 # generate_arphrd_list = find_program('generate-arphrd-list.sh')
384 # arphrd_list_txt = custom_target(
386 # output : 'arphrd-list.txt',
387 # command : [generate_arphrd_list, cpp],
391 generate_cap_list = find_program('generate-cap-list.sh')
392 cap_list_txt = custom_target(
394 output : 'cap-list.txt',
395 #if 0 /// elogind needs musl_missing.h, so generate_cap_list must know the source root
396 # command : [generate_cap_list, cpp, config_h, missing_h],
398 command : [generate_cap_list, cpp, meson.source_root(), config_h, missing_h],
402 generate_errno_list = find_program('generate-errno-list.sh')
403 errno_list_txt = custom_target(
405 output : 'errno-list.txt',
406 command : [generate_errno_list, cpp],
409 generate_socket_protocol_list = find_program('generate-socket-protocol-list.sh')
410 socket_protocol_list_txt = custom_target(
411 'socket-protocol-list.txt',
412 output : 'socket-protocol-list.txt',
413 command : [generate_socket_protocol_list, cpp],
416 generated_gperf_headers = []
417 #if 0 /// elogind has only the cap and errno list.
418 # foreach item : [['af', af_list_txt, 'af', ''],
419 # ['arphrd', arphrd_list_txt, 'arphrd', 'ARPHRD_'],
420 # ['cap', cap_list_txt, 'capability', ''],
421 # ['errno', errno_list_txt, 'errno', ''],
422 # ['socket-protocol', socket_protocol_list_txt, 'socket_protocol', 'IPPROTO_']]
424 foreach item : [['cap', cap_list_txt, 'capability', ''],
425 ['errno', errno_list_txt, 'errno', '']]
428 fname = '@0@-from-name.gperf'.format(item[0])
429 gperf_file = custom_target(
433 command : [generate_gperfs, item[2], item[3], '@INPUT@'],
436 fname = '@0@-from-name.h'.format(item[0])
437 target1 = custom_target(
442 '-L', 'ANSI-C', '-t', '--ignore-case',
443 '-N', 'lookup_@0@'.format(item[2]),
444 '-H', 'hash_@0@_name'.format(item[2]),
449 fname = '@0@-to-name.h'.format(item[0])
450 awkscript = '@0@-to-name.awk'.format(item[0])
451 target2 = custom_target(
453 input : [awkscript, item[1]],
455 command : [awk, '-f', '@INPUT0@', '@INPUT1@'],
458 generated_gperf_headers += [target1, target2]
461 basic_sources += [missing_h] + generated_gperf_headers
462 #if 0 /// elogind does not need gcrypt
463 # basic_gcrypt_sources = files(
468 libbasic = static_library(
471 include_directories : includes,
472 dependencies : [threads,
474 #if 0 /// Neither blkid nor libmount in elogind
479 c_args : ['-fvisibility=default'],
482 #if 0 /// elogind does not need gcrypt
483 # # A convenience library that is separate from libbasic to avoid
484 # # unnecessary linking to libgcrypt.
485 # libbasic_gcrypt = static_library(
487 # basic_gcrypt_sources,
488 # include_directories : includes,
489 # dependencies : [libgcrypt],
490 # c_args : ['-fvisibility=default'])