]> ruderich.org/simon Gitweb - config/dotfiles.git/blob - lib.sh
lib.sh: Add os function which returns current OS.
[config/dotfiles.git] / lib.sh
1 # Setup functions and settings used in subdirectories.
2 #
3 # Their setup.sh script sources this file.
4
5
6 # csh gives the error "Unknown colorls variable `su'." when used with newer
7 # options supported by zsh or GNU ls.
8 unset LS_COLORS
9
10 # Get path to m4 because it's later redefined as function.
11 m4=`which m4`
12
13
14 # Check if the given program is installed. Returns 0 if it exists, 1
15 # otherwise; so it can be used in if.
16 installed() {
17     which $1 | grep -E '^/' > /dev/null
18 }
19
20 # Prints the current OS. Supported are Debian (debian) and Mac OS X (darwin)
21 # at the moment. If an unsupported OS is used an error is printed.
22 os() {
23     if [ -f /etc/debian_version ]; then
24         echo debian
25     elif [ x`uname` = xDarwin ]; then
26         echo darwin
27     else
28         echo unsupported OS! >&2
29         return 1
30     fi
31 }
32
33 # Creates a symbolic link for file $1 in dirname of $2 with name of basenmae
34 # $2.
35 #
36 # `./link.sh example ~/.examplerc` creates a symbolic link to example
37 # (wherever it is located) in ~/ named .examplerc.
38 link() {
39     # Get all necessary paths.
40     pwd=`pwd`
41     base=`dirname "$2"`
42     source=`echo -n "$pwd/$1" | sed "s|$base/||"`
43     target=`basename "$2"`
44
45     # Go to the directory where the link is going to be created.
46     cd "$base"
47
48     # Abort if the target file exists and is no symbolic link. Prevents
49     # overwriting real files.
50     if [ -e "$target" -a ! -h "$target" ]; then
51         echo "link(): target '$target' exists already and is no symbolic link!" >&2
52         exit 1
53     fi
54
55     # Make sure the source exists.
56     if [ ! -e "$source" ]; then
57         echo "link(): source '$source' doesn't exist!" >&2
58         exit 1
59     fi
60
61     # Create the new symbolic link; remove the old one if necessary.
62     echo "link(): linking '$source' to '$target'"
63     rm -f "$target"
64     ln -s "$source" "$target"
65
66     # Go back to the directory where we were before.
67     cd "$pwd"
68
69     unset pwd base source target
70 }
71
72 # m4 wrapper which uses $1.m4 as template file, feeds it to m4 and writes it
73 # to $1 with a warning at the beginning to not edit the generated file.
74 #
75 # All arguments (except the first which is the filename) are passed to m4.
76 m4() {
77     # First argument is file name.
78     file=$1
79     shift
80
81     # Write a warning to the generated file.
82     echo "###################################" > $file
83     echo "# WARNING! DO NOT EDIT THIS FILE! #" >> $file
84     echo "###################################" >> $file
85     echo >> $file
86     echo "# It was generated from $file.m4 on `date`." >> $file
87     echo >> $file
88
89     # Process $1.m4 with m4 using the given options.
90     echo "m4(): generating '$file' from '$file.m4' with options '$*'"
91     $m4 $* $file.m4 >> $file
92
93     unset file
94 }