Add work-around for PATH. Under Windows find.exe going in collision with
Cygwin and %WINDIR%/sysem32.
SHELL = /bin/sh
export PATH := /bin:/usr/bin:${PATH}
.PHONY: all
all:
ifeq '' '$(HOME)'
$(error HOME env var not set!)
endif
host_os = linux
ifneq '' '$(COMSPEC)'
host_os = windows
endif
OVERRIDDEN_ITEMS = \
.inputrc .minttyrc .Xdefaults .xinitrc .xserverrc .screenrc \
.bashrc .vimrc .ssh \
.mailsign .tidy \
.hgrc .hgignore .bazaar .gitconfig .gitignore \
.gnupg
MANUALINSTALL_ITEMS = .mc
IFNONEXIST_ITEMS = .wgetrc .subversion
.PHONY: install
install:
for item in $(OVERRIDDEN_ITEMS); do \
if [ -f $$item ]; then \
install -m 640 $$item $(HOME)/$$item; \
fi; \
if [ -d $$item ]; then \
for file in `find $$item`; do \
if [ -d $$file ]; then \
mkdir -p $(HOME)/$$file; \
continue; \
fi; \
install -m 640 $$file $(HOME)/$$file; \
done; \
fi; \
done
for item in $(IFNONEXIST_ITEMS); do \
if [ -f $$item -a ! -f $(HOME)/$$item ]; then \
install -m 640 $$item $(HOME)/$$item; \
fi; \
if [ -d $$item ]; then \
for file in `find $$item`; do \
if [ -d $$file ]; then \
mkdir -p $(HOME)/$$file; \
continue; \
fi; \
if [ ! -f $(HOME)/$$file ]; then \
install -m 640 $$file $(HOME)/$$file; \
fi; \
done; \
fi; \
done
mkdir -p $(HOME)/.mc
install -m 640 .mc/bashrc $(HOME)/.mc
ifeq '$(host_os)' 'windows'
install -m 640 .mc/bindings.cygwin $(HOME)/.mc/bindings
else
install -m 640 .mc/bindings $(HOME)/.mc/bindings
endif
.PHONY: uninstall
uninstall:
for item in $(OVERRIDDEN_ITEMS); do \
if [ -f $$item ]; then \
[ -f $(HOME)/$$file ] && rm -f $(HOME)/$$item; \
fi; \
if [ -d $$item ]; then \
for file in `find $$item -depth`; do \
if [ -d $$file ]; then \
rmdir $(HOME)/$$file || :; \
continue; \
fi; \
[ -f $(HOME)/$$file ] && rm $(HOME)/$$file; \
done; \
fi; \
done
rm -f $(HOME)/.mc/bashrc $(HOME)/.mc/ini $(HOME)/.mc/bindings
rmdir $(HOME)/.mc || :
.PHONY: clean
clean:
.PHONY: distclean
distclean: clean