thicket 0.1.4 → 0.1.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/lib/thicket/log.rb +56 -1
- data/lib/thicket/option_parser.rb +12 -2
- data/lib/thicket/version.rb +1 -1
- metadata +46 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: c541a3fa38a35509b3833a3f584359a661b34f2e
|
4
|
+
data.tar.gz: d4d781ec4b428b1e1f439bb807a1a91c3e0fe33d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c782cf435c8eb5cf9b753982a2415403ed0c0b872b97f2fea9391e71d9e66bdb5936f2f72c21cd18b481707cfa15158499f9efa012c6bd006d8a60c5f23e1ddf
|
7
|
+
data.tar.gz: 6229ade1765ded8520550923aafa07046b94306b490a6747ff22604d036e5fbcdc600b4c8076305c0a9ab7c0c71838c197bfbe0c16d03b55e13e429b642d5a3f
|
data/lib/thicket/log.rb
CHANGED
@@ -26,7 +26,7 @@ module Thicket
|
|
26
26
|
|
27
27
|
puts "..."
|
28
28
|
puts "Stopped after #{@options[:limit]} commits. More commit history exists."
|
29
|
-
|
29
|
+
break
|
30
30
|
end
|
31
31
|
rescue Errno::EPIPE, SystemExit, Interrupt
|
32
32
|
exit
|
@@ -41,6 +41,7 @@ module Thicket
|
|
41
41
|
|
42
42
|
line.match(LOG_PARSE_REGEX) do |matcher|
|
43
43
|
line = process_date_time(matcher[1], line, matcher[3])
|
44
|
+
line = process_refs(matcher[3], line) if matcher[3] && @options[:consolidate_refs]
|
44
45
|
line = process_message_prefix(matcher[4], line) if @options[:color_prefixes]
|
45
46
|
line = process_author_name(matcher[2], line)
|
46
47
|
@count_parsed += 1
|
@@ -61,6 +62,60 @@ module Thicket
|
|
61
62
|
line.sub(time_string, to_sub)
|
62
63
|
end
|
63
64
|
|
65
|
+
# Takes an input log string and a refs list, and formats the refs list in a
|
66
|
+
# more consolidated way.
|
67
|
+
def process_refs(refs, line)
|
68
|
+
original_refs = refs
|
69
|
+
main_remote = @options[:main_remote] || "origin"
|
70
|
+
refs = strip_color(refs).split(",").map(&:strip)
|
71
|
+
tags = []
|
72
|
+
|
73
|
+
head_ref_index = refs.find_index { |r| r.start_with?("HEAD -> ") }
|
74
|
+
|
75
|
+
refs_to_delete = []
|
76
|
+
refs.each do |r|
|
77
|
+
refs_to_delete << r if r == "#{main_remote}/HEAD"
|
78
|
+
next if r.start_with?("#{main_remote}/")
|
79
|
+
|
80
|
+
ref_without_head = r.delete("HEAD -> ")
|
81
|
+
branch = "#{main_remote}/#{ref_without_head}"
|
82
|
+
if refs.include?(branch)
|
83
|
+
refs_to_delete << branch
|
84
|
+
r << "#"
|
85
|
+
end
|
86
|
+
|
87
|
+
if r.start_with?("tag:")
|
88
|
+
tag = r
|
89
|
+
tag.slice!("tag: ")
|
90
|
+
|
91
|
+
refs_to_delete << r
|
92
|
+
tags << tag
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
refs[head_ref_index].sub!("HEAD -> ", "@") if head_ref_index
|
97
|
+
refs.delete_if { |r| refs_to_delete.include? r }
|
98
|
+
|
99
|
+
refs = if refs.any?
|
100
|
+
"(#{refs.join(", ")})"
|
101
|
+
else
|
102
|
+
""
|
103
|
+
end
|
104
|
+
|
105
|
+
substitute = if tags.any?
|
106
|
+
tags = "\e[35m[#{tags.join(", ")}]\e[0m"
|
107
|
+
if refs.empty?
|
108
|
+
tags
|
109
|
+
else
|
110
|
+
"#{refs} #{tags}"
|
111
|
+
end
|
112
|
+
else
|
113
|
+
refs
|
114
|
+
end
|
115
|
+
|
116
|
+
line.sub("(#{original_refs})", substitute)
|
117
|
+
end
|
118
|
+
|
64
119
|
# Takes an input log string and commit message, finds commit messages
|
65
120
|
# prefixes, and darkens them.
|
66
121
|
def process_message_prefix(message, line)
|
@@ -19,7 +19,7 @@ module Thicket
|
|
19
19
|
args = Options.new("world")
|
20
20
|
|
21
21
|
opt_parser = ::OptionParser.new do |opts|
|
22
|
-
opts.banner = "Usage: thicket [options]
|
22
|
+
opts.banner = "Usage: thicket [options]"
|
23
23
|
|
24
24
|
opts.on("-v", "--version", "Print the version number") do |v|
|
25
25
|
args.name = v
|
@@ -42,11 +42,21 @@ module Thicket
|
|
42
42
|
@options[:limit] = limit
|
43
43
|
end
|
44
44
|
|
45
|
-
opts.on("-a", "--all", TrueClass, "Displays all branches on all remotes
|
45
|
+
opts.on("-a", "--all", TrueClass, "Displays all branches on all remotes") do |all|
|
46
46
|
args.name = all
|
47
47
|
@options[:all] = all
|
48
48
|
end
|
49
49
|
|
50
|
+
opts.on("-r", "--refs", TrueClass, "Consolidate the refs list") do |refs|
|
51
|
+
args.name = refs
|
52
|
+
@options[:consolidate_refs] = refs
|
53
|
+
end
|
54
|
+
|
55
|
+
opts.on("--main-remote=MAIN_REMOTE", String, "The name of the primary remote, defaults to 'origin'") do |main_remote|
|
56
|
+
args.name = main_remote
|
57
|
+
@options[:main_remote] = main_remote
|
58
|
+
end
|
59
|
+
|
50
60
|
opts.on("-p", "--color-prefixes", TrueClass, "Adds coloring to commit message prefixes.") do |prefixes|
|
51
61
|
args.name = prefixes
|
52
62
|
@options[:color_prefixes] = prefixes
|
data/lib/thicket/version.rb
CHANGED
metadata
CHANGED
@@ -1,15 +1,57 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: thicket
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.6
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Taylor Thurlow
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2019-
|
11
|
+
date: 2019-06-02 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
|
+
- !ruby/object:Gem::Dependency
|
14
|
+
name: as-duration
|
15
|
+
requirement: !ruby/object:Gem::Requirement
|
16
|
+
requirements:
|
17
|
+
- - ">="
|
18
|
+
- !ruby/object:Gem::Version
|
19
|
+
version: '0'
|
20
|
+
type: :development
|
21
|
+
prerelease: false
|
22
|
+
version_requirements: !ruby/object:Gem::Requirement
|
23
|
+
requirements:
|
24
|
+
- - ">="
|
25
|
+
- !ruby/object:Gem::Version
|
26
|
+
version: '0'
|
27
|
+
- !ruby/object:Gem::Dependency
|
28
|
+
name: factory_bot
|
29
|
+
requirement: !ruby/object:Gem::Requirement
|
30
|
+
requirements:
|
31
|
+
- - ">="
|
32
|
+
- !ruby/object:Gem::Version
|
33
|
+
version: '0'
|
34
|
+
type: :development
|
35
|
+
prerelease: false
|
36
|
+
version_requirements: !ruby/object:Gem::Requirement
|
37
|
+
requirements:
|
38
|
+
- - ">="
|
39
|
+
- !ruby/object:Gem::Version
|
40
|
+
version: '0'
|
41
|
+
- !ruby/object:Gem::Dependency
|
42
|
+
name: faker
|
43
|
+
requirement: !ruby/object:Gem::Requirement
|
44
|
+
requirements:
|
45
|
+
- - ">="
|
46
|
+
- !ruby/object:Gem::Version
|
47
|
+
version: '0'
|
48
|
+
type: :development
|
49
|
+
prerelease: false
|
50
|
+
version_requirements: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - ">="
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '0'
|
13
55
|
- !ruby/object:Gem::Dependency
|
14
56
|
name: guard
|
15
57
|
requirement: !ruby/object:Gem::Requirement
|
@@ -143,7 +185,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
143
185
|
- !ruby/object:Gem::Version
|
144
186
|
version: '0'
|
145
187
|
requirements: []
|
146
|
-
|
188
|
+
rubyforge_project:
|
189
|
+
rubygems_version: 2.5.2.3
|
147
190
|
signing_key:
|
148
191
|
specification_version: 4
|
149
192
|
summary: An opinionated replacement for git's log command.
|