diff options
author | Marius Vlad <marius.vlad@collabora.com> | 2022-09-30 17:10:39 +0300 |
---|---|---|
committer | Marius Vlad <marius.vlad@collabora.com> | 2022-10-27 17:24:04 +0300 |
commit | 4df12ac75fc5b65b7cfbf9d1829c0f780595d43e (patch) | |
tree | 847ee27ef2a555b665cce86eef1a689c39e83365 /meson.build | |
parent | 9f39c12f709fc9f59b06b0ebbc6b1d9065846f98 (diff) |
src: Add initial support for gRPC
Brings in initial support for gRPC. It re-uses the same protobuf as
supplied by the compositor. With it, this changes from C to CPP as that
allows far better and easier integration with gRPC.
Bug-AGL: SPEC-4503
Signed-off-by: Marius Vlad <marius.vlad@collabora.com>
Change-Id: Idf09db80063dfa0c4cd7f3f345686fe9d2d27622
Diffstat (limited to 'meson.build')
-rw-r--r-- | meson.build | 61 |
1 files changed, 39 insertions, 22 deletions
diff --git a/meson.build b/meson.build index 0a56242..fa7b1bb 100644 --- a/meson.build +++ b/meson.build @@ -1,41 +1,53 @@ project('agl-shell-activator', - 'c', - version: '0.0.1', + 'c', 'cpp', + version: '0.0.2', default_options: [ 'warning_level=3', 'c_std=gnu99', ], - meson_version: '>= 0.50', + meson_version: '>= 0.60', license: 'MIT/Expat', ) pkgconfig = import('pkgconfig') -cc = meson.get_compiler('c') - -add_project_arguments( - cc.get_supported_arguments([ - '-Wno-unused-parameter', - '-Wno-pedantic', - '-Wextra', - '-Werror' - ]), - language: 'c' -) +cpp = meson.get_compiler('cpp') + +grpcpp_reflection_dep = cpp.find_library('grpc++_reflection') +protoc = find_program('protoc') +grpc_cpp = find_program('grpc_cpp_plugin') + add_project_arguments([ '-DPACKAGE_STRING="agl-shell-activator @0@"'.format(meson.project_version()), '-D_GNU_SOURCE', '-D_ALL_SOURCE', ], - language: 'c' + language: 'cpp' ) -optional_libc_funcs = [ 'memfd_create', 'strchrnul' ] -foreach func: optional_libc_funcs - if cc.has_function(func) - add_project_arguments('-DHAVE_@0@=1'.format(func.to_upper()), language: 'c') - endif -endforeach +protoc_gen = generator(protoc, \ + output : ['@BASENAME@.pb.cc', '@BASENAME@.pb.h'], + arguments : ['--proto_path=@CURRENT_SOURCE_DIR@/src', + '--cpp_out=@BUILD_DIR@', + '@INPUT@']) + +generated_protoc_sources = protoc_gen.process('src/agl_shell.proto') + +grpc_gen = generator(protoc, \ + output : ['@BASENAME@.grpc.pb.cc', '@BASENAME@.grpc.pb.h'], + arguments : ['--proto_path=@CURRENT_SOURCE_DIR@/src', + '--grpc_out=@BUILD_DIR@', + '--plugin=protoc-gen-grpc=' + grpc_cpp.path(), + '@INPUT@']) +generated_grpc_sources = grpc_gen.process('src/agl_shell.proto') + +grpc_deps = [ + dependency('protobuf'), + dependency('grpc'), + dependency('grpc++'), + grpcpp_reflection_dep, +] + env_modmap = '' @@ -98,10 +110,15 @@ common_inc = include_directories('include') deps_agl_activator = [ libwayland_dep, + grpc_deps, ] srcs_agl_activator = [ - 'src/main.c', + 'src/main.cpp', + 'src/AglShellGrpcClient.cpp', + 'src/AglShellGrpcClient.h', + generated_protoc_sources, + generated_grpc_sources, agl_shell_desktop_client_protocol_h, agl_shell_desktop_protocol_c, ] |