2011-11-02 23:45:32 +04:00
# Makefile for C source code
#
2014-05-01 20:55:13 +04:00
# Copyright (C) 2011,2014 Colin Walters <walters@verbum.org>
2011-11-02 23:45:32 +04:00
#
2018-01-30 22:26:26 +03:00
# SPDX-License-Identifier: LGPL-2.0+
#
2011-11-10 22:17:04 +04:00
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2 of the License, or (at your option) any later version.
2011-11-02 23:45:32 +04:00
#
2011-11-10 22:17:04 +04:00
# This library is distributed in the hope that it will be useful,
2011-11-02 23:45:32 +04:00
# but WITHOUT ANY WARRANTY; without even the implied warranty of
2011-11-10 22:17:04 +04:00
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
2011-11-02 23:45:32 +04:00
#
2011-11-10 22:17:04 +04:00
# You should have received a copy of the GNU Lesser General Public
2021-12-07 04:20:55 +03:00
# License along with this library. If not, see <https://www.gnu.org/licenses/>.
2011-11-02 23:45:32 +04:00
2013-08-17 06:54:35 +04:00
include Makefile-libostree-defines.am
oxidation: Add implementation of bupsplit in Rust
This is an initial drop of "oxidation", or adding implementation
of components in Rust. The bupsplit code is a good target - no
dependencies, just computation.
Translation into Rust had a few twists -
- The C code relies a lot on overflowing unsigned ints, and
also on the C promotion rules for e.g. `uint8_t -> int32_t`
- There were some odd loops that I introduced bugs in while
translating...in particular, the function always returns `len`,
but I mistakenly translated to `len+1`, resulting in an OOB
read on the C side, which was hard to debug.
On the plus side, an off-by-one array indexing in the Rust code paniced nicely.
In practice, we'll need a lot more build infrastructure to make this work, such
as using `cargo vendor` when producing build artifacts for example. Also, Cargo
is yet another thing we need to cache.
Where do we go with this? Well, I think we should merge this, it's not a lot of
code. We can just have it be an alternative CI target. Should we do a lot more
right now? Probably not immediately, but I find the medium/long term prospects
pretty exciting!
Closes: #656
Approved by: jlebon
2017-01-25 05:43:53 +03:00
bupsplitpath = libbupsplit.la
noinst_LTLIBRARIES += libbupsplit.la
libbupsplit_la_SOURCES = src/libostree/bupsplit.h src/libostree/bupsplit.c
2014-01-16 22:04:00 +04:00
2013-07-27 03:25:07 +04:00
lib_LTLIBRARIES += libostree-1.la
2011-11-02 23:45:32 +04:00
2013-08-12 18:27:42 +04:00
libostreeincludedir = $(includedir)/ostree-1
2017-03-10 20:33:52 +03:00
libostreeinclude_HEADERS = $(libostree_public_headers) $(libostree_public_built_headers)
2013-07-27 03:25:07 +04:00
2016-05-12 17:15:24 +03:00
ENUM_TYPES = $(NULL)
ENUM_TYPES += $(srcdir)/src/libostree/ostree-fetcher.h
2015-11-10 03:04:42 +03:00
2017-11-07 17:53:12 +03:00
# TODO: GLIB_CHECK_VERSION > 2.5x: use --output instead of mv (see https://github.com/ostreedev/ostree/pull/1329)
2015-11-10 03:04:42 +03:00
src/libostree/ostree-enumtypes.h: src/libostree/ostree-enumtypes.h.template $(ENUM_TYPES)
$(AM_V_GEN) $(GLIB_MKENUMS) \
2015-12-14 22:19:35 +03:00
--template $< \
$(ENUM_TYPES) > $@.tmp && mv $@.tmp $@
2015-11-10 03:04:42 +03:00
2017-11-03 18:47:16 +03:00
src/libostree/ostree-enumtypes.c: src/libostree/ostree-enumtypes.c.template src/libostree/ostree-enumtypes.h $(ENUM_TYPES)
2015-11-10 03:04:42 +03:00
$(AM_V_GEN) $(GLIB_MKENUMS) \
2015-12-14 22:19:35 +03:00
--template $< \
$(ENUM_TYPES) > $@.tmp && mv $@.tmp $@
2015-11-10 03:04:42 +03:00
2017-01-27 12:06:39 +03:00
nodist_libostree_1_la_SOURCES = \
2015-11-10 03:04:42 +03:00
src/libostree/ostree-enumtypes.h \
src/libostree/ostree-enumtypes.c \
$(NULL)
2017-01-27 12:06:39 +03:00
BUILT_SOURCES += $(nodist_libostree_1_la_SOURCES)
2015-11-10 03:04:42 +03:00
CLEANFILES += $(BUILT_SOURCES)
2013-07-27 03:25:07 +04:00
libostree_1_la_SOURCES = \
2013-10-24 17:10:34 +04:00
src/libostree/ostree-async-progress.c \
2022-06-03 00:13:17 +03:00
src/libostree/ostree-cmd-private.h \
src/libostree/ostree-cmd-private.c \
2013-10-16 00:30:09 +04:00
src/libostree/ostree-core-private.h \
2013-07-27 03:25:07 +04:00
src/libostree/ostree-core.c \
2020-10-16 19:05:54 +03:00
src/libostree/ostree-date-utils.c \
src/libostree/ostree-date-utils-private.h \
2016-05-12 17:32:17 +03:00
src/libostree/ostree-dummy-enumtypes.c \
2012-04-11 00:40:22 +04:00
src/libostree/ostree-checksum-input-stream.c \
src/libostree/ostree-checksum-input-stream.h \
2012-04-11 23:18:34 +04:00
src/libostree/ostree-chain-input-stream.c \
src/libostree/ostree-chain-input-stream.h \
2021-04-09 03:35:54 +03:00
src/libostree/ostree-content-writer.c \
src/libostree/ostree-content-writer.h \
2014-04-29 16:56:05 +04:00
src/libostree/ostree-lzma-common.c \
src/libostree/ostree-lzma-common.h \
src/libostree/ostree-lzma-compressor.c \
src/libostree/ostree-lzma-compressor.h \
src/libostree/ostree-lzma-decompressor.c \
src/libostree/ostree-lzma-decompressor.h \
2015-01-30 18:13:07 +03:00
src/libostree/ostree-rollsum.h \
src/libostree/ostree-rollsum.c \
2013-08-15 17:03:21 +04:00
src/libostree/ostree-varint.h \
src/libostree/ostree-varint.c \
2014-05-30 18:02:01 +04:00
src/libostree/ostree-linuxfsutil.h \
src/libostree/ostree-linuxfsutil.c \
2012-09-01 01:49:58 +04:00
src/libostree/ostree-diff.c \
2011-12-21 22:34:10 +04:00
src/libostree/ostree-mutable-tree.c \
2017-06-07 17:27:10 +03:00
src/libostree/ostree-ref.c \
2017-04-21 18:25:23 +03:00
src/libostree/ostree-remote.c \
src/libostree/ostree-remote-private.h \
2021-03-11 04:36:13 +03:00
src/libostree/ostree-repo-os.c \
2011-11-15 00:39:38 +04:00
src/libostree/ostree-repo.c \
2013-07-10 03:02:38 +04:00
src/libostree/ostree-repo-checkout.c \
2013-09-05 23:43:07 +04:00
src/libostree/ostree-repo-commit.c \
lib: Add (private) API for checking out commits into a composefs image
This supports checking out a commit into a tree which is then
converted into a composefs image containing fs-verity digests for all
the regular files, and payloads that are relative to a the
`repo/objects` directory of a bare ostree repo.
Some specal files are always created in the image. This ensures that
various directories (usr, etc, boot, var, sysroot) exists in the
created image, even if they were not in the source commit. These are
needed (as bindmount targets) if you want to boot from the image. In
the non-composefs case these are just created as needed in the checked
out deploydir, but we can't do that here.
This is all controlled by the new ex-integrity config section, which
has the following layout:
```
[ex-integrity]
fsverity=yes/no/maybe
composefs=yes/no/maybe
composefs-apply-sig=yes/no
composefs-add-metadata=yes/no
composefs-keyfiile=/a/path
composefs-certfile=/a/path
```
The `fsverity` key overrides the old `ex-fsverity` section if
specified. The default for all these is for the new behaviour to be
disabled. Additionally, enabling composefs implies fsverity defaults
to `maybe`, to avoid having to set both.
2022-06-09 18:15:29 +03:00
src/libostree/ostree-repo-composefs.c \
2016-06-08 21:48:44 +03:00
src/libostree/ostree-repo-pull.c \
2017-11-20 15:37:24 +03:00
src/libostree/ostree-repo-pull-private.h \
2020-04-17 04:13:51 +03:00
src/libostree/ostree-repo-pull-verify.c \
2013-07-10 03:11:37 +04:00
src/libostree/ostree-repo-libarchive.c \
2013-07-10 04:05:31 +04:00
src/libostree/ostree-repo-prune.c \
2013-07-10 03:49:00 +04:00
src/libostree/ostree-repo-refs.c \
2021-01-08 00:17:01 +03:00
src/libostree/ostree-repo-verity.c \
2013-07-10 03:59:39 +04:00
src/libostree/ostree-repo-traverse.c \
2013-07-10 03:02:38 +04:00
src/libostree/ostree-repo-private.h \
2011-11-15 00:39:38 +04:00
src/libostree/ostree-repo-file.c \
src/libostree/ostree-repo-file-enumerator.c \
src/libostree/ostree-repo-file-enumerator.h \
2014-02-19 17:40:29 +04:00
src/libostree/ostree-sepolicy.c \
2017-03-23 21:29:59 +03:00
src/libostree/ostree-sepolicy-private.h \
2013-09-16 02:07:34 +04:00
src/libostree/ostree-sysroot-private.h \
2013-09-15 22:33:57 +04:00
src/libostree/ostree-sysroot.c \
2013-09-16 02:07:34 +04:00
src/libostree/ostree-sysroot-cleanup.c \
2013-09-16 04:16:20 +04:00
src/libostree/ostree-sysroot-deploy.c \
2014-03-23 16:54:28 +04:00
src/libostree/ostree-sysroot-upgrader.c \
Switch to using a systemd generator for /var
If one wants to set up a mount for `/var` in `/etc/fstab`, it
won't be mounted since `ostree-prepare-root` set up a bind mount for
`/var` to `/sysroot/ostree/$stateroot/var`, and systemd will take
the already extant mount over what's in `/etc/fstab`.
There are a few options to fix this, but what I settled on is parsing
`/etc/fstab` in a generator (exactly like `systemd-fstab-generator` does),
except here we look for an explicit mount for `/var`, and if one *isn't* found,
synthesize the default ostree mount to the stateroot. Another nice property is
that if an admin creates a `var.mount` unit in `/etc` for example, that will
also override our mount.
Note that today ostree doesn't hard depend on systemd, so this behavior only
kicks in if we're built with systemd *and* libmount support (for parsing
`/etc/fstab`). I didn't really test that case though.
Initially I started writing this as a "pure libc" program, but at one point
decided to use `libostree.so` to find the booted deployment. That didn't work
out because `/boot` wasn't necessarily mounted and hence we couldn't find the
bootloader config. A leftover artifact from this is that the generator code
calls into libostree via the "cmd private" infrastructure. But it's an easy way
to share code, and doesn't hurt.
Closes: #859
Approved by: jlebon
2017-05-11 21:54:12 +03:00
src/libostree/ostree-impl-system-generator.c \
2013-09-15 23:06:31 +04:00
src/libostree/ostree-bootconfig-parser.c \
src/libostree/ostree-deployment.c \
2013-09-16 04:26:13 +04:00
src/libostree/ostree-bootloader.h \
2013-09-16 02:07:34 +04:00
src/libostree/ostree-bootloader.c \
2022-12-13 17:12:25 +03:00
src/libostree/ostree-bootloader-aboot.h \
src/libostree/ostree-bootloader-aboot.c \
2014-10-11 16:59:06 +04:00
src/libostree/ostree-bootloader-grub2.h \
src/libostree/ostree-bootloader-grub2.c \
2019-10-14 22:22:19 +03:00
src/libostree/ostree-bootloader-zipl.h \
src/libostree/ostree-bootloader-zipl.c \
2013-09-16 02:07:34 +04:00
src/libostree/ostree-bootloader-syslinux.h \
src/libostree/ostree-bootloader-syslinux.c \
src/libostree/ostree-bootloader-uboot.h \
src/libostree/ostree-bootloader-uboot.c \
2013-08-15 17:17:37 +04:00
src/libostree/ostree-repo-static-delta-core.c \
src/libostree/ostree-repo-static-delta-processing.c \
src/libostree/ostree-repo-static-delta-compilation.c \
2015-02-11 11:29:14 +03:00
src/libostree/ostree-repo-static-delta-compilation-analysis.c \
2013-08-15 17:17:37 +04:00
src/libostree/ostree-repo-static-delta-private.h \
2016-05-12 15:42:26 +03:00
src/libostree/ostree-autocleanups.h \
Make P2P API public (no longer experimental)
Currently the API that allows P2P operations (e.g. pulling an ostree ref
from a LAN or USB source) is hidden behind the configure flag
--enable-experimental-api. This commit makes the API public and makes
that flag essentially a no-op (leaving it in place in case we want to
use it again in the future). The P2P API has been tested over the last
several months and proven to work.
This means that since we're no longer using the "experimental" feature
flag, P2P builds of Flatpak will fail when using versions of OSTree from
this commit onwards, until Flatpak is patched in the near future. If you
want to build Flatpak < 0.11.8 with P2P enabled and link against OSTree
2018.6, you'll have to patch Flatpak. However, since Flatpak won't yet
have a hard dependency on OSTree 2018.6, it needs a new way to determine
if the P2P API in OSTree is available, so this commit adds a "p2p"
feature flag. This way the feature set is more semantically correct than
if we had continued to use the "experimental" feature flag.
In addition to making the P2P API public, this commit makes the P2P unit
tests run by default, removes the f27-experimental CI instance that's no
longer needed, changes a few man pages to reflect the changes, and
updates the bash completion script to accept the new commands and
options.
Closes: #1596
Approved by: cgwalters
2018-05-23 01:55:14 +03:00
src/libostree/ostree-bloom.c \
src/libostree/ostree-bloom-private.h \
src/libostree/ostree-repo-finder.c \
src/libostree/ostree-repo-finder-avahi.c \
src/libostree/ostree-repo-finder-config.c \
src/libostree/ostree-repo-finder-mount.c \
src/libostree/ostree-repo-finder-override.c \
2019-05-28 21:02:54 +03:00
src/libostree/ostree-kernel-args.h \
2023-07-23 17:26:30 +03:00
src/libostree/ostree-kernel-args-private.h \
2019-05-28 21:02:54 +03:00
src/libostree/ostree-kernel-args.c \
2011-11-02 23:45:32 +04:00
$(NULL)
2011-12-04 21:14:08 +04:00
if USE_LIBARCHIVE
2013-07-27 03:25:07 +04:00
libostree_1_la_SOURCES += src/libostree/ostree-libarchive-input-stream.h \
2011-12-04 21:14:08 +04:00
src/libostree/ostree-libarchive-input-stream.c \
2016-12-02 21:34:32 +03:00
src/libostree/ostree-libarchive-private.h \
2011-12-04 21:14:08 +04:00
$(NULL)
endif
2014-05-01 20:55:13 +04:00
if HAVE_LIBSOUP_CLIENT_CERTS
libostree_1_la_SOURCES += \
src/libostree/ostree-tls-cert-interaction.c \
2021-10-06 19:42:56 +03:00
src/libostree/ostree-tls-cert-interaction-private.h \
2014-05-01 20:55:13 +04:00
$(NULL)
endif
2017-04-19 02:13:28 +03:00
if USE_AVAHI
libostree_1_la_SOURCES += \
src/libostree/ostree-repo-finder-avahi-parser.c \
src/libostree/ostree-repo-finder-avahi-private.h \
$(NULL)
endif # USE_AVAHI
2011-12-04 21:14:08 +04:00
2019-05-19 16:47:45 +03:00
if USE_GPGME
libostree_1_la_SOURCES += \
src/libostree/ostree-gpg-verifier.c \
src/libostree/ostree-gpg-verifier.h \
src/libostree/ostree-gpg-verify-result.c \
src/libostree/ostree-gpg-verify-result-private.h \
$(NULL)
2019-07-21 23:40:32 +03:00
else
libostree_1_la_SOURCES += \
src/libostree/ostree-gpg-verify-result-dummy.c \
$(NULL)
2019-05-19 16:47:45 +03:00
endif # USE_GPGME
2017-06-19 17:23:21 +03:00
symbol_files = $(top_srcdir)/src/libostree/libostree-released.sym
2020-11-17 13:14:16 +03:00
2021-03-11 04:36:13 +03:00
# Uncomment this include when adding new development symbols.
2023-11-13 19:33:57 +03:00
if BUILDOPT_IS_DEVEL_BUILD
2024-05-23 01:16:48 +03:00
symbol_files += $(top_srcdir)/src/libostree/libostree-devel.sym
2023-11-13 19:33:57 +03:00
endif
2020-11-17 13:14:16 +03:00
2017-06-15 04:44:04 +03:00
# http://blog.jgc.org/2007/06/escaping-comma-and-space-in-gnu-make.html
wl_versionscript_arg = -Wl,--version-script=
2017-07-12 15:58:16 +03:00
EXTRA_DIST += \
$(top_srcdir)/src/libostree/libostree-devel.sym \
$(top_srcdir)/src/libostree/libostree-released.sym \
$(NULL)
2017-06-15 04:44:04 +03:00
2024-02-15 18:15:26 +03:00
libostree_1_la_CFLAGS = $(AM_CFLAGS) -I$(srcdir)/bsdiff -I$(srcdir)/libglnx -I$(srcdir)/src/libotutil -I$(srcdir)/src/libotcore -I$(srcdir)/src/libostree -I$(builddir)/src/libostree \
2023-07-23 17:47:19 +03:00
-I$(srcdir)/src/switchroot \
2017-06-13 16:56:21 +03:00
$(OT_INTERNAL_GIO_UNIX_CFLAGS) $(OT_INTERNAL_GPGME_CFLAGS) $(OT_DEP_LZMA_CFLAGS) $(OT_DEP_ZLIB_CFLAGS) $(OT_DEP_CRYPTO_CFLAGS) \
2022-01-17 17:59:54 +03:00
-fvisibility=hidden '-D_OSTREE_PUBLIC=__attribute__((visibility("default"))) extern' \
-DPKGLIBEXECDIR=\"$(pkglibexecdir)\"
2017-06-15 04:44:04 +03:00
libostree_1_la_LDFLAGS = -version-number 1:0:0 -Bsymbolic-functions $(addprefix $(wl_versionscript_arg),$(symbol_files))
2023-07-07 23:31:58 +03:00
libostree_1_la_LIBADD = libotutil.la libotcore.la libglnx.la libbsdiff.la $(OT_INTERNAL_GIO_UNIX_LIBS) $(OT_INTERNAL_GPGME_LIBS) \
2017-06-13 16:56:21 +03:00
$(OT_DEP_LZMA_LIBS) $(OT_DEP_ZLIB_LIBS) $(OT_DEP_CRYPTO_LIBS)
2018-01-02 17:54:52 +03:00
# Some change between rust-1.21.0-1.fc27 and rust-1.22.1-1.fc27.x86_64
oxidation: Add implementation of bupsplit in Rust
This is an initial drop of "oxidation", or adding implementation
of components in Rust. The bupsplit code is a good target - no
dependencies, just computation.
Translation into Rust had a few twists -
- The C code relies a lot on overflowing unsigned ints, and
also on the C promotion rules for e.g. `uint8_t -> int32_t`
- There were some odd loops that I introduced bugs in while
translating...in particular, the function always returns `len`,
but I mistakenly translated to `len+1`, resulting in an OOB
read on the C side, which was hard to debug.
On the plus side, an off-by-one array indexing in the Rust code paniced nicely.
In practice, we'll need a lot more build infrastructure to make this work, such
as using `cargo vendor` when producing build artifacts for example. Also, Cargo
is yet another thing we need to cache.
Where do we go with this? Well, I think we should merge this, it's not a lot of
code. We can just have it be an alternative CI target. Should we do a lot more
right now? Probably not immediately, but I find the medium/long term prospects
pretty exciting!
Closes: #656
Approved by: jlebon
2017-01-25 05:43:53 +03:00
libostree_1_la_LIBADD += $(bupsplitpath)
2017-06-15 04:44:04 +03:00
EXTRA_libostree_1_la_DEPENDENCIES = $(symbol_files)
2016-06-12 12:36:44 +03:00
2011-12-04 21:14:08 +04:00
if USE_LIBARCHIVE
2013-07-27 03:25:07 +04:00
libostree_1_la_CFLAGS += $(OT_DEP_LIBARCHIVE_CFLAGS)
libostree_1_la_LIBADD += $(OT_DEP_LIBARCHIVE_LIBS)
2011-12-04 21:14:08 +04:00
endif
2011-12-19 03:37:48 +04:00
2017-04-19 02:13:28 +03:00
if USE_AVAHI
libostree_1_la_CFLAGS += $(OT_DEP_AVAHI_CFLAGS)
libostree_1_la_LIBADD += $(OT_DEP_AVAHI_LIBS)
endif
build: fix systemd feature advertisement
17db0f15a798 ("configure: add option for libsystemd") exposed
--without-libsystemd to allow systemd to be disabled even if the systemd
pkgconfig script was present, introducing a new variable
with_libsystemd; there are now three, almost identical variables:
- with_libsystemd [yes, no, maybe] - controlled by --without-libsystemd,
resolved into yes/no by the initial checks
- have_libsystemd [yes, no, <undefined>] - only set if with_libsystemd
is yes/maybe, otherwise undefined
- with_systemd [yes, <undefined>] - yes if have_systemd is yes,
otherwise undefined
with_systemd is the earliest variable and was previously set by a set of
checks for dracut and mkinitcpio. These checks were changed for a
systemd check in 9e2763106be0 ("lib: Use sd_journal directly
(optionally)"). This commit also introduced BUILDOPT_LIBSYSTEMD, which
will always match BUILDOPT_SYSTEMD.
Fix the confusion by removing with_systemd which will always be yes when
with_libsystemd=yes, or undefined if with_libsystemd=no. We can ignore
the with_libsystemd=maybe case because it will always be resolved into
yes/no before with_systemd is set.
And replace all uses of BUILDOPT_SYSTEMD with BUILDOPT_LIBSYSTEMD, since
they again always match.
This fixes both the advertised features and the summary output when
systemd is disabled by using with_libsystemd which is always defined.
Signed-off-by: Alex Kiernan <alex.kiernan@gmail.com>
Fixes: 5c62a7e4d0a5 ("build: Expose systemd in OSTREE_FEATURES")
Fixes: 17db0f15a798 ("configure: add option for libsystemd")
Supersedes: #1992
2020-01-21 15:37:52 +03:00
if BUILDOPT_SYSTEMD
2016-06-14 20:12:21 +03:00
libostree_1_la_CFLAGS += $(LIBSYSTEMD_CFLAGS)
libostree_1_la_LIBADD += $(LIBSYSTEMD_LIBS)
endif
2016-12-08 05:02:30 +03:00
if USE_CURL_OR_SOUP
2013-07-27 03:25:07 +04:00
libostree_1_la_SOURCES += \
2013-07-10 04:14:53 +04:00
src/libostree/ostree-fetcher.h \
2016-12-23 04:34:07 +03:00
src/libostree/ostree-fetcher-util.h \
src/libostree/ostree-fetcher-util.c \
2016-12-08 05:02:30 +03:00
src/libostree/ostree-fetcher-uri.c \
2014-08-01 02:50:19 +04:00
src/libostree/ostree-metalink.h \
src/libostree/ostree-metalink.c \
2013-07-10 04:14:53 +04:00
$(NULL)
2016-12-08 05:02:30 +03:00
endif
2022-02-17 22:12:18 +03:00
# Only enable one fetcher backend.
2016-12-08 05:02:30 +03:00
if USE_CURL
libostree_1_la_SOURCES += src/libostree/ostree-fetcher-curl.c \
$(NULL)
libostree_1_la_CFLAGS += $(OT_DEP_CURL_CFLAGS)
libostree_1_la_LIBADD += $(OT_DEP_CURL_LIBS)
else
2022-02-17 22:12:18 +03:00
if USE_LIBSOUP3
libostree_1_la_SOURCES += src/libostree/ostree-fetcher-soup3.c
libostree_1_la_CFLAGS += $(OT_INTERNAL_SOUP_CFLAGS)
libostree_1_la_LIBADD += $(OT_INTERNAL_SOUP_LIBS)
else
2016-12-08 05:02:30 +03:00
if USE_LIBSOUP
libostree_1_la_SOURCES += src/libostree/ostree-fetcher-soup.c
2013-07-27 03:25:07 +04:00
libostree_1_la_CFLAGS += $(OT_INTERNAL_SOUP_CFLAGS)
libostree_1_la_LIBADD += $(OT_INTERNAL_SOUP_LIBS)
endif
2016-12-08 05:02:30 +03:00
endif
2022-02-17 22:12:18 +03:00
endif
2013-07-27 03:25:07 +04:00
2016-03-21 17:37:38 +03:00
if USE_LIBMOUNT
libostree_1_la_CFLAGS += $(OT_DEP_LIBMOUNT_CFLAGS)
libostree_1_la_LIBADD += $(OT_DEP_LIBMOUNT_LIBS)
endif
2014-10-20 19:06:51 +04:00
if USE_SELINUX
libostree_1_la_CFLAGS += $(OT_DEP_SELINUX_CFLAGS)
libostree_1_la_LIBADD += $(OT_DEP_SELINUX_LIBS)
endif
2019-07-29 02:32:28 +03:00
libostree_1_la_SOURCES += \
src/libostree/ostree-sign.c \
src/libostree/ostree-sign.h \
src/libostree/ostree-sign-dummy.c \
src/libostree/ostree-sign-dummy.h \
src/libostree/ostree-sign-ed25519.c \
src/libostree/ostree-sign-ed25519.h \
2020-01-21 21:56:09 +03:00
src/libostree/ostree-sign-private.h \
2019-07-29 02:32:28 +03:00
$(NULL)
lib: Add (private) API for checking out commits into a composefs image
This supports checking out a commit into a tree which is then
converted into a composefs image containing fs-verity digests for all
the regular files, and payloads that are relative to a the
`repo/objects` directory of a bare ostree repo.
Some specal files are always created in the image. This ensures that
various directories (usr, etc, boot, var, sysroot) exists in the
created image, even if they were not in the source commit. These are
needed (as bindmount targets) if you want to boot from the image. In
the non-composefs case these are just created as needed in the checked
out deploydir, but we can't do that here.
This is all controlled by the new ex-integrity config section, which
has the following layout:
```
[ex-integrity]
fsverity=yes/no/maybe
composefs=yes/no/maybe
composefs-apply-sig=yes/no
composefs-add-metadata=yes/no
composefs-keyfiile=/a/path
composefs-certfile=/a/path
```
The `fsverity` key overrides the old `ex-fsverity` section if
specified. The default for all these is for the new behaviour to be
disabled. Additionally, enabling composefs implies fsverity defaults
to `maybe`, to avoid having to set both.
2022-06-09 18:15:29 +03:00
if USE_COMPOSEFS
2024-02-15 18:15:26 +03:00
libostree_1_la_LIBADD += $(OT_DEP_COMPOSEFS_LIBS)
lib: Add (private) API for checking out commits into a composefs image
This supports checking out a commit into a tree which is then
converted into a composefs image containing fs-verity digests for all
the regular files, and payloads that are relative to a the
`repo/objects` directory of a bare ostree repo.
Some specal files are always created in the image. This ensures that
various directories (usr, etc, boot, var, sysroot) exists in the
created image, even if they were not in the source commit. These are
needed (as bindmount targets) if you want to boot from the image. In
the non-composefs case these are just created as needed in the checked
out deploydir, but we can't do that here.
This is all controlled by the new ex-integrity config section, which
has the following layout:
```
[ex-integrity]
fsverity=yes/no/maybe
composefs=yes/no/maybe
composefs-apply-sig=yes/no
composefs-add-metadata=yes/no
composefs-keyfiile=/a/path
composefs-certfile=/a/path
```
The `fsverity` key overrides the old `ex-fsverity` section if
specified. The default for all these is for the new behaviour to be
disabled. Additionally, enabling composefs implies fsverity defaults
to `maybe`, to avoid having to set both.
2022-06-09 18:15:29 +03:00
endif # USE_COMPOSEFS
2019-06-19 20:32:00 +03:00
# XXX: work around clang being passed -fstack-clash-protection which it doesn't understand
# See: https://bugzilla.redhat.com/show_bug.cgi?id=1672012
INTROSPECTION_SCANNER_ENV = CC=gcc
2013-07-27 03:25:07 +04:00
if BUILDOPT_INTROSPECTION
OSTree-1.0.gir: libostree-1.la Makefile
OSTree_1_0_gir_EXPORT_PACKAGES = ostree-1
OSTree_1_0_gir_INCLUDES = Gio-2.0
2023-02-08 12:24:50 +03:00
OSTree_1_0_gir_C_INCLUDES = ostree.h
2013-07-27 03:25:07 +04:00
OSTree_1_0_gir_CFLAGS = $(libostree_1_la_CFLAGS)
OSTree_1_0_gir_LIBS = libostree-1.la
2017-06-27 01:12:33 +03:00
OSTree_1_0_gir_SCANNERFLAGS = --warn-all --identifier-prefix=Ostree --symbol-prefix=ostree $(GI_SCANNERFLAGS)
2023-02-08 12:24:50 +03:00
OSTree_1_0_gir_FILES = $(libostreeinclude_HEADERS) $(filter-out %.h,$(libostree_1_la_SOURCES))
2013-07-27 03:25:07 +04:00
INTROSPECTION_GIRS += OSTree-1.0.gir
gir_DATA += OSTree-1.0.gir
typelib_DATA += OSTree-1.0.typelib
2013-08-12 18:27:42 +04:00
CLEANFILES += $(gir_DATA) $(typelib_DATA)
2013-07-10 04:14:53 +04:00
endif
2013-07-27 03:25:07 +04:00
pkgconfig_DATA += src/libostree/ostree-1.pc
2013-09-03 05:43:49 +04:00
2013-09-05 22:50:36 +04:00
gpgreadme_DATA = src/libostree/README-gpg
2017-02-03 22:10:27 +03:00
gpgreadmedir = $(datadir)/ostree/trusted.gpg.d
2016-01-29 13:02:17 +03:00
EXTRA_DIST += src/libostree/README-gpg src/libostree/bupsplit.h \
src/libostree/ostree-enumtypes.h.template \
src/libostree/ostree-enumtypes.c.template \
2016-07-27 12:11:13 +03:00
src/libostree/ostree-deployment-private.h \
2017-03-10 20:33:52 +03:00
src/libostree/ostree-repo-deprecated.h \
2022-09-05 15:54:03 +03:00
src/libostree/ostree-version.h
2013-09-03 05:43:49 +04:00
2014-05-08 17:16:36 +04:00
install-mkdir-remotes-d-hook:
2014-05-09 17:06:59 +04:00
mkdir -p $(DESTDIR)$(sysconfdir)/ostree/remotes.d
2014-05-08 17:16:36 +04:00
INSTALL_DATA_HOOKS += install-mkdir-remotes-d-hook