git-story-workflow 1.0.0 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/VERSION +1 -1
- data/git-story-workflow.gemspec +5 -5
- data/lib/git/story/app.rb +24 -4
- data/lib/git/story/pre-push +35 -0
- data/lib/git/story/prepare-commit-msg +38 -15
- data/lib/git/story/setup.rb +26 -18
- data/lib/git/story/version.rb +1 -1
- metadata +4 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 04601b201fea90d5e5054d3e61881533d1d5c87b8fb9f4d0c23ab71b74fbda4d
|
4
|
+
data.tar.gz: 3991c64783f6d63815273b6475597a87731a7737cbfc41e2050919c18ec5c1af
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 34536de7b1148214bd5fa6a09dfee1ac876ff16a0d4a9543eb34b08ae92aac111d264bc8b0aefb4bdde112b76c9867ebd7622e58f771ffce411e2a9aee3e2a9e
|
7
|
+
data.tar.gz: 9ecadc6812f41148ad7e79b0184b694a19ec593a041b93626972f9ad2100f6b6b7a6c51962a1e16ceb86222a0800794f2538086b8ad5d7666d406a1fb4e45cd6
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
1.
|
1
|
+
1.4.0
|
data/git-story-workflow.gemspec
CHANGED
@@ -1,23 +1,23 @@
|
|
1
1
|
# -*- encoding: utf-8 -*-
|
2
|
-
# stub: git-story-workflow 1.
|
2
|
+
# stub: git-story-workflow 1.4.0 ruby lib
|
3
3
|
|
4
4
|
Gem::Specification.new do |s|
|
5
5
|
s.name = "git-story-workflow".freeze
|
6
|
-
s.version = "1.
|
6
|
+
s.version = "1.4.0"
|
7
7
|
|
8
8
|
s.required_rubygems_version = Gem::Requirement.new(">= 0".freeze) if s.respond_to? :required_rubygems_version=
|
9
9
|
s.require_paths = ["lib".freeze]
|
10
10
|
s.authors = ["Florian Frank".freeze]
|
11
|
-
s.date = "
|
11
|
+
s.date = "2021-08-17"
|
12
12
|
s.description = "Gem abstracting a git workflow\u2026".freeze
|
13
13
|
s.email = "flori@ping.de".freeze
|
14
14
|
s.executables = ["git-story".freeze]
|
15
15
|
s.extra_rdoc_files = ["README.md".freeze, "lib/git/story.rb".freeze, "lib/git/story/app.rb".freeze, "lib/git/story/setup.rb".freeze, "lib/git/story/utils.rb".freeze, "lib/git/story/version.rb".freeze]
|
16
|
-
s.files = [".gitignore".freeze, "COPYING".freeze, "Gemfile".freeze, "README.md".freeze, "Rakefile".freeze, "VERSION".freeze, "bin/git-story".freeze, "config/story.yml".freeze, "git-story-workflow.gemspec".freeze, "lib/git/story.rb".freeze, "lib/git/story/app.rb".freeze, "lib/git/story/prepare-commit-msg".freeze, "lib/git/story/setup.rb".freeze, "lib/git/story/utils.rb".freeze, "lib/git/story/version.rb".freeze, "spec/git/story/app_spec.rb".freeze, "spec/spec_helper.rb".freeze]
|
16
|
+
s.files = [".gitignore".freeze, "COPYING".freeze, "Gemfile".freeze, "README.md".freeze, "Rakefile".freeze, "VERSION".freeze, "bin/git-story".freeze, "config/story.yml".freeze, "git-story-workflow.gemspec".freeze, "lib/git/story.rb".freeze, "lib/git/story/app.rb".freeze, "lib/git/story/pre-push".freeze, "lib/git/story/prepare-commit-msg".freeze, "lib/git/story/setup.rb".freeze, "lib/git/story/utils.rb".freeze, "lib/git/story/version.rb".freeze, "spec/git/story/app_spec.rb".freeze, "spec/spec_helper.rb".freeze]
|
17
17
|
s.homepage = "http://flori.github.com/git-story-workflow".freeze
|
18
18
|
s.licenses = ["Apache-2.0".freeze]
|
19
19
|
s.rdoc_options = ["--title".freeze, "Git-story-workflow".freeze, "--main".freeze, "README.md".freeze]
|
20
|
-
s.rubygems_version = "3.
|
20
|
+
s.rubygems_version = "3.2.15".freeze
|
21
21
|
s.summary = "Gem abstracting a git workflow".freeze
|
22
22
|
s.test_files = ["spec/git/story/app_spec.rb".freeze, "spec/spec_helper.rb".freeze]
|
23
23
|
|
data/lib/git/story/app.rb
CHANGED
@@ -39,10 +39,10 @@ class Git::Story::App
|
|
39
39
|
@opts = go 'n:', @argv
|
40
40
|
@debug = debug
|
41
41
|
determine_command
|
42
|
+
Git::Story::Setup.perform
|
42
43
|
end
|
43
44
|
|
44
45
|
def run
|
45
|
-
Git::Story::Setup.perform
|
46
46
|
if command_of(@command)
|
47
47
|
if method(@command).parameters.include?(%i[key rest])
|
48
48
|
puts __send__(@command, *@argv, rest: @rest_argv)
|
@@ -286,7 +286,7 @@ class Git::Story::App
|
|
286
286
|
command doc: '[BRANCH] open branch on github'
|
287
287
|
def github(branch = current(check: false))
|
288
288
|
if url = github_url(branch)
|
289
|
-
|
289
|
+
sh "open #{url.inspect}"
|
290
290
|
end
|
291
291
|
nil
|
292
292
|
end
|
@@ -295,8 +295,28 @@ class Git::Story::App
|
|
295
295
|
def pivotal(branch = current(check: true))
|
296
296
|
if story_id = branch&.[](/_(\d+)\z/, 1)&.to_i
|
297
297
|
story_url = fetch_story(story_id)&.url
|
298
|
-
|
298
|
+
sh "open #{story_url}"
|
299
|
+
end
|
300
|
+
nil
|
301
|
+
end
|
302
|
+
|
303
|
+
command doc: 'open project on semaphore'
|
304
|
+
def semaphore
|
305
|
+
sh "open #{complex_config.story.semaphore_project_url}"
|
306
|
+
nil
|
307
|
+
end
|
308
|
+
|
309
|
+
command doc: '[REF] create a hotfix branch from REF'
|
310
|
+
def hotfix(ref = nil)
|
311
|
+
if ref
|
312
|
+
start_point = ref
|
313
|
+
elsif tag = tags.last
|
314
|
+
start_point = tag_name(tag)
|
315
|
+
else
|
316
|
+
fail 'no last deployment tag found'
|
299
317
|
end
|
318
|
+
branch = "hotfix_#{start_point}"
|
319
|
+
sh "git checkout -b #{branch.inspect} #{start_point.inspect}"
|
300
320
|
nil
|
301
321
|
end
|
302
322
|
|
@@ -388,7 +408,7 @@ class Git::Story::App
|
|
388
408
|
end
|
389
409
|
loop do
|
390
410
|
r = block.()
|
391
|
-
|
411
|
+
sh 'clear'
|
392
412
|
start = Time.now
|
393
413
|
puts r
|
394
414
|
refresh_at = start + seconds
|
@@ -0,0 +1,35 @@
|
|
1
|
+
#!/bin/sh
|
2
|
+
# Installed by the git-story gem
|
3
|
+
|
4
|
+
remote="$1"
|
5
|
+
url="$2"
|
6
|
+
|
7
|
+
z40=0000000000000000000000000000000000000000
|
8
|
+
|
9
|
+
while read local_ref local_sha remote_ref remote_sha
|
10
|
+
do
|
11
|
+
if [ "$local_sha" = $z40 ]
|
12
|
+
then
|
13
|
+
# Handle delete
|
14
|
+
:
|
15
|
+
else
|
16
|
+
if [ "$remote_sha" = $z40 ]
|
17
|
+
then
|
18
|
+
# New branch, examine all commits
|
19
|
+
range="$local_sha"
|
20
|
+
else
|
21
|
+
# Update to existing branch, examine new commits
|
22
|
+
range="$remote_sha..$local_sha"
|
23
|
+
fi
|
24
|
+
|
25
|
+
# Check for WIP or [TODO] commit
|
26
|
+
commit=`git rev-list -n 1 --pretty=%B "$range" | egrep -i 'WIP|\[TODO\]'`
|
27
|
+
if [ -n "$commit" -a "$FORCE" != "1" ]
|
28
|
+
then
|
29
|
+
echo >&2 "Found WIP / [TODO] commit in $local_ref, not pushing"
|
30
|
+
exit 1
|
31
|
+
fi
|
32
|
+
fi
|
33
|
+
done
|
34
|
+
|
35
|
+
exit 0
|
@@ -2,11 +2,14 @@
|
|
2
2
|
# Installed by the git-story gem
|
3
3
|
|
4
4
|
require 'tempfile'
|
5
|
+
require 'complex_config/rude'
|
6
|
+
include ComplexConfig::Provider::Shortcuts
|
5
7
|
|
6
8
|
class CommitMesssageParser
|
7
9
|
def initialize
|
8
10
|
@line_index = 0
|
9
11
|
@story_number_found = false
|
12
|
+
@story_number_done = false
|
10
13
|
@message_data = []
|
11
14
|
end
|
12
15
|
|
@@ -16,10 +19,20 @@ class CommitMesssageParser
|
|
16
19
|
@story_number_found
|
17
20
|
end
|
18
21
|
|
22
|
+
def story_number_done?
|
23
|
+
@story_number_done
|
24
|
+
end
|
25
|
+
|
19
26
|
def parse(template)
|
20
27
|
@message_data = template.readlines
|
21
28
|
@message_data.each do |line|
|
22
|
-
|
29
|
+
if /^\s*\[.*(?:#\d+|TODO|(?<done>DONE)).*\]/i =~ line
|
30
|
+
@story_number_found = true
|
31
|
+
if @story_number_done = !!done
|
32
|
+
@message_data.slice!(@line_index)
|
33
|
+
next
|
34
|
+
end
|
35
|
+
end
|
23
36
|
if line =~ /^\s*#/
|
24
37
|
break
|
25
38
|
else
|
@@ -49,21 +62,31 @@ story_numbers =
|
|
49
62
|
break $1.split(/_/)
|
50
63
|
} || []
|
51
64
|
story_numbers.map!(&:chomp)
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
65
|
+
Tempfile.open('commit') do |output|
|
66
|
+
File.open(ARGV.first) do |template|
|
67
|
+
message_parsed = CommitMesssageParser.new.parse(template)
|
68
|
+
if message_parsed.story_number_found?
|
69
|
+
output.puts message_parsed.total
|
70
|
+
elsif complex_config.todo_nudging? && story_numbers.empty? && !message_parsed.story_number_done?
|
71
|
+
output.puts message_parsed.data, "", "[TODO]", "", message_parsed.footer
|
72
|
+
else
|
73
|
+
full_message = [ message_parsed.data, "", ]
|
74
|
+
if prefix = complex_config.story.pivotal_reference_prefix?
|
75
|
+
pivotal_reference = -> number { "%s-%u" % [ prefix, number ] }
|
76
|
+
full_message.concat(
|
77
|
+
story_numbers.each_with_index.map { |story_number, i| "#{i + 1}. " + pivotal_reference.(story_number) }
|
78
|
+
)
|
79
|
+
full_message << ""
|
66
80
|
end
|
81
|
+
full_message <<
|
82
|
+
"[#{story_numbers.map { |story_number| "##{story_number}" } * ' '}]" <<
|
83
|
+
"" <<
|
84
|
+
message_parsed.footer
|
85
|
+
output.puts full_message
|
86
|
+
end
|
87
|
+
output.rewind
|
88
|
+
File.open(ARGV.first, 'w') do |message|
|
89
|
+
message.write output.read
|
67
90
|
end
|
68
91
|
end
|
69
92
|
end
|
data/lib/git/story/setup.rb
CHANGED
@@ -11,30 +11,38 @@ module Git::Story::Setup
|
|
11
11
|
module_function
|
12
12
|
|
13
13
|
def perform(force: false)
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
14
|
+
for filename in %w[ prepare-commit-msg pre-push ]
|
15
|
+
if path = file_installed?(filename)
|
16
|
+
if force
|
17
|
+
install_file filename
|
18
|
+
elsif File.read(path).match?(MARKER)
|
19
|
+
;
|
20
|
+
else
|
21
|
+
ask(
|
22
|
+
prompt: "File #{path.inspect} not created by git-story."\
|
23
|
+
" Overwrite? (y/n, default is %s) ",
|
24
|
+
default: ?n,
|
25
|
+
) do |response|
|
26
|
+
if response == ?y
|
27
|
+
install_file filename
|
28
|
+
end
|
28
29
|
end
|
29
30
|
end
|
31
|
+
else
|
32
|
+
install_file filename
|
30
33
|
end
|
31
|
-
else
|
32
|
-
install_prepare_commit_msg
|
33
34
|
end
|
34
35
|
end
|
35
36
|
|
36
|
-
def
|
37
|
+
def file_installed?(filename)
|
38
|
+
path = File.join(HOOKS_DIR, filename)
|
39
|
+
if File.exist?(path)
|
40
|
+
path
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
def install_file(filename)
|
37
45
|
File.exist?(HOOKS_DIR) or mkdir_p(HOOKS_DIR)
|
38
|
-
cp
|
46
|
+
cp File.join(__dir__, filename), File.join(HOOKS_DIR, filename)
|
39
47
|
end
|
40
48
|
end
|
data/lib/git/story/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: git-story-workflow
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.4.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Florian Frank
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2021-08-17 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: gem_hadar
|
@@ -174,6 +174,7 @@ files:
|
|
174
174
|
- git-story-workflow.gemspec
|
175
175
|
- lib/git/story.rb
|
176
176
|
- lib/git/story/app.rb
|
177
|
+
- lib/git/story/pre-push
|
177
178
|
- lib/git/story/prepare-commit-msg
|
178
179
|
- lib/git/story/setup.rb
|
179
180
|
- lib/git/story/utils.rb
|
@@ -203,7 +204,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
203
204
|
- !ruby/object:Gem::Version
|
204
205
|
version: '0'
|
205
206
|
requirements: []
|
206
|
-
rubygems_version: 3.
|
207
|
+
rubygems_version: 3.2.15
|
207
208
|
signing_key:
|
208
209
|
specification_version: 4
|
209
210
|
summary: Gem abstracting a git workflow
|