Add explicit build rule for clockloop
[khome.git] / Makefile
index 261b5a5..ca39916 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -2,33 +2,108 @@ MAKEFLAGS := --no-builtin-rules
 
 DEPS := $(wildcard deps/*)
 
-.PHONY: home pkgs_deb_install pkgs_deb_purge pkgs deps $(DEPS) pkgs_snap_classic pkgs_snap_strict
+.PHONY: \
+    default \
+    clean \
+    $(DEPS) \
+    deps \
+    home \
+    mpdconf \
+    pkgs_brew_cask_install \
+    pkgs_brew_install \
+    pkgs_deb_install \
+    pkgs_deb_purge \
+    pkgs_debian \
+    pkgs_mac \
+    pkgs_pip \
+    pkgs_snap_classic \
+    pkgs_snap_strict
 
-home:
+default:
+       @echo '================================================================================'
+       @echo '| Default target disabled. Specify a concrete one.'
+       @echo '================================================================================'
+       @exit 1
+
+home: mpdconf compiled
+       @cp  -Rp       bin           $(HOME)/
        @cp  -Rp  home/bin           $(HOME)/
        @cp  -Rp  home/lib           $(HOME)/
        @cp       home/.compton.conf $(HOME)/
        @cp  -Rp  home/.config/      $(HOME)/
+       @cp  -Rp  home/.newsboat/    $(HOME)/
        @cp       home/.profile      $(HOME)/
        @cp       home/.fonts.conf   $(HOME)/
-       @fc-cache                    $(HOME)/.fonts
        @cp       home/.Rprofile     $(HOME)/
-       @cp       home/.mpdconf      $(HOME)/
        @cp       home/.tmux.conf    $(HOME)/
        @cp       home/.xbindkeysrc  $(HOME)/
 
-pkgs:
-       $(MAKE) pkgs_deb_install
-       $(MAKE) pkgs_deb_purge
-       $(MAKE) pkgs_snap_classic
-       $(MAKE) pkgs_snap_strict
+mpdconf:
+       @mkdir -p ~/Archives/Audio
+       @mkdir -p ~/var/lib/mpd/playlists
+       @mkdir -p ~/var/log/mpd
+       @mkdir -p ~/var/run/mpd
+       @cp home/.mpdconf $(HOME)/
+
+compiled:
+       mkdir -p bin
+       cd src && make
+       mv src/clockloop bin/
+
+font_cache:
+       @fc-cache -fv
+
+#
+# Golang
+#
+pkgs_golang: list pkgs-golang.list
+       go get $(shell ./list pkgs-golang.list)
+
+#
+# Ubuntu
+#
+pkgs_ubuntu: list pkgs-ubuntu.list
+       sudo apt install $(shell ./list pkgs-ubuntu.list)
+
+pkgs_ubuntu_debfiles: list pkgs-ubuntu-debfiles.list
+       ./install-debfiles pkgs-ubuntu-debfiles.list
+
+#
+# PIP
+#
+pkgs_pip:
+       sudo pip3 install $(shell ./list pkgs-pip.list)
 
+#
+# Homebrew/Mac
+#
+
+pkgs_mac:
+       $(MAKE) pkgs_brew_install
+       $(MAKE) pkgs_brew_cask_install
+
+# TODO: Test pkgs_brew_tap when list contains multiple items
+pkgs_brew_tap: list pkgs-brew-tap.list
+       brew tap $(shell ./list pkgs-brew-tap.list)
+
+pkgs_brew_install: list pkgs-brew-install.list
+       brew install $(shell ./list pkgs-brew-install.list)
+
+pkgs_brew_cask_install: list pkgs-brew-cask-install.list
+       brew cask install $(shell ./list pkgs-brew-cask-install.list)
+
+#
+# Debian
+#
 pkgs_deb_install: list pkgs-deb-install.list
        sudo apt install $(shell ./list pkgs-deb-install.list)
 
 pkgs_deb_purge: list pkgs-deb-purge.list
        sudo apt purge $(shell ./list pkgs-deb-purge.list)
 
+#
+# Snap
+#
 pkgs_snap_classic: list pkgs-snap-classic.list
        @$(MAKE) $(foreach p,$(shell ./list pkgs-snap-classic.list),pkg_snap_classic_$(p))
 
@@ -49,3 +124,27 @@ $(1):
 endef
 
 $(foreach d,$(DEPS),$(eval $(call GEN_DEP_RULE,$(d))))
+
+diff:
+       diff  $(HOME)/.Rprofile                           home/.Rprofile                           ||  true
+       diff  $(HOME)/.compton.conf                       home/.compton.conf                       ||  true
+       diff  $(HOME)/.config/dunst/dunstrc               home/.config/dunst/dunstrc               ||  true
+       diff  $(HOME)/.config/mimeapps.list               home/.config/mimeapps.list               ||  true
+       diff  $(HOME)/.config/neofetch/config.conf        home/.config/neofetch/config.conf        ||  true
+       diff  $(HOME)/.config/ranger/rc.conf              home/.config/ranger/rc.conf              ||  true
+       diff  $(HOME)/.config/screengrab/screengrab.conf  home/.config/screengrab/screengrab.conf  ||  true
+       diff  $(HOME)/.fonts.conf                         home/.fonts.conf                         ||  true
+       diff  $(HOME)/.mpdconf                            home/.mpdconf                            ||  true
+       diff  $(HOME)/.newsboat/config                    home/.newsboat/config                    ||  true
+       diff  $(HOME)/.profile                            home/.profile                            ||  true
+       diff  $(HOME)/.tmux.conf                          home/.tmux.conf                          ||  true
+       diff  $(HOME)/.xbindkeysrc                        home/.xbindkeysrc                        ||  true
+       diff  $(HOME)/lib/login_aliases.sh                home/lib/login_aliases.sh                ||  true
+       diff  $(HOME)/lib/login_functions.sh              home/lib/login_functions.sh              ||  true
+       diff  $(HOME)/lib/login_variables.sh              home/lib/login_variables.sh              ||  true
+       diff  $(HOME)/lib/login_variables_dpi_high.sh     home/lib/login_variables_dpi_high.sh     ||  true
+       diff  $(HOME)/lib/login_variables_dpi_norm.sh     home/lib/login_variables_dpi_norm.sh     ||  true
+
+clean:
+       rm -rf ./debfiles
+       cd src && make clean
This page took 0.033443 seconds and 4 git commands to generate.