e83b51b4f6
Filters can now call hook_write and unhook_write if they want to redirect writing to stdout to a different function. This saves us from potential file descriptor pipes and other less efficient mechanisms. We do this instead of replacing the call in html_raw because some places stdlib's printf functions are used (ui-patch or within git itself), which has its own internal buffering, which makes it difficult to interlace our function calls. So, we dlsym libc's write and then override it in the link stage. While we're at it, we move considerations of argument count into the generic new filter handler. Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
93 lines
3 KiB
Makefile
93 lines
3 KiB
Makefile
# This Makefile is run in the "git" directory in order to re-use Git's
|
|
# build variables and operating system detection. Hence all files in
|
|
# CGit's directory must be prefixed with "../".
|
|
include Makefile
|
|
|
|
CGIT_PREFIX = ../
|
|
|
|
-include $(CGIT_PREFIX)cgit.conf
|
|
|
|
# The CGIT_* variables are inherited when this file is called from the
|
|
# main Makefile - they are defined there.
|
|
|
|
$(CGIT_PREFIX)VERSION: force-version
|
|
@cd $(CGIT_PREFIX) && '$(SHELL_PATH_SQ)' ./gen-version.sh "$(CGIT_VERSION)"
|
|
-include $(CGIT_PREFIX)VERSION
|
|
.PHONY: force-version
|
|
|
|
# CGIT_CFLAGS is a separate variable so that we can track it separately
|
|
# and avoid rebuilding all of Git when these variables change.
|
|
CGIT_CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"'
|
|
CGIT_CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"'
|
|
CGIT_CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"'
|
|
|
|
ifdef NO_C99_FORMAT
|
|
CFLAGS += -DNO_C99_FORMAT
|
|
endif
|
|
|
|
CGIT_OBJ_NAMES += cgit.o
|
|
CGIT_OBJ_NAMES += cache.o
|
|
CGIT_OBJ_NAMES += cmd.o
|
|
CGIT_OBJ_NAMES += configfile.o
|
|
CGIT_OBJ_NAMES += filter.o
|
|
CGIT_OBJ_NAMES += html.o
|
|
CGIT_OBJ_NAMES += parsing.o
|
|
CGIT_OBJ_NAMES += scan-tree.o
|
|
CGIT_OBJ_NAMES += shared.o
|
|
CGIT_OBJ_NAMES += ui-atom.o
|
|
CGIT_OBJ_NAMES += ui-blob.o
|
|
CGIT_OBJ_NAMES += ui-clone.o
|
|
CGIT_OBJ_NAMES += ui-commit.o
|
|
CGIT_OBJ_NAMES += ui-diff.o
|
|
CGIT_OBJ_NAMES += ui-log.o
|
|
CGIT_OBJ_NAMES += ui-patch.o
|
|
CGIT_OBJ_NAMES += ui-plain.o
|
|
CGIT_OBJ_NAMES += ui-refs.o
|
|
CGIT_OBJ_NAMES += ui-repolist.o
|
|
CGIT_OBJ_NAMES += ui-shared.o
|
|
CGIT_OBJ_NAMES += ui-snapshot.o
|
|
CGIT_OBJ_NAMES += ui-ssdiff.o
|
|
CGIT_OBJ_NAMES += ui-stats.o
|
|
CGIT_OBJ_NAMES += ui-summary.o
|
|
CGIT_OBJ_NAMES += ui-tag.o
|
|
CGIT_OBJ_NAMES += ui-tree.o
|
|
|
|
CGIT_OBJS := $(addprefix $(CGIT_PREFIX),$(CGIT_OBJ_NAMES))
|
|
|
|
# Only cgit.c reference CGIT_VERSION so we only rebuild its objects when the
|
|
# version changes.
|
|
CGIT_VERSION_OBJS := $(addprefix $(CGIT_PREFIX),cgit.o)
|
|
$(CGIT_VERSION_OBJS): $(CGIT_PREFIX)VERSION
|
|
$(CGIT_VERSION_OBJS): EXTRA_CPPFLAGS = \
|
|
-DCGIT_VERSION='"$(CGIT_VERSION)"'
|
|
|
|
CGIT_LIBS += -ldl
|
|
|
|
|
|
# Git handles dependencies using ":=" so dependencies in CGIT_OBJ are not
|
|
# handled by that and we must handle them ourselves.
|
|
cgit_dep_files := $(foreach f,$(CGIT_OBJS),$(dir $f).depend/$(notdir $f).d)
|
|
cgit_dep_files_present := $(wildcard $(cgit_dep_files))
|
|
ifneq ($(cgit_dep_files_present),)
|
|
include $(cgit_dep_files_present)
|
|
endif
|
|
|
|
ifeq ($(wildcard $(CGIT_PREFIX).depend),)
|
|
missing_dep_dirs += $(CGIT_PREFIX).depend
|
|
endif
|
|
|
|
$(CGIT_PREFIX).depend:
|
|
@mkdir -p $@
|
|
|
|
$(CGIT_PREFIX)CGIT-CFLAGS: FORCE
|
|
@FLAGS='$(subst ','\'',$(CGIT_CFLAGS))'; \
|
|
if test x"$$FLAGS" != x"`cat ../CGIT-CFLAGS 2>/dev/null`" ; then \
|
|
echo 1>&2 " * new CGit build flags"; \
|
|
echo "$$FLAGS" >$(CGIT_PREFIX)CGIT-CFLAGS; \
|
|
fi
|
|
|
|
$(CGIT_OBJS): %.o: %.c GIT-CFLAGS $(CGIT_PREFIX)CGIT-CFLAGS $(missing_dep_dirs)
|
|
$(QUIET_CC)$(CC) -o $*.o -c $(dep_args) $(ALL_CFLAGS) $(EXTRA_CPPFLAGS) $(CGIT_CFLAGS) $<
|
|
|
|
$(CGIT_PREFIX)cgit: $(CGIT_OBJS) GIT-LDFLAGS $(GITLIBS)
|
|
$(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) $(CGIT_LIBS)
|