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
370 missing_h = files('missing.h')
372 generate_gperfs = find_program('generate-gperfs.py')
374 #if 0 /// elogind has only the cap and errno list.
375 # generate_af_list = find_program('generate-af-list.sh')
376 # af_list_txt = custom_target(
378 # output : 'af-list.txt',
379 # command : [generate_af_list, cpp],
382 # generate_arphrd_list = find_program('generate-arphrd-list.sh')
383 # arphrd_list_txt = custom_target(
385 # output : 'arphrd-list.txt',
386 # command : [generate_arphrd_list, cpp],
390 generate_cap_list = find_program('generate-cap-list.sh')
391 cap_list_txt = custom_target(
393 output : 'cap-list.txt',
394 #if 0 /// elogind needs musl_missing.h, so generate_cap_list must know the source root
395 # command : [generate_cap_list, cpp, config_h, missing_h],
397 command : [generate_cap_list, cpp, meson.source_root(), config_h, missing_h],
401 generate_errno_list = find_program('generate-errno-list.sh')
402 errno_list_txt = custom_target(
404 output : 'errno-list.txt',
405 command : [generate_errno_list, cpp],
408 generate_socket_protocol_list = find_program('generate-socket-protocol-list.sh')
409 socket_protocol_list_txt = custom_target(
410 'socket-protocol-list.txt',
411 output : 'socket-protocol-list.txt',
412 command : [generate_socket_protocol_list, cpp],
415 generated_gperf_headers = []
416 #if 0 /// elogind has only the cap and errno list.
417 # foreach item : [['af', af_list_txt, 'af', ''],
418 # ['arphrd', arphrd_list_txt, 'arphrd', 'ARPHRD_'],
419 # ['cap', cap_list_txt, 'capability', ''],
420 # ['errno', errno_list_txt, 'errno', ''],
421 # ['socket-protocol', socket_protocol_list_txt, 'socket_protocol', 'IPPROTO_']]
423 foreach item : [['cap', cap_list_txt, 'capability', ''],
424 ['errno', errno_list_txt, 'errno', '']]
427 fname = '@0@-from-name.gperf'.format(item[0])
428 gperf_file = custom_target(
432 command : [generate_gperfs, item[2], item[3], '@INPUT@'],
435 fname = '@0@-from-name.h'.format(item[0])
436 target1 = custom_target(
441 '-L', 'ANSI-C', '-t', '--ignore-case',
442 '-N', 'lookup_@0@'.format(item[2]),
443 '-H', 'hash_@0@_name'.format(item[2]),
448 fname = '@0@-to-name.h'.format(item[0])
449 awkscript = '@0@-to-name.awk'.format(item[0])
450 target2 = custom_target(
452 input : [awkscript, item[1]],
454 command : [awk, '-f', '@INPUT0@', '@INPUT1@'],
457 generated_gperf_headers += [target1, target2]
460 basic_sources += [missing_h] + generated_gperf_headers
461 #if 0 /// elogind does not need gcrypt
462 # basic_gcrypt_sources = files(
467 libbasic = static_library(
470 include_directories : includes,
471 dependencies : [threads,
473 #if 0 /// Neither blkid nor libmount in elogind
478 c_args : ['-fvisibility=default'],
481 #if 0 /// elogind does not need gcrypt
482 # # A convenience library that is separate from libbasic to avoid
483 # # unnecessary linking to libgcrypt.
484 # libbasic_gcrypt = static_library(
486 # basic_gcrypt_sources,
487 # include_directories : includes,
488 # dependencies : [libgcrypt],
489 # c_args : ['-fvisibility=default'])