EOS_GIT_BACKUPSITE=/net/fs08/fs08/DataBase/EosBackup.git
EOS_GIT_REPOSITRY= git.sourceforge.jp:/gitroot/eos/base.git 
EOS_GIT_REPOSITRY_NOUSER=git://git.sourceforge.jp/gitroot/eos/base.git
EOS_GIT_REPOSITRY_OPTIONAL= git.sourceforge.jp:/gitroot/eos/optional.git 
EOS_GIT_REPOSITRY_OPTIONAL_NOUSER=git://git.sourceforge.jp/gitroot/eos/optional.git
EOS_GIT_REPOSITRY_TUTORIAL= git.sourceforge.jp:/gitroot/eos/tutorial.git 
EOS_GIT_REPOSITRY_TUTORILA_NOUSER=git://git.sourceforge.jp/gitroot/eos/tutorial.git
EOS_GIT_REPOSITRY_DATA= git.sourceforge.jp:/gitroot/eos/data.git 
EOS_GIT_REPOSITRY_DATA_NOUSER=git://git.sourceforge.jp/gitroot/eos/data.git
EOS_GIT_REPOSITRY_OTHERS= git.sourceforge.jp:/gitroot/eos/others.git 
EOS_GIT_REPOSITRY_OTHRES_NOUSER=git://git.sourceforge.jp/gitroot/eos/others.git


help::
	@echo ">> Help"
	@echo ">>>> Download"
	@echo "---- To register new/Modified source codes. ----"
	@echo " $$ make git-add         or git-add[-all|-data|-tutorial|-optional|-others|-others2]" 
	@echo " $$ make git-commit      or git-commit[-all|-data|-tutorial|-optional|-others|-others2]" 
	@echo " $$ git tag " 
	@echo " $$ git tag newtag "
	@echo " $$ make git-push        or git-push[-all|-data|-tutorial|-optional|-others]" 
	@echo ""
	@echo "---- To fetch and merge new/modified source codes. ----" 
	@echo " $$ make git-fetch       or git-fetch[-all|-data|-tutorial|-optional|-others]" 
	@echo " $$ make git-merge       or git-merge[-all|-data|-tutorial|-optional|-others]" 
	@echo " $$ make setting"
	@echo "---- To init git repository ----"
	@echo " $$ make git-init        or git-init[-all|-data|-tutorial|-optional|-others]" 
	@echo "---- To clonse git repository ----"
	@echo " $$ make git-clone or git-clone[-all|-data|-tutorial|-optional|-others]" 
	@echo "---- option ----"
	@echo "     [] : base only"
	@echo "     [-data]     : data (for test)"
	@echo "     [-tutorial] : tutorial"
	@echo "     [-optional] : optional(for documents)"
	@echo "     [-others] : other source codes for utils"
	@echo "     [-others2] : other source codes for utils"
	@echo "     [-all] : all"
	@echo ""
	@echo ">>>> Setting"
	@echo "---- To set Eos ----"
	@echo " $$ make setting ; # Create links."
	@echo " $$ make install ; # No clean, just install."
	@echo " $$ make rebuild ; # Clean and install."
	@echo ""
	@echo ">>>> Rebuild"
	@echo "---- To rebuild source codes of Eos ----"
	@echo " $$ make rebuild"
	@echo "---- To set Eos ----"
	@echo " $$ make setting"
	@echo ""
	@echo ">>>> Setting for Eos utils using other softwares "
	@echo "---- To set Eos ----"
	@echo " $$ cd util; make setting"
	@echo " $$ cd util; make rebuild"



rebuild: rebuild-src rebuild-Objects rebuild-Tools
install: install-src install-Objects install-Tools

rebuild-src:
	echo "rebuild-src"
	cd src; rm -f Objects/Makefile; cp -f Config/Template/ObjectsHomeTemplate.Dir/Makefile Objects/Makefile; rm -f Objects/Config/Target.inc; cp -f Config/Template/ObjectsHomeTemplate.Dir/Config/Target.inc Objects/Config/Target.inc
	cd src; rm -f Tools/Makefile; cp -f Config/Template/ToolsHomeTemplate.Dir/Makefile Tools/Makefile; rm -f Tools/Config/Target.inc ; cp -f Config/Template/ToolsHomeTemplate.Dir/Config/Target.inc Tools/Config/Target.inc

rebuild-Objects:
	cd src/Objects;  make clean; make check; make depend; make ; make install

rebuild-Tools:
	cd src/Tools;    make clean; make check; make depend; make ; make install

install-src:
	echo "rebuild-src"
	cd src; rm -f Objects/Makefile; cp -f Config/Template/ObjectsHomeTemplate.Dir/Makefile Objects/Makefile
	cd src; rm -f Tools/Makefile; cp -f Config/Template/ToolsHomeTemplate.Dir/Makefile Tools/Makefile

install-Objects:
	cd src/Objects;  make check; make depend; make ; make install

install-Tools:
	cd src/Tools;    make check; make depend; make ; make install

setting:relink

relink:
	ln -sf optional/doc .
	ln -sf optional/objects .
	ln -sf data/example .

git-add-all:: git-add git-add-data git-add-optional git-add-tutorial git-add-others

git-add::
	git add -v --all .

git-add-optional::
	cd optional; git add -v --all . 

git-add-data::
	cd data; git add -v --all . 

git-add-tutorial::
	cd tutorial; git add -v --all . 

git-add-others::
	cd others; git add -v --all . 

git-add-others2::
	cd others2; git add --all . 

git-commit-all:: git-commit git-commit-data git-commit-optional git-commit-tutorial git-commit-others

git-commit::
	git commit 

git-commit-optional::
	cd optional; git commit  

git-commit-data::
	cd data; git commit 

git-commit-tutorial::
	cd tutorial; git commit 

git-commit-others::
	cd others; git commit 

git-commit-others2::
	cd others2; git commit 

git-backup::
	git push $(EOS_GIT_BACKUPSITE) master  --tags

git-tag::
	@export DIRECTORYNAME=./; \
	make git-tag-common;

git-tag-optional::
	@export DIRECTORYNAME=optional; \
	make git-tag-common;

git-tag-data::
	@export DIRECTORYNAME=data; \
	make git-tag-common;

git-tag-tutorial::
	@export DIRECTORYNAME=tutorial; \
	make git-tag-common;

git-tag-others::
	@export DIRECTORYNAME=others; \
	make git-tag-common;

git-tag-common::
	@if [ ! -z "$$DIRECTORYNAME" ]; then \
		cd $$DIRECTORYNAME; \
		echo; \
		git tag | sort -k 2,2 -n -t p ; \
		echo "Version No. (e.g. vXX.YY.ZZpSSSS)"; \
		read TTT; \
		if [ ! -z "$$TTT" ]; then \
			git tag $$TTT; \
		else \
			echo "Incorrect."; \
		fi; \
	fi;

git-push-all:: git-push git-push-data git-push-optional git-push-tutorial git-push-others

git-push::
#	git push origin master  --tags
	@export DIRECTORYNAME=./; \
	export ORIGINNAME=origin; \
	make git-push-with-check;

git-push-optional::
#	cd optional; git push optional master --tags
	@export DIRECTORYNAME=optional; \
	export ORIGINNAME=optional; \
	make git-push-with-check;

git-push-data::
#	cd data; git push data master --tags
	@export DIRECTORYNAME=data; \
	export ORIGINNAME=data; \
	make git-push-with-check;

git-push-tutorial::
#	cd tutorial; git push tutorial master --tags
	@export DIRECTORYNAME=tutorial; \
	export ORIGINNAME=tutorial; \
	make git-push-with-check;

git-push-others::
#	cd others; git push others master --tags
	@export DIRECTORYNAME=others; \
	export ORIGINNAME=others; \
	make git-push-with-check;

git-push-with-check::
	@if [ ! -z "$$DIRECTORYNAME" -a ! -z "$$ORIGINNAME" ]; then \
		cd $$DIRECTORYNAME; \
		echo; \
		SSS=`git tag | sort -k 2,2 -n -t p | tail -1`; \
		if [ ! -z "$$SSS" ]; then \
			echo "$$SSS is Current Tags in $$ORIGINNAME."; \
			echo "Did Tag update? Y(: push) | N(or Otherwords : not push)"; \
			read TTT; \
			if [ "$$TTT" = Y ]; then \
				git push $$ORIGINNAME master --tags; \
			else \
				echo "not push."; \
			fi; \
		else \
			echo "Tags do not exist in $$ORIGINNAME."; \
			echo "Before push please add tag at current repositry."; \
		fi; \
	fi;

git-fetch-all:: git-fetch git-fetch-data git-fetch-optional git-fetch-tutorial git-fetch-others

git-fetch::
	cd .       ; git fetch origin master --tags 	; git log -1

git-fetch-data::
	cd data    ; git fetch data master --tags		; git log -1

git-fetch-optional::
	cd optional; git fetch optional master --tags	; git log -1

git-fetch-tutorial::
	cd tutorial; git fetch tutorial master --tags	; git log -1

git-fetch-others::
	cd others  ; git fetch others master --tags		; git log -1

git-merge-all:: git-merge git-merge-data git-merge-optional git-merge-tutorial git-merge-others

git-merge::
	cd .       ; git log -1; git merge FETCH_HEAD 

git-merge-data::
	cd data    ; git log -1; git merge FETCH_HEAD 

git-merge-optional::
	cd optional; git log -1; git merge FETCH_HEAD

git-merge-tutorial::
	cd tutorial; git log -1; git merge FETCH_HEAD 

git-merge-others::
	cd others  ; git log -1; git merge FETCH_HEAD 

#
# Nickname 
#

git-init-all:: git-init git-init-data git-init-optional git-init-tutorial git-init-others

git-init::
	if [ ! -d .git ] ; then git init	; fi
	SSS=`git remote -v | grep origin`; if [ ! -z "$$SSS" ] ; then git remote rm origin ; fi ; \
	git remote add origin    $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY)

git-init-data::
	if [ ! -d data ] ; then mkdir data; fi
	cd data; SSS=`git remote -v | grep data`; if [ ! -z "$$SSS" ] ; then git remote rm data ; fi ; \
	git remote add data      $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY_DATA)

git-init-optional::
	if [ ! -d optional ] ; then mkdir optional; fi
	if [ ! -L doc      ] ; then ln -sf optional/doc . ; fi
	if [ ! -L objects  ] ; then ln -sf optional/objects . ; fi
	cd optional; SSS=`git remote -v | grep optional`; if [ ! -z "$$SSS" ] ; then git remote rm optional ; fi ; \
	git remote add optional  $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY_OPTIONAL)

git-init-tutorial::
	if [ ! -d tutorial ] ; then mkdir tutorial ; fi
	cd tutorial; SSS=`git remote -v | grep tutorial`; if [ ! -z "$$SSS" ] ; then git remote rm tutorial ; fi ; \
	git remote add tutorial  $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY_TUTORIAL)

git-init-others::
	if [ ! -d others ] ; then mkdir others; fi
	cd others ; SSS=`git remote -v | grep others`; if [ ! -z "$$SSS" ] ; then git remote rm others ; fi ; \
	git remote add others $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY_OTHERS)

git-init-others2::
	if [ ! -d others2 ] ; then mkdir others2; fi
	cd others2 ; git remote add others2 $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY_OTHERS)

git-clone-all:: git-clone git-clone-data git-clone-optional git-clone-tutorial git-clone-others

git-clone:git-init
	if [ ! -d  .git ] ; \
	then \
		if [ -z $${EOS_GITUSER} ] ; then \
			git clone --depth 1 $(EOS_GIT_REPOSITRY_NOUSER) ./ ; \
		else \
			git clone --depth 1 $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY) ./ ; \
		fi ; \
	fi

git-clone-data: git-init-data
	cd data;  if [ ! -d .git ] ; \
	then \
		if [ -z $${EOS_GITUSER} ] ; then \
			git clone --depth 1 $(EOS_GIT_REPOSITRY_DATA_NOUSER) ./ ; \
		else \
			git clone --depth 1 $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY_DATA) ./; \
		fi ; \
	fi

git-clone-optional: git-init-optional 
	cd optional; if [ ! -d .git ] ; \
	then \
		if [ -z $${EOS_GITUSER} ] ; then \
			git clone --depth 1 $(EOS_GIT_REPOSITRY_OPTIONAL_NOUSER) ./ ; \
		else \
			git clone --depth 1 $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY_OPTIONAL) ./ ; \
		fi ; \
	fi

git-clone-tutorial: git-init-tutorial
	cd tutorial; if [ ! -d .git ] ; \
	then \
		if [ -z $${EOS_GITUSER} ] ; then \
			git clone --depth 1 $(EOS_GIT_REPOSITRY_TUTORIAL_NOUSER) ./ ; \
		else \
			git clone --depth 1 $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY_TUTORIAL) ./ ; \
		fi; \
	fi

git-clone-others: git-init-others
	cd others ; if [ ! -d .git ] ; \
	then \
		if [ -z $${EOS_GITUSER} ] ; then \
			git clone --depth 1 $(EOS_GIT_REPOSITRY_OTHERS_NOUSER) ./ ; \
		else \
			git clone --depth 1 $${EOS_GITUSER}@$(EOS_GIT_REPOSITRY_OTHERS) ./ ; \
		fi; \
	fi


