aboutsummaryrefslogtreecommitdiff
path: root/commit
blob: 3e417d248d01e26e397a399d0e25cdf25b50f5cf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#!/bin/bash
#
# Commit both on git and svn
#

# Check if a folder is inside a git repository
function is_git {
  # simple git folder checker
  # usage: is_git <folder>
  if [ -z "$1" ]; then
    false
  elif [ ! -d "$1" ]; then
    false
  elif [ -d "$1/.git" ]; then
    true
  else
    ( cd "$1" && git status &> /dev/null )
    
    if [ "$?" != "128" ]; then
      true
    else
      false
    fi
  fi
}

# Check if a folder is inside a svn repository
function is_svn {
  # simple svn folder checker
  # usage: is_svn <folder>
  
  if [ -d "$1/.svn" ]; then
    return
  else
    return 1
  fi
} 

# Push to repositories
function git_push {
  if [ "`git remote | wc -l`" == "0" ]; then
    return
  elif git remote | grep -q 'all'; then
    git push all --all
  elif git remote | grep -q 'origin'; then
    git push --all
  fi
}

# Check user information
function git_user {
  if ! grep -q "^\[user\]" .git/config; then
    echo "No user configuration section found in the repository."
    echo "This might be a privacy issue"

   if [ -e "$HOME/.gitconfig" ]; then
     echo "You should try to use your default setting:"
     echo "cat <<EOF >> .git/config"
     grep -A 2 "^\[user\]" $HOME/.gitconfig
     echo "EOF"
   fi

    exit 1
  fi
}

if [ ! -z "$1" ]; then
  if is_svn .; then
    svn commit -m "$*"
  fi

  if is_git .; then
    git_user
    git commit -a -m "$*"
    git_push
  fi
fi