oh-my-zsh: cleanup

- use fetchFromGitHub instead of fetchgit
 - indent the `installPhase` properly
 - remove unused `pathsToLink`
 - don't hardcode `phases` to allow patching
 - don't copy from $src, but . to allow patching
This commit is contained in:
Florian Klink 2020-08-28 12:28:16 +02:00
parent db77fb705e
commit f1e667234d

View File

@ -1,70 +1,68 @@
# This script was inspired by the ArchLinux User Repository package: # This script was inspired by the ArchLinux User Repository package:
# #
# https://aur.archlinux.org/cgit/aur.git/tree/PKGBUILD?h=oh-my-zsh-git # https://aur.archlinux.org/cgit/aur.git/tree/PKGBUILD?h=oh-my-zsh-git
{ stdenv, fetchgit }: { stdenv, fetchFromGitHub }:
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
version = "2020-08-24"; version = "2020-08-24";
pname = "oh-my-zsh"; pname = "oh-my-zsh";
rev = "cfb86cd08d3b24fd4b59d0d35b3af1f589c891fa";
src = fetchgit { inherit rev; src = fetchFromGitHub {
url = "https://github.com/ohmyzsh/ohmyzsh"; owner = "ohmyzsh";
repo = "ohmyzsh";
rev = "cfb86cd08d3b24fd4b59d0d35b3af1f589c891fa";
sha256 = "0af37smv0bqw37bng2halzgszf8y3m2sxahdff54m16asm0py2cr"; sha256 = "0af37smv0bqw37bng2halzgszf8y3m2sxahdff54m16asm0py2cr";
}; };
pathsToLink = [ "/share/oh-my-zsh" ];
phases = "installPhase";
installPhase = '' installPhase = ''
outdir=$out/share/oh-my-zsh outdir=$out/share/oh-my-zsh
template=templates/zshrc.zsh-template template=templates/zshrc.zsh-template
mkdir -p $outdir mkdir -p $outdir
cp -r $src/* $outdir cp -r * $outdir
cd $outdir cd $outdir
rm LICENSE.txt rm LICENSE.txt
rm -rf .git* rm -rf .git*
chmod -R +w templates chmod -R +w templates
# Change the path to oh-my-zsh dir and disable auto-updating. # Change the path to oh-my-zsh dir and disable auto-updating.
sed -i -e "s#ZSH=\$HOME/.oh-my-zsh#ZSH=$outdir#" \ sed -i -e "s#ZSH=\$HOME/.oh-my-zsh#ZSH=$outdir#" \
-e 's/\# \(DISABLE_AUTO_UPDATE="true"\)/\1/' \ -e 's/\# \(DISABLE_AUTO_UPDATE="true"\)/\1/' \
$template $template
chmod +w oh-my-zsh.sh chmod +w oh-my-zsh.sh
# Both functions expect oh-my-zsh to be in ~/.oh-my-zsh and try to # Both functions expect oh-my-zsh to be in ~/.oh-my-zsh and try to
# modify the directory. # modify the directory.
cat >> oh-my-zsh.sh <<- EOF cat >> oh-my-zsh.sh <<- EOF
# Undefine functions that don't work on Nix. # Undefine functions that don't work on Nix.
unfunction uninstall_oh_my_zsh unfunction uninstall_oh_my_zsh
unfunction upgrade_oh_my_zsh unfunction upgrade_oh_my_zsh
EOF EOF
# Look for .zsh_variables, .zsh_aliases, and .zsh_funcs, and source # Look for .zsh_variables, .zsh_aliases, and .zsh_funcs, and source
# them, if found. # them, if found.
cat >> $template <<- EOF cat >> $template <<- EOF
# Load the variables. # Load the variables.
if [ -f ~/.zsh_variables ]; then if [ -f ~/.zsh_variables ]; then
. ~/.zsh_variables . ~/.zsh_variables
fi fi
# Load the functions. # Load the functions.
if [ -f ~/.zsh_funcs ]; then if [ -f ~/.zsh_funcs ]; then
. ~/.zsh_funcs . ~/.zsh_funcs
fi fi
# Load the aliases. # Load the aliases.
if [ -f ~/.zsh_aliases ]; then if [ -f ~/.zsh_aliases ]; then
. ~/.zsh_aliases . ~/.zsh_aliases
fi fi
EOF EOF
''; '';
meta = with stdenv.lib; { meta = with stdenv.lib; {