X-Git-Url: https://uglyman.kremlin.cc/gitweb/gitweb.cgi?p=systembsd.git;a=blobdiff_plain;f=Makefile;h=48d3b873b75a87df6219b8c18fa5c301e77a3a21;hp=b80240374cee4930253d07e96a2f3d72c9a3e305;hb=89048d5b9f63b1fbc3d1520221500ed139dbc28b;hpb=9ce456700bab1a39ee3aa7f95bd7a2f9505d91ec diff --git a/Makefile b/Makefile index b802403..48d3b87 100644 --- a/Makefile +++ b/Makefile @@ -1,34 +1,65 @@ .PHONY: all -CC=/usr/bin/cc -CFLAGS=-Wall -Wextra -Werror -std=c89 -DEBUGF=-O0 -g - -LINKGN=bin/obj/hostnamed-gen.o bin/obj/localed-gen.o bin/obj/timedated-gen.o bin/obj/logind-gen.o -LINKHN=bin/systemd-hostnamed bin/systemd-localed bin/systemd-timedated bin/systemd-logind - -GLIBEF=`pkg-config --cflags --libs glib-2.0 gobject-2.0 gio-2.0 gio-unix-2.0` -GLIBOF=`pkg-config --cflags glib-2.0 gobject-2.0 gio-2.0 gio-unix-2.0` - -SANITY=-Wno-unused-variable -Wno-unused-parameter # -Wno-comment - -PREFIX=/usr/local -SYSCONFDIR=/etc -SRCDIR=src -INTFDIR=$(SRCDIR)/interfaces - -DBUS_POLICYDIR=$(SYSCONFDIR)/dbus-1/system.d -DBUS_CONFIGDIR=$(PREFIX)/share/dbus-1/system-services - -INVOKE_GENFILE_SCRIPT=./scripts/gen-gdbus-interfaces.sh +CC?= /usr/bin/cc +CFLAGS= -Wall -Wextra -Werror -std=c89 + +DEBUG= 1 +.ifdef DEBUG +CFLAGS+= -O0 -g +.endif + +SANITY= 1 +.ifdef SANITY +CFLAGS+= -Wno-unused-variable -Wno-unused-parameter # -Wno-comment +.endif + +PREFIX?= /usr/local +BINDIR= $(PREFIX)/libexec +SYSCONFDIR?= /etc + +INSTALL_PROGRAM= install -c -s -o root -g bin -m 555 +INSTALL_PROGRAM_DIR= install -d -o root -g bin -m 755 +INSTALL_DATA= install -c -o root -g bin -m 444 +INSTALL_DATA_DIR= install -d -o root -g bin -m 755 + +LINKGN= bin/obj/hostnamed-gen.o \ + bin/obj/localed-gen.o \ + bin/obj/timedated-gen.o \ + bin/obj/logind-gen.o + +LINKHN= bin/systemd-hostnamed \ + bin/systemd-localed \ + bin/systemd-timedated \ + bin/systemd-logind + +DBUS_SERVICES= org.freedesktop.hostname1.service \ + org.freedesktop.locale1.service \ + org.freedesktop.login1.service \ + org.freedesktop.timedate1.service + +GLIBEF=`pkg-config --cflags --libs glib-2.0 gobject-2.0 gio-2.0 gio-unix-2.0 polkit-agent-1` +GLIBOF=`pkg-config --cflags glib-2.0 gobject-2.0 gio-2.0 gio-unix-2.0 polkit-agent-1` + +SRCDIR= src +CONFDIR= conf +POLICYDIR= $(CONFDIR)/sysbus-policy +ISPECTDIR= $(CONFDIR)/introspect-xml +SERVICEFDIR= $(CONFDIR)/service-files +POLKITDIR= $(CONFDIR)/polkit-policy + +INTFDIR= $(SRCDIR)/interfaces + +DBUS_POLICYDIR= $(SYSCONFDIR)/dbus-1/system.d +DBUS_CONFIGDIR= $(PREFIX)/share/dbus-1/system-services +POLKIT_POLICYDIR= $(PREFIX)/share/polkit-1/actions + +INVOKE_GENFILE_SCRIPT= \ + ./scripts/gen-gdbus-interfaces.sh all: build -build: _build_interface_objs_debug - $(CC) -o bin/out.bin $(DEBUGF) $(GLIBEF) $(SANITY) $(SRCDIR)/main.c - -publish: _build_interface_objs - $(CC) -o bin/out.bin $(CFLAGS) $(GLIBEF) $(SANITY) $(SRCDIR)/main.c +build: _build_interface_objs + $(CC) -o bin/out.bin $(CFLAGS) $(GLIBEF) $(SRCDIR)/main.c clean: find ./bin -type f -exec rm {} \; @@ -37,28 +68,16 @@ clean: install: _install_conf _install_interface_binaries _build_interface_objs: _build_genfile_objs - $(CC) -o bin/systemd-hostnamed $(CFLAGS) $(GLIBEF) $(SANITY) $(INTFDIR)/hostnamed/hostnamed.c bin/obj/hostnamed-gen.o - $(CC) -o bin/systemd-localed $(CFLAGS) $(GLIBEF) $(SANITY) $(INTFDIR)/localed/localed.c bin/obj/localed-gen.o - $(CC) -o bin/systemd-timedated $(CFLAGS) $(GLIBEF) $(SANITY) $(INTFDIR)/timedated/timedated.c bin/obj/timedated-gen.o - $(CC) -o bin/systemd-logind $(CFLAGS) $(GLIBEF) $(SANITY) $(INTFDIR)/logind/logind.c bin/obj/logind-gen.o - -_build_interface_objs_debug: _build_genfile_objs_debug - $(CC) -o bin/systemd-hostnamed $(DEBUGF) $(GLIBEF) $(SANITY) $(INTFDIR)/hostnamed/hostnamed.c bin/obj/hostnamed-gen.o - $(CC) -o bin/systemd-localed $(DEBUGF) $(GLIBEF) $(SANITY) $(INTFDIR)/localed/localed.c bin/obj/localed-gen.o - $(CC) -o bin/systemd-timedated $(DEBUGF) $(GLIBEF) $(SANITY) $(INTFDIR)/timedated/timedated.c bin/obj/timedated-gen.o - $(CC) -o bin/systemd-logind $(DEBUGF) $(GLIBEF) $(SANITY) $(INTFDIR)/logind/logind.c bin/obj/logind-gen.o + $(CC) -o bin/systemd-hostnamed $(CFLAGS) $(GLIBEF) $(INTFDIR)/hostnamed/hostnamed.c bin/obj/hostnamed-gen.o + $(CC) -o bin/systemd-localed $(CFLAGS) $(GLIBEF) $(INTFDIR)/localed/localed.c bin/obj/localed-gen.o + $(CC) -o bin/systemd-timedated $(CFLAGS) $(GLIBEF) $(INTFDIR)/timedated/timedated.c bin/obj/timedated-gen.o + $(CC) -o bin/systemd-logind $(CFLAGS) $(GLIBEF) $(INTFDIR)/logind/logind.c bin/obj/logind-gen.o _build_genfile_objs: _generate_genfiles - $(CC) -o bin/obj/hostnamed-gen.o $(CFLAGS) $(GLIBOF) $(SANITY) -c $(INTFDIR)/hostnamed/hostnamed-gen.c - $(CC) -o bin/obj/localed-gen.o $(CFLAGS) $(GLIBOF) $(SANITY) -c $(INTFDIR)/localed/localed-gen.c - $(CC) -o bin/obj/timedated-gen.o $(CFLAGS) $(GLIBOF) $(SANITY) -c $(INTFDIR)/timedated/timedated-gen.c - $(CC) -o bin/obj/logind-gen.o $(CFLAGS) $(GLIBOF) $(SANITY) -c $(INTFDIR)/logind/logind-gen.c - -_build_genfile_objs_debug: _generate_genfiles - $(CC) -o bin/obj/hostnamed-gen.o $(DEBUGF) $(GLIBOF) $(SANITY) -c $(INTFDIR)/hostnamed/hostnamed-gen.c - $(CC) -o bin/obj/localed-gen.o $(DEBUGF) $(GLIBOF) $(SANITY) -c $(INTFDIR)/localed/localed-gen.c - $(CC) -o bin/obj/timedated-gen.o $(DEBUGF) $(GLIBOF) $(SANITY) -c $(INTFDIR)/timedated/timedated-gen.c - $(CC) -o bin/obj/logind-gen.o $(DEBUGF) $(GLIBOF) $(SANITY) -c $(INTFDIR)/logind/logind-gen.c + $(CC) -o bin/obj/hostnamed-gen.o $(CFLAGS) $(GLIBOF) -c $(INTFDIR)/hostnamed/hostnamed-gen.c + $(CC) -o bin/obj/localed-gen.o $(CFLAGS) $(GLIBOF) -c $(INTFDIR)/localed/localed-gen.c + $(CC) -o bin/obj/timedated-gen.o $(CFLAGS) $(GLIBOF) -c $(INTFDIR)/timedated/timedated-gen.c + $(CC) -o bin/obj/logind-gen.o $(CFLAGS) $(GLIBOF) -c $(INTFDIR)/logind/logind-gen.c _generate_genfiles: $(INVOKE_GENFILE_SCRIPT) hostnamed @@ -66,11 +85,20 @@ _generate_genfiles: $(INVOKE_GENFILE_SCRIPT) timedated $(INVOKE_GENFILE_SCRIPT) logind -_install_conf: - cp conf/*-dbus.conf $(DBUS_POLICYDIR)/ - cp conf/org.freedesktop.*.service $(DBUS_CONFIGDIR)/ - cp conf/systemd_compat.conf $(SYSCONFDIR)/ +_generate_servicefiles: + for svc in $(DBUS_SERVICES); do \ + sed -e 's,@BINDIR@,${BINDIR},' $(SERVICEFDIR)/$$svc.in > $(SERVICEFDIR)/$$svc; \ + done + +_install_conf: _generate_servicefiles + ${INSTALL_DATA_DIR} $(DESTDIR)$(DBUS_POLICYDIR) + ${INSTALL_DATA_DIR} $(DESTDIR)$(DBUS_CONFIGDIR) + ${INSTALL_DATA_DIR} $(DESTDIR)$(SYSCONFDIR) + ${INSTALL_DATA} $(POLICYDIR)/*-dbus.conf $(DESTDIR)$(DBUS_POLICYDIR)/ + ${INSTALL_DATA} $(SERVICEFDIR)/*.service $(DESTDIR)$(DBUS_CONFIGDIR)/ + ${INSTALL_DATA} $(CONFDIR)/systemd_compat.conf $(DESTDIR)$(SYSCONFDIR)/ + ${INSTALL_DATA} $(POLKITDIR)/*.policy $(DESTDIR)$(POLKIT_POLICYDIR)/ _install_interface_binaries: $(LINKHN) - mkdir $(PREFIX)/bin/systemd-compat - cp bin/systemd-* $(PREFIX)/bin/systemd-compat/ + ${INSTALL_PROGRAM_DIR} $(DESTDIR)$(BINDIR) + ${INSTALL_PROGRAM} bin/systemd-* $(DESTDIR)$(BINDIR)/