-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgit-branch-dates
82 lines (72 loc) · 3.42 KB
/
git-branch-dates
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
78
79
80
81
82
#!/bin/bash
# -----------------------------------------------------------------------------
# Script: git-branch-dates
# Description: This script fetches all branches in a git repository, displays
# their creation and last update dates in a formatted table.
#
# Author: trne <[email protected]>
# Date: 2024-08-30
#
# License: MIT License
# Permission is hereby granted, free of charge, to any person obtaining
# a copy of this software and associated documentation files (the
# "Software"), to deal in the Software without restriction, including
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Software, and to
# permit persons to whom the Software is furnished to do so, subject to
# the following conditions:
#
# The above copyright notice and this permission notice shall be included
# in all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
#
# Setup Instructions:
# 1. Download this script and save it to the appropriate directory:
# - On macOS: Use the following path:
# sudo nano /usr/local/bin/git-branch-dates
# - On Linux: Use the following path:
# sudo nano /usr/local/bin/git-branch-dates
#
# 2. Make the script executable by running:
# sudo chmod +x /usr/local/bin/git-branch-dates
#
# 3. To use the script globally, run:
# git-branch-dates
#
# Note: The above steps will allow you to use the `git-branch-dates` command
# from any git repository on your system.
# -----------------------------------------------------------------------------
# Fetch all branches to ensure we have the latest data
git fetch --all
# Function to format the date
format_date() {
local date_string="$1"
date -j -f "%Y-%m-%d %H:%M:%S %z" "$date_string" "+%Y-%m-%d %H:%M:%S %Z" 2>/dev/null
}
# List all local and remote branches, excluding the detached HEAD reference, and remove duplicates
branches=$(git branch -a | sed 's/^\* //' | sort | uniq)
# Format string for printf
format_string="%-70s %-25s %-25s\n"
# Header with fixed-width columns
printf "$format_string" "Branch Name" "Creation Date" "Last Update Date"
for branch in $branches; do
# Skip lines that contain '->' or are empty, as they are not valid branch names
if [[ "$branch" == *"->"* || -z "$branch" ]]; then
continue
fi
# Get the first commit date (creation date) and format it
creation_date=$(git log --reverse --pretty=format:'%ci' "$branch" 2>/dev/null | head -n 1)
creation_date=$(format_date "$creation_date")
# Get the last commit date (last update date) and format it
last_update_date=$(git log -1 --pretty=format:'%ci' "$branch" 2>/dev/null)
last_update_date=$(format_date "$last_update_date")
# Print branch name, creation date, and last update date with aligned columns
printf "$format_string" "$branch" "$creation_date" "$last_update_date"
done