Browse Source

further Makefile enhancements

pull/36/head
Antonio SJ Musumeci 11 years ago
parent
commit
655436f258
  1. 66
      Makefile
  2. 9
      TODO

66
Makefile

@ -21,7 +21,6 @@
# THE SOFTWARE. # THE SOFTWARE.
XATTR_AVAILABLE = $(shell test ! -e /usr/include/attr/xattr.h; echo $$?) XATTR_AVAILABLE = $(shell test ! -e /usr/include/attr/xattr.h; echo $$?)
FUSE_AVAILABLE = $(shell ! pkg-config --exists fuse; echo $$?) FUSE_AVAILABLE = $(shell ! pkg-config --exists fuse; echo $$?)
ifeq ($(FUSE_AVAILABLE),0) ifeq ($(FUSE_AVAILABLE),0)
FUSE_AVAILABLE = $(shell test ! -e /usr/include/fuse.h; echo $$?) FUSE_AVAILABLE = $(shell test ! -e /usr/include/fuse.h; echo $$?)
@ -31,41 +30,84 @@ ifeq ($(FUSE_AVAILABLE),0)
$(error "FUSE development package doesn't appear available") $(error "FUSE development package doesn't appear available")
endif endif
PKGCONFIG = $(shell which pkg-config)
GIT = $(shell which git)
TAR = $(shell which tar)
MKDIR = $(shell which mkdir)
TOUCH = $(shell which touch)
CP = $(shell which cp)
RM = $(shell which rm)
FIND = $(shell which find)
INSTALL = $(shell which install)
MKTEMP = $(shell which mktemp)
STRIP = $(shell which strip)
SRC = $(wildcard src/*.cpp) SRC = $(wildcard src/*.cpp)
OBJ = $(SRC:src/%.cpp=obj/%.o) OBJ = $(SRC:src/%.cpp=obj/%.o)
DEPS = $(OBJ:obj/%.o=obj/%.d) DEPS = $(OBJ:obj/%.o=obj/%.d)
TARGET = mergerfs TARGET = mergerfs
CFLAGS = -g -Wall \ CFLAGS = -g -Wall \
$(shell pkg-config fuse --cflags) \ $(shell $(PKGCONFIG) fuse --cflags) \
-DFUSE_USE_VERSION=26 \ -DFUSE_USE_VERSION=26 \
-MMD -MMD
LDFLAGS = $(shell pkg-config fuse --libs) LDFLAGS = $(shell $(PKGCONFIG) fuse --libs)
BINDIR = $(PREFIX)/usr/bin
MANDIR = $(PREFIX)/share/man/man1
INSTALLPATH = $(DESTDIR)/$(BINDIR)
INSTALLTARGET = $(INSTALLPATH)/$(TARGET)
ifeq ($(XATTR_AVAILABLE),0) ifeq ($(XATTR_AVAILABLE),0)
CFLAGS += -DWITHOUT_XATTR CFLAGS += -DWITHOUT_XATTR
endif endif
all: $(TARGET) all: $(TARGET)
help: help:
@echo usage: make @echo "usage: make"
@echo make XATTR_AVAILABLE=0 - to build program without xattrs functionality (auto discovered otherwise) @echo "make XATTR_AVAILABLE=0 - to build program without xattrs functionality (auto discovered otherwise)"
$(TARGET): obj/obj-stamp $(OBJ) $(TARGET): changelog obj/obj-stamp $(OBJ)
$(CXX) $(CFLAGS) $(OBJ) -o $@ $(LDFLAGS) $(CXX) $(CFLAGS) $(OBJ) -o $@ $(LDFLAGS)
changelog:
$(GIT) log --pretty --numstat --summary | git2cl > ChangeLog
obj/obj-stamp: obj/obj-stamp:
mkdir -p obj $(MKDIR) -p obj
touch $@ $(TOUCH) $@
obj/%.o: src/%.cpp obj/%.o: src/%.cpp
$(CXX) $(CFLAGS) -c $< -o $@ $(CXX) $(CFLAGS) -c $< -o $@
clean: clean:
rm -rf obj "$(TARGET)" $(RM) -rf obj "$(TARGET)"
find -name "*~" -delete $(FIND) -name "*~" -delete
distclean: clean
$(GIT) clean -ifd
install: $(TARGET)
$(INSTALL) -m 0755 -D "$(TARGET)" "$(INSTALLTARGET)"
install-strip: install
$(STRIP) "$(INSTALLTARGET)"
uninstall:
$(RM) "$(INSTALLTARGET)"
tarball: distclean
$(eval VERSION := $(shell $(GIT) describe --always --tags --dirty))
$(eval FILENAME := $(TARGET)-$(VERSION))
$(eval TMPDIR := $(shell $(MKTEMP) --tmpdir -d .$(FILENAME).XXXXXXXX))
$(MKDIR) $(TMPDIR)/$(FILENAME)
$(CP) -ar . $(TMPDIR)/$(FILENAME)
$(TAR) --exclude=.git -cz -C $(TMPDIR) -f ../$(FILENAME).tar.gz $(FILENAME)
$(RM) -rf $(TMPDIR)
deb:
$(GIT) buildpackage
.PHONY: all clean help .PHONY: all clean install help
include $(wildcard obj/*.d) include $(wildcard obj/*.d)

9
TODO

@ -1,9 +0,0 @@
* logging
* dynamic changing of source mounts
* policies for readdir
* first found
* all found
* all found w/ permission
* newest
* unit tests
* add more to ioctl
|||||||
100:0
Loading…
Cancel
Save