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('''
304 parse-printf-format.c
305 parse-printf-format.h
374 missing_h = files('missing.h')
376 generate_gperfs = find_program('generate-gperfs.py')
378 #if 0 /// elogind has only the cap and errno list.
379 # generate_af_list = find_program('generate-af-list.sh')
380 # af_list_txt = custom_target(
382 # output : 'af-list.txt',
383 # command : [generate_af_list, cpp],
386 # generate_arphrd_list = find_program('generate-arphrd-list.sh')
387 # arphrd_list_txt = custom_target(
389 # output : 'arphrd-list.txt',
390 # command : [generate_arphrd_list, cpp],
394 generate_cap_list = find_program('generate-cap-list.sh')
395 cap_list_txt = custom_target(
397 output : 'cap-list.txt',
398 #if 0 /// elogind needs musl_missing.h, so generate_cap_list must know the source root
399 # command : [generate_cap_list, cpp, config_h, missing_h],
401 command : [generate_cap_list, cpp, meson.source_root(), config_h, missing_h],
405 generate_errno_list = find_program('generate-errno-list.sh')
406 errno_list_txt = custom_target(
408 output : 'errno-list.txt',
409 command : [generate_errno_list, cpp],
412 generate_socket_protocol_list = find_program('generate-socket-protocol-list.sh')
413 socket_protocol_list_txt = custom_target(
414 'socket-protocol-list.txt',
415 output : 'socket-protocol-list.txt',
416 command : [generate_socket_protocol_list, cpp],
419 generated_gperf_headers = []
420 #if 0 /// elogind has only the cap and errno list.
421 # foreach item : [['af', af_list_txt, 'af', ''],
422 # ['arphrd', arphrd_list_txt, 'arphrd', 'ARPHRD_'],
423 # ['cap', cap_list_txt, 'capability', ''],
424 # ['errno', errno_list_txt, 'errno', ''],
425 # ['socket-protocol', socket_protocol_list_txt, 'socket_protocol', 'IPPROTO_']]
427 foreach item : [['cap', cap_list_txt, 'capability', ''],
428 ['errno', errno_list_txt, 'errno', '']]
431 fname = '@0@-from-name.gperf'.format(item[0])
432 gperf_file = custom_target(
436 command : [generate_gperfs, item[2], item[3], '@INPUT@'],
439 fname = '@0@-from-name.h'.format(item[0])
440 target1 = custom_target(
445 '-L', 'ANSI-C', '-t', '--ignore-case',
446 '-N', 'lookup_@0@'.format(item[2]),
447 '-H', 'hash_@0@_name'.format(item[2]),
452 fname = '@0@-to-name.h'.format(item[0])
453 awkscript = '@0@-to-name.awk'.format(item[0])
454 target2 = custom_target(
456 input : [awkscript, item[1]],
458 command : [awk, '-f', '@INPUT0@', '@INPUT1@'],
461 generated_gperf_headers += [target1, target2]
464 basic_sources += [missing_h] + generated_gperf_headers
465 #if 0 /// elogind does not need gcrypt
466 # basic_gcrypt_sources = files(
471 libbasic = static_library(
474 include_directories : includes,
475 dependencies : [threads,
477 #if 0 /// Neither blkid nor libmount in elogind
482 c_args : ['-fvisibility=default'],
485 #if 0 /// elogind does not need gcrypt
486 # # A convenience library that is separate from libbasic to avoid
487 # # unnecessary linking to libgcrypt.
488 # libbasic_gcrypt = static_library(
490 # basic_gcrypt_sources,
491 # include_directories : includes,
492 # dependencies : [libgcrypt],
493 # c_args : ['-fvisibility=default'])