squared 0.6.13 → 0.7.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/CHANGELOG.md +69 -85
- data/README.md +242 -204
- data/lib/squared/common/format.rb +7 -10
- data/lib/squared/common/prompt.rb +23 -24
- data/lib/squared/common/shell.rb +21 -22
- data/lib/squared/common/system.rb +29 -21
- data/lib/squared/common/utils.rb +43 -54
- data/lib/squared/config.rb +17 -16
- data/lib/squared/version.rb +1 -1
- data/lib/squared/workspace/application.rb +292 -180
- data/lib/squared/workspace/project/base.rb +559 -467
- data/lib/squared/workspace/project/docker.rb +166 -159
- data/lib/squared/workspace/project/git.rb +202 -168
- data/lib/squared/workspace/project/node.rb +115 -127
- data/lib/squared/workspace/project/python.rb +248 -160
- data/lib/squared/workspace/project/ruby.rb +403 -292
- data/lib/squared/workspace/project/support/class.rb +13 -7
- data/lib/squared/workspace/project/support/optionpartition.rb +70 -55
- data/lib/squared/workspace/project/support/utils.rb +68 -0
- data/lib/squared/workspace/project.rb +0 -7
- data/lib/squared/workspace/repo.rb +234 -169
- data/lib/squared/workspace/series.rb +91 -86
- data/lib/squared/workspace/support/base.rb +15 -1
- metadata +3 -2
|
@@ -84,7 +84,7 @@ module Squared
|
|
|
84
84
|
def revbuild(file: nil)
|
|
85
85
|
@revfile = @home.join(file || "#{@main}.revb")
|
|
86
86
|
@revdoc = JSON.parse(@revfile.read) if @revfile.exist?
|
|
87
|
-
rescue
|
|
87
|
+
rescue => e
|
|
88
88
|
@revfile = nil
|
|
89
89
|
warn log_warn(e, pass: true)
|
|
90
90
|
self
|
|
@@ -117,7 +117,7 @@ module Squared
|
|
|
117
117
|
|
|
118
118
|
def rev_timesince(*keys, clock: false)
|
|
119
119
|
epoch = time_epoch - rev_entry(*keys).to_i
|
|
120
|
-
rescue
|
|
120
|
+
rescue
|
|
121
121
|
nil
|
|
122
122
|
else
|
|
123
123
|
time_format(epoch, clock: clock)
|
|
@@ -140,7 +140,7 @@ module Squared
|
|
|
140
140
|
rev_timeutc(name, utc) if utc
|
|
141
141
|
end
|
|
142
142
|
File.write(@revfile, JSON.pretty_generate(@revdoc))
|
|
143
|
-
rescue
|
|
143
|
+
rescue => e
|
|
144
144
|
log&.debug e
|
|
145
145
|
warn log_warn(e, pass: true) if warning
|
|
146
146
|
ensure
|
|
@@ -169,28 +169,29 @@ module Squared
|
|
|
169
169
|
}.freeze,
|
|
170
170
|
fetch: {
|
|
171
171
|
base: %w[multiple porcelain progress P|prune-tags refetch stdin u|update-head-ok
|
|
172
|
-
recurse-submodules-default=b
|
|
172
|
+
recurse-submodules-default=b].freeze,
|
|
173
173
|
pull: %w[4 6 n t a|append atomic dry-run f|force k|keep negotiate-only prefetch p|prune q|quiet set-upstream
|
|
174
174
|
unshallow update-shallow v|verbose deepen=i depth=i j|jobs=i negotiation-tip=q recurse-submodules=v
|
|
175
175
|
refmap=q o|server-option=q shallow-exclude=b shallow-since=v upload-pack=q].freeze
|
|
176
176
|
}.freeze,
|
|
177
177
|
git: {
|
|
178
|
-
add: %w[N|intent-to-add].freeze,
|
|
178
|
+
add: %w[N|intent-to-add refresh].freeze,
|
|
179
179
|
blame: %w[b c l s t w C=im? L=q M=im? S=p color-by-age color-lines first-parent incremental line-porcelain
|
|
180
180
|
p|porcelain root score-debug f|show-name e|show-email n|show-number show-stats abbrev=i contents=p
|
|
181
|
-
date=q
|
|
181
|
+
date=q encoding=b ignore-rev=b ignore-revs-file=p reverse=q].freeze,
|
|
182
182
|
clean: %w[d x X f|force n|dry-run i|interactive q|quiet e|exclude=q].freeze,
|
|
183
183
|
grep: %w[e f=p h H I O=bm r all-match and G|basic-regexp break cached column c|count E|extended-regexp
|
|
184
184
|
l|files-with-matches L|files-without-match F|fixed-strings full-name W|function-context heading
|
|
185
185
|
i|ignore-case v|invert-match n|line-number name-only no-index not z|null o|only-matching or
|
|
186
186
|
P|perl-regexp q|quiet recurse-submodules p|show-function a|text untracked w|word-regexp
|
|
187
|
-
A|after-context=i B|before-context=i color=b C|context=i m|max-count=n max-depth=
|
|
187
|
+
A|after-context=i B|before-context=i color=b C|context=i m|max-count=n max-depth=i
|
|
188
188
|
open-files-in-pager=b threads=n].freeze,
|
|
189
189
|
mv: %w[k f|force n|dry-run v|verbose].freeze,
|
|
190
190
|
revert: %w[e S=bm? n|no-commit reference cleanup=b gpg-sign=b? m|mainline=i s|signoff strategy=b
|
|
191
191
|
X|strategy-option=b].freeze,
|
|
192
192
|
rm: %w[r cached f|force n|dry-run ignore-unmatch pathspec-file-nul q|quiet sparse
|
|
193
|
-
pathspec-from-file=p].freeze
|
|
193
|
+
pathspec-from-file=p].freeze,
|
|
194
|
+
'sparse-checkout': %w[cone sparse-index no-cone no-sparse-index skip-checks].freeze
|
|
194
195
|
}.freeze,
|
|
195
196
|
log: {
|
|
196
197
|
base: %w[L=qm all all-match alternate-refs author-date-order basic-regexp bisect boundary cherry cherry-mark
|
|
@@ -242,6 +243,10 @@ module Squared
|
|
|
242
243
|
show-object-format=b? since=q tags=q? until=q].freeze,
|
|
243
244
|
show: %w[t combined-all-paths no-diff-merges remerge-diff show-notes-by-default show-signature diff-merges=b
|
|
244
245
|
encoding=b expand-tabs=i notes=q show-notes=q?].freeze,
|
|
246
|
+
sparse_checkout: {
|
|
247
|
+
add: %w[skip-checks].freeze,
|
|
248
|
+
clean: %w[n f v].freeze
|
|
249
|
+
}.freeze,
|
|
245
250
|
stash: {
|
|
246
251
|
common: %w[q|quiet].freeze,
|
|
247
252
|
push: %w[a|all u|include-untracked k|keep-index no-keep-index no-include-untracked pathspec-file-nul p|patch
|
|
@@ -254,7 +259,7 @@ module Squared
|
|
|
254
259
|
submodule: {
|
|
255
260
|
status: %w[cached recursive].freeze,
|
|
256
261
|
update: %w[checkout f|force init merge N|no-fetch no-recommend-shallow no-single-branch recommend-shallow
|
|
257
|
-
rebase recursive remote single-branch depth=i filter=q jobs=i reference=
|
|
262
|
+
rebase recursive remote single-branch depth=i filter=q jobs=i reference=b ref-format=q].freeze,
|
|
258
263
|
branch: %w[b|branch d|default].freeze,
|
|
259
264
|
sync: %w[recursive].freeze
|
|
260
265
|
}.freeze,
|
|
@@ -287,6 +292,10 @@ module Squared
|
|
|
287
292
|
rev_parse: %w[flags].freeze,
|
|
288
293
|
revert: %w[edit gpg-sign rerere-autoupdate].freeze,
|
|
289
294
|
show: %w[standard-notes].freeze,
|
|
295
|
+
sparse_checkout: {
|
|
296
|
+
reapply: %w[cone sparse-index].freeze,
|
|
297
|
+
clean: %w[dry-run force verbose].freeze
|
|
298
|
+
}.freeze,
|
|
290
299
|
status: %w[ahead-behind column renames].freeze,
|
|
291
300
|
switch: %w[guess progress recurse-submodules track].freeze,
|
|
292
301
|
tag: %w[column].freeze
|
|
@@ -326,7 +335,7 @@ module Squared
|
|
|
326
335
|
'diff' => %i[head branch files view between contain].freeze,
|
|
327
336
|
'fetch' => %i[origin remote all].freeze,
|
|
328
337
|
'files' => %i[cached modified deleted others].freeze,
|
|
329
|
-
'git' => %i[add blame clean grep mv revert rm status].freeze,
|
|
338
|
+
'git' => %i[add blame clean grep mv revert rm sparse-checkout status].freeze,
|
|
330
339
|
'log' => %i[view grep between contain].freeze,
|
|
331
340
|
'merge' => %i[commit no-commit send].freeze,
|
|
332
341
|
'pull' => %i[origin remote all].freeze,
|
|
@@ -334,8 +343,9 @@ module Squared
|
|
|
334
343
|
'refs' => %i[heads tags remote].freeze,
|
|
335
344
|
'reset' => %i[commit index patch mode undo].freeze,
|
|
336
345
|
'restore' => %i[source staged worktree].freeze,
|
|
337
|
-
'rev' => %i[commit build output].freeze,
|
|
346
|
+
'rev' => %i[commit branch build output].freeze,
|
|
338
347
|
'show' => %i[format oneline textconv].freeze,
|
|
348
|
+
'sparse-checkout' => %i[add reapply list clean disable].freeze,
|
|
339
349
|
'stash' => %i[push pop apply branch drop clear list all staged worktree].freeze,
|
|
340
350
|
'submodule' => %i[status update branch url sync].freeze,
|
|
341
351
|
'switch' => %i[branch create detach].freeze,
|
|
@@ -426,7 +436,7 @@ module Squared
|
|
|
426
436
|
end
|
|
427
437
|
if squash
|
|
428
438
|
found = false
|
|
429
|
-
git_spawn('log --format=%h', stdout: false).each do |val|
|
|
439
|
+
git_spawn(git_output('log --format=%h'), stdout: false).each do |val|
|
|
430
440
|
if found
|
|
431
441
|
squash = val.chomp
|
|
432
442
|
break
|
|
@@ -479,9 +489,8 @@ module Squared
|
|
|
479
489
|
])
|
|
480
490
|
choice_remote
|
|
481
491
|
end
|
|
482
|
-
tag(flag, refs: [name], message: message, commit: commit, remote: remote)
|
|
483
|
-
|
|
484
|
-
end
|
|
492
|
+
ret = tag(flag, refs: [name], message: message, commit: commit, remote: remote)
|
|
493
|
+
success?(ret, !remote)
|
|
485
494
|
end
|
|
486
495
|
end
|
|
487
496
|
when 'stash'
|
|
@@ -505,16 +514,15 @@ module Squared
|
|
|
505
514
|
args.shift
|
|
506
515
|
index = choice_commit(multiple: true)
|
|
507
516
|
else
|
|
508
|
-
index = []
|
|
509
|
-
args.each do |val|
|
|
517
|
+
index = args.each_with_object([]) do |val, out|
|
|
510
518
|
if matchhead(val)
|
|
511
|
-
|
|
519
|
+
out << commithead(val)
|
|
512
520
|
elsif (sha = commithash(val))
|
|
513
|
-
|
|
521
|
+
out << sha
|
|
514
522
|
elsif val.start_with?('^')
|
|
515
|
-
|
|
523
|
+
out << shell_quote(val)
|
|
516
524
|
else
|
|
517
|
-
break
|
|
525
|
+
break out
|
|
518
526
|
end
|
|
519
527
|
end
|
|
520
528
|
args = args.drop(index.size)
|
|
@@ -547,11 +555,10 @@ module Squared
|
|
|
547
555
|
args.shift
|
|
548
556
|
index = choice_commit(multiple: true)
|
|
549
557
|
else
|
|
550
|
-
index = []
|
|
551
|
-
|
|
552
|
-
break unless (sha = commithead(val) || commithash(val))
|
|
558
|
+
index = args.each_with_object([]) do |val, out|
|
|
559
|
+
break out unless (sha = commithead(val) || commithash(val))
|
|
553
560
|
|
|
554
|
-
|
|
561
|
+
out << sha
|
|
555
562
|
end
|
|
556
563
|
args = args.drop(index.size)
|
|
557
564
|
end
|
|
@@ -697,12 +704,12 @@ module Squared
|
|
|
697
704
|
format_desc action, flag, '[^~]name*,:?'
|
|
698
705
|
task flag do |_, args|
|
|
699
706
|
refs = args.to_a
|
|
700
|
-
if refs.empty? || (
|
|
707
|
+
if refs.empty? || (i = refs.last == ':')
|
|
701
708
|
accept = ['Delete?']
|
|
702
|
-
accept << accept_b('Force?') unless
|
|
703
|
-
remote = choice_refs('Choose a branch',
|
|
709
|
+
accept << accept_b('Force?') unless i
|
|
710
|
+
remote = choice_refs('Choose a branch', i ? 'remotes' : 'heads', multiple: true,
|
|
704
711
|
accept: accept)
|
|
705
|
-
if
|
|
712
|
+
if i
|
|
706
713
|
refs.pop
|
|
707
714
|
else
|
|
708
715
|
refs = remote.first
|
|
@@ -882,6 +889,12 @@ module Squared
|
|
|
882
889
|
end
|
|
883
890
|
rev_parse(flag, ref: ref, size: size)
|
|
884
891
|
end
|
|
892
|
+
when :branch
|
|
893
|
+
format_desc action, flag, 'ref?=HEAD|upstream|push'
|
|
894
|
+
task flag, [:ref] do |_, args|
|
|
895
|
+
ret = rev_parse(flag, ref: args.ref || 'upstream')
|
|
896
|
+
puts ret unless ret.empty?
|
|
897
|
+
end
|
|
885
898
|
when :build
|
|
886
899
|
next unless build?
|
|
887
900
|
|
|
@@ -927,20 +940,28 @@ module Squared
|
|
|
927
940
|
task flag do |_, args|
|
|
928
941
|
args = args.to_a
|
|
929
942
|
if args.empty? || args.last == ':'
|
|
930
|
-
files = []
|
|
931
|
-
|
|
943
|
+
files = status_data.each_with_object([]) do |row, out|
|
|
944
|
+
out << row[0] if row[flag == :staged ? 2 : 1].match?(/[AMDRTC]/)
|
|
945
|
+
end
|
|
932
946
|
unless files.empty?
|
|
933
947
|
files = choice_index('Select a file', files, multiple: true, force: false,
|
|
934
948
|
accept: 'Restore?')
|
|
935
949
|
end
|
|
936
950
|
args.pop
|
|
937
|
-
args, glob = args.partition { |val| val.match?(/^(
|
|
951
|
+
args, glob = args.partition { |val| val.match?(/^([a-z-]+=|[^*]+$)/) }
|
|
938
952
|
files.concat(glob)
|
|
939
953
|
next if args.empty? && files.empty?
|
|
940
954
|
end
|
|
941
955
|
restore(flag, args, files: files)
|
|
942
956
|
end
|
|
943
957
|
end
|
|
958
|
+
when 'sparse-checkout'
|
|
959
|
+
break unless matchfile(gitpath('config.worktree'), /\bsparseCheckout\s+=\s+true/)
|
|
960
|
+
|
|
961
|
+
format_desc(action, flag, 'opts*', after: ('dir+' if flag == :add))
|
|
962
|
+
task flag do |_, args|
|
|
963
|
+
sparse_checkout flag, args.to_a
|
|
964
|
+
end
|
|
944
965
|
when 'git'
|
|
945
966
|
before = case flag
|
|
946
967
|
when :blame
|
|
@@ -955,6 +976,8 @@ module Squared
|
|
|
955
976
|
'pathspec*,pattern*'
|
|
956
977
|
when :grep
|
|
957
978
|
'tree*,pathspec*'
|
|
979
|
+
when :'sparse-checkout'
|
|
980
|
+
'dir+'
|
|
958
981
|
when :clean, :rm, :status
|
|
959
982
|
'pathspec*'
|
|
960
983
|
end
|
|
@@ -1009,18 +1032,21 @@ module Squared
|
|
|
1009
1032
|
printsucc
|
|
1010
1033
|
end
|
|
1011
1034
|
op = OptionPartition.new(opts, OPT_GIT[:pull], cmd, project: self, no: OPT_GIT[:no][:pull])
|
|
1012
|
-
|
|
1013
|
-
|
|
1035
|
+
reg = if op.empty?
|
|
1036
|
+
[]
|
|
1037
|
+
else
|
|
1038
|
+
opts = op.uniq(opts)
|
|
1039
|
+
matchmap op
|
|
1040
|
+
end
|
|
1014
1041
|
session_done op.target
|
|
1015
1042
|
heads = []
|
|
1016
1043
|
cur = nil
|
|
1017
1044
|
foreachref('heads', format: '%(if)%(HEAD)%(then)* %(end)%(refname:short)').each do |line|
|
|
1018
|
-
line.chomp!
|
|
1019
1045
|
cur ||= line.delete_prefix!('* ')
|
|
1020
|
-
heads << line if matchany?(
|
|
1046
|
+
heads << line if matchany?(reg, line)
|
|
1021
1047
|
end
|
|
1022
1048
|
raise_error 'head not found', hint: 'for-each-ref' unless cur
|
|
1023
|
-
opts << 'ff-only' if opts.empty? &&
|
|
1049
|
+
opts << 'ff-only' if opts.empty? && option('ff-only', notequals: '0')
|
|
1024
1050
|
(heads.dup << cur).each_with_index do |branch, i|
|
|
1025
1051
|
next unless (i < heads.size && cur != branch) || i == heads.size
|
|
1026
1052
|
|
|
@@ -1034,12 +1060,16 @@ module Squared
|
|
|
1034
1060
|
end
|
|
1035
1061
|
append_pull(opts, OPT_GIT[:pull] + OPT_GIT[:fetch][:pull],
|
|
1036
1062
|
flag: flag, from: :pull, remote: remote, no: OPT_GIT[:no][:pull] + OPT_GIT[:no][:fetch][:pull])
|
|
1037
|
-
|
|
1038
|
-
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
|
|
1042
|
-
|
|
1063
|
+
if sync
|
|
1064
|
+
source(hint: hint)
|
|
1065
|
+
else
|
|
1066
|
+
source(sync: false, sub: if stdout?
|
|
1067
|
+
[
|
|
1068
|
+
opt_style(color(:red), /^(.+)(\|\s+\d+\s+)([^-]*)(-+)(.*)$/, 4),
|
|
1069
|
+
opt_style(color(:green), /^(.+)(\|\s+\d+\s+)(\++)(.*)$/, 3)
|
|
1070
|
+
]
|
|
1071
|
+
end, hint: hint, **threadargs)
|
|
1072
|
+
end
|
|
1043
1073
|
end
|
|
1044
1074
|
|
|
1045
1075
|
def rebase(flag = nil, opts = [], sync: invoked_sync?('rebase', flag), commit: nil, upstream: nil, branch: nil,
|
|
@@ -1083,7 +1113,11 @@ module Squared
|
|
|
1083
1113
|
opts << 'all' if flag == :all || option('all')
|
|
1084
1114
|
append_pull(opts, collect_hash(OPT_GIT[:fetch]), flag: flag, from: :fetch, remote: remote,
|
|
1085
1115
|
no: collect_hash(OPT_GIT[:no][:fetch]))
|
|
1086
|
-
|
|
1116
|
+
if sync
|
|
1117
|
+
source
|
|
1118
|
+
else
|
|
1119
|
+
source(sync: false, **threadargs)
|
|
1120
|
+
end
|
|
1087
1121
|
end
|
|
1088
1122
|
|
|
1089
1123
|
def clone(*, sync: invoked_sync?('clone'), **)
|
|
@@ -1191,10 +1225,14 @@ module Squared
|
|
|
1191
1225
|
end
|
|
1192
1226
|
else
|
|
1193
1227
|
git_session('stash', 'push', opts: opts)
|
|
1194
|
-
append_option(OptionPartition.select(OPT_GIT[:stash][:push], no: false), no: true, ignore: false)
|
|
1228
|
+
append_option(*OptionPartition.select(OPT_GIT[:stash][:push], no: false), no: true, ignore: false)
|
|
1195
1229
|
append_message
|
|
1196
1230
|
end
|
|
1197
|
-
|
|
1231
|
+
if sync
|
|
1232
|
+
source(banner: !quiet?)
|
|
1233
|
+
else
|
|
1234
|
+
source(sync: false, banner: !quiet?, **threadargs)
|
|
1235
|
+
end
|
|
1198
1236
|
end
|
|
1199
1237
|
|
|
1200
1238
|
def status(flag = nil, opts = [])
|
|
@@ -1207,12 +1245,10 @@ module Squared
|
|
|
1207
1245
|
cmd << '--branch' if option('branch')
|
|
1208
1246
|
option('ignore-submodules', ignore: false) do |val|
|
|
1209
1247
|
cmd << basic_option('ignore-submodules', case val
|
|
1210
|
-
when '0', '
|
|
1248
|
+
when 'none', '0', 'false'
|
|
1211
1249
|
'none'
|
|
1212
|
-
when '
|
|
1213
|
-
|
|
1214
|
-
when '2', 'dirty'
|
|
1215
|
-
'dirty'
|
|
1250
|
+
when 'untracked', 'dirty'
|
|
1251
|
+
val
|
|
1216
1252
|
else
|
|
1217
1253
|
'all'
|
|
1218
1254
|
end)
|
|
@@ -1238,7 +1274,7 @@ module Squared
|
|
|
1238
1274
|
list_result(ret, 'files', action: 'modified', from: from)
|
|
1239
1275
|
end
|
|
1240
1276
|
|
|
1241
|
-
def revbuild(flag = nil, opts = [],
|
|
1277
|
+
def revbuild(flag = nil, opts = [], **kwargs)
|
|
1242
1278
|
kw = lambda do
|
|
1243
1279
|
{
|
|
1244
1280
|
include: relativepath(*Array(kwargs[:include]), all: true),
|
|
@@ -1256,7 +1292,7 @@ module Squared
|
|
|
1256
1292
|
sha = git_spawn('rev-parse --verify HEAD').chomp
|
|
1257
1293
|
return if sha.empty?
|
|
1258
1294
|
|
|
1259
|
-
sync = invoked_sync?('revbuild', flag)
|
|
1295
|
+
sync = kwargs.fetch(:sync) { invoked_sync?('revbuild', flag) }
|
|
1260
1296
|
kwargs = kwargs.key?(:include) || kwargs.key?(:exclude) ? kw.call : @revbuild || {}
|
|
1261
1297
|
case flag
|
|
1262
1298
|
when :build
|
|
@@ -1279,11 +1315,11 @@ module Squared
|
|
|
1279
1315
|
end
|
|
1280
1316
|
end
|
|
1281
1317
|
start = time_epoch
|
|
1282
|
-
build(*@output, sync: sync, from:
|
|
1283
|
-
rescue
|
|
1318
|
+
build(*@output, sync: sync, from: symjoin('git', 'revbuild'))
|
|
1319
|
+
rescue => e
|
|
1284
1320
|
print_error(e, pass: true)
|
|
1285
1321
|
else
|
|
1286
|
-
print_status('revbuild', subject: name, start: start
|
|
1322
|
+
print_status('revbuild', subject: name, start: start)
|
|
1287
1323
|
workspace.rev_write(name, { 'revision' => sha, 'files' => status_digest(*args, **kwargs) },
|
|
1288
1324
|
sync: sync, utc: 'build')
|
|
1289
1325
|
end
|
|
@@ -1337,9 +1373,9 @@ module Squared
|
|
|
1337
1373
|
cmd << '-m' if merge
|
|
1338
1374
|
cmd << '--detach' << commit
|
|
1339
1375
|
else
|
|
1340
|
-
|
|
1341
|
-
|
|
1342
|
-
|
|
1376
|
+
op = OptionPartition.new(opts, OPT_GIT[:checkout] + OPT_GIT[:log][:diff_context], cmd,
|
|
1377
|
+
project: self, no: OPT_GIT[:no][:checkout],
|
|
1378
|
+
first: (matchpathspec if flag == :path))
|
|
1343
1379
|
if flag == :path
|
|
1344
1380
|
append_head
|
|
1345
1381
|
append_pathspec(op.extras, pass: false)
|
|
@@ -1379,8 +1415,10 @@ module Squared
|
|
|
1379
1415
|
list_result(ret, 'tags', grep: op.extras, from: from)
|
|
1380
1416
|
return
|
|
1381
1417
|
end
|
|
1382
|
-
remote ||= option('remote')
|
|
1383
|
-
|
|
1418
|
+
if (ret = source) && (remote ||= option('remote'))
|
|
1419
|
+
git_spawn('push', ('-d' if flag == :delete), remote, *refs.quote!)
|
|
1420
|
+
end
|
|
1421
|
+
ret
|
|
1384
1422
|
end
|
|
1385
1423
|
|
|
1386
1424
|
def log!(flag, opts = [], range: [], index: [], grep: [])
|
|
@@ -1484,7 +1522,7 @@ module Squared
|
|
|
1484
1522
|
format = '%(if)%(HEAD)%(then)%(refname:short)...%(upstream:short)...%(upstream:track)%(end)'
|
|
1485
1523
|
git_spawn 'fetch --no-tags --quiet'
|
|
1486
1524
|
foreachref('heads', format: format).each do |line|
|
|
1487
|
-
next if
|
|
1525
|
+
next if line.empty?
|
|
1488
1526
|
|
|
1489
1527
|
branch, origin, hint = line.split('...')
|
|
1490
1528
|
if hint && !hint.match?(/^\[(\D+0,\D+0)\]$/)
|
|
@@ -1529,7 +1567,7 @@ module Squared
|
|
|
1529
1567
|
cached = git_spawn 'diff --cached --name-only --no-color'
|
|
1530
1568
|
if amend || !cached.empty? || dryrun?
|
|
1531
1569
|
if adding.empty? && !cached.empty? && banner?
|
|
1532
|
-
puts(cached.lines(chomp: true).map
|
|
1570
|
+
puts(cached.lines(chomp: true).map { |val| "cached #{shell_quote(val)}" })
|
|
1533
1571
|
end
|
|
1534
1572
|
source co
|
|
1535
1573
|
source pu
|
|
@@ -1601,7 +1639,7 @@ module Squared
|
|
|
1601
1639
|
end
|
|
1602
1640
|
when :delete
|
|
1603
1641
|
remote&.each { |val| source git_output('push --delete', *val.split('/', 2).quote!) }
|
|
1604
|
-
force, list = refs.partition { |val| val.start_with?(
|
|
1642
|
+
force, list = refs.partition { |val| val.start_with?('~', '^') }
|
|
1605
1643
|
force.each do |val|
|
|
1606
1644
|
r = '-r' if val.delete!('~')
|
|
1607
1645
|
source git_output('branch', val.delete!('^') ? '-D' : '-d', r, shell_quote(val))
|
|
@@ -1708,7 +1746,7 @@ module Squared
|
|
|
1708
1746
|
op << '--recursive' if option('r', 'recursive')
|
|
1709
1747
|
op.splice(path: true)
|
|
1710
1748
|
end
|
|
1711
|
-
|
|
1749
|
+
success?(source, flag == :branch)
|
|
1712
1750
|
end
|
|
1713
1751
|
|
|
1714
1752
|
def restore(flag, opts = [], commit: nil, files: nil)
|
|
@@ -1728,7 +1766,7 @@ module Squared
|
|
|
1728
1766
|
cmd << '--textconv'
|
|
1729
1767
|
append_value(files.flat_map { |val| Dir[val] }
|
|
1730
1768
|
.select { |val| projectpath?(val) }
|
|
1731
|
-
.map
|
|
1769
|
+
.map { |val| shell_quote("HEAD:#{val}") })
|
|
1732
1770
|
source(banner: false)
|
|
1733
1771
|
return
|
|
1734
1772
|
when :oneline
|
|
@@ -1743,9 +1781,8 @@ module Squared
|
|
|
1743
1781
|
opts << format if format
|
|
1744
1782
|
end
|
|
1745
1783
|
list = OPT_GIT[:show] + OPT_GIT[:diff][:show] + OPT_GIT[:log][:diff] + OPT_GIT[:log][:diff_context]
|
|
1746
|
-
op = OptionPartition.new(opts, list, cmd,
|
|
1747
|
-
|
|
1748
|
-
no: OPT_GIT[:no][:show] + collect_hash(OPT_GIT[:no][:log], pass: [:base]))
|
|
1784
|
+
op = OptionPartition.new(opts, list, cmd, project: self, pass: [:base],
|
|
1785
|
+
no: OPT_GIT[:no][:show] + collect_hash(OPT_GIT[:no][:log]))
|
|
1749
1786
|
op.append(delim: true)
|
|
1750
1787
|
source(exception: false, banner: flag != :oneline)
|
|
1751
1788
|
end
|
|
@@ -1757,8 +1794,13 @@ module Squared
|
|
|
1757
1794
|
cmd << (size.to_i.zero? ? '--verify' : basic_option('short', [size.to_i, 5].max))
|
|
1758
1795
|
append_commit(ref, head: true)
|
|
1759
1796
|
when :branch
|
|
1760
|
-
cmd << '--abbrev-ref'
|
|
1761
|
-
|
|
1797
|
+
cmd << '--abbrev-ref' << '--symbolic-full-name' << shell_quote(case ref
|
|
1798
|
+
when 'upstream', 'push'
|
|
1799
|
+
"@{#{ref}}"
|
|
1800
|
+
else
|
|
1801
|
+
ref
|
|
1802
|
+
end)
|
|
1803
|
+
return git_spawn(cmd, exception: false).chomp
|
|
1762
1804
|
when :output
|
|
1763
1805
|
if opts.delete('sq-quote')
|
|
1764
1806
|
cmd << '--sq-quote'
|
|
@@ -1770,6 +1812,20 @@ module Squared
|
|
|
1770
1812
|
source(banner: verbose?)
|
|
1771
1813
|
end
|
|
1772
1814
|
|
|
1815
|
+
def sparse_checkout(flag, opts = [])
|
|
1816
|
+
cmd, opts = git_session('sparse-checkout', flag, opts: opts)
|
|
1817
|
+
op = OptionPartition.new(opts, OPT_GIT[:sparse_checkout].fetch(flag, []), cmd,
|
|
1818
|
+
project: self, no: OPT_GIT[:no][:sparse_checkout][flag])
|
|
1819
|
+
case flag
|
|
1820
|
+
when :add
|
|
1821
|
+
append_pathspec(op.detach, expect: true, resolve: false, pass: false)
|
|
1822
|
+
when :clean
|
|
1823
|
+
op << '--dry-run' unless op.arg?('n', 'f', 'force')
|
|
1824
|
+
end
|
|
1825
|
+
op.clear
|
|
1826
|
+
success?(source, flag != :list)
|
|
1827
|
+
end
|
|
1828
|
+
|
|
1773
1829
|
def ls_remote(flag, opts = [], remote: nil)
|
|
1774
1830
|
cmd, opts = git_session('ls-remote --refs', opts: opts)
|
|
1775
1831
|
cmd << "--#{flag}" unless flag == :remote
|
|
@@ -1799,10 +1855,12 @@ module Squared
|
|
|
1799
1855
|
list.concat(OPT_GIT[:log][:diff_context])
|
|
1800
1856
|
when :revert
|
|
1801
1857
|
list.concat(VAL_GIT[:rebase][:send])
|
|
1858
|
+
when :'sparse-checkout'
|
|
1859
|
+
cmd << 'set'
|
|
1802
1860
|
end
|
|
1803
1861
|
op = OptionPartition.new(opts, list, cmd, project: self, no: OPT_GIT[:no][flag], single: /\A\d+\z/,
|
|
1804
1862
|
first: case flag
|
|
1805
|
-
when :blame, :revert then nil
|
|
1863
|
+
when :blame, :revert, :'sparse-checkout' then nil
|
|
1806
1864
|
else matchpathspec
|
|
1807
1865
|
end)
|
|
1808
1866
|
case flag
|
|
@@ -1823,12 +1881,12 @@ module Squared
|
|
|
1823
1881
|
grep, pathspec = op.partition { |val| OptionPartition.pattern?(val) }
|
|
1824
1882
|
unless grep.empty? && !pathspec.empty?
|
|
1825
1883
|
grep.map! { |val| Regexp.new(val[1..-2]) }
|
|
1826
|
-
files =
|
|
1827
|
-
status_data.each do |a, b|
|
|
1884
|
+
files = status_data.map do |a, b|
|
|
1828
1885
|
next if b.strip.empty? || (!grep.empty? && grep.none? { |pat| pat.match?(a) })
|
|
1829
1886
|
|
|
1830
|
-
|
|
1887
|
+
"#{sub_style(b, color(:red))} #{a}"
|
|
1831
1888
|
end
|
|
1889
|
+
.compact
|
|
1832
1890
|
unless files.empty?
|
|
1833
1891
|
files = choice_index('Select files', files, multiple: true, trim: /^\S+\s/,
|
|
1834
1892
|
accept: [accept_y('Add?')])
|
|
@@ -1837,23 +1895,17 @@ module Squared
|
|
|
1837
1895
|
end
|
|
1838
1896
|
end
|
|
1839
1897
|
return source(git_session('status -s'), banner: false) unless append_pathspec(op.extras)
|
|
1840
|
-
return success?(source) if flag == :add && !op.arg?('verbose')
|
|
1841
1898
|
when :mv
|
|
1842
1899
|
refs = projectmap op.extras
|
|
1843
1900
|
raise_error 'no source/destination' unless refs.size > 1
|
|
1844
1901
|
op.merge(refs)
|
|
1845
|
-
when :rm, :clean
|
|
1846
|
-
append_pathspec(op.extras, expect: flag
|
|
1902
|
+
when :rm, :clean, :'sparse-checkout'
|
|
1903
|
+
append_pathspec(op.extras, expect: flag != :clean, resolve: flag != :'sparse-checkout')
|
|
1847
1904
|
when :grep
|
|
1848
|
-
delim = false
|
|
1849
1905
|
op.each do |val|
|
|
1850
|
-
if
|
|
1851
|
-
delim = true
|
|
1852
|
-
op.delim
|
|
1853
|
-
elsif delim
|
|
1906
|
+
if op.include?('--')
|
|
1854
1907
|
op.add_path(val)
|
|
1855
1908
|
elsif op.exist?(val, glob: true)
|
|
1856
|
-
delim = true
|
|
1857
1909
|
op.delim
|
|
1858
1910
|
.add_path(val)
|
|
1859
1911
|
else
|
|
@@ -1865,7 +1917,7 @@ module Squared
|
|
|
1865
1917
|
when :revert, :mv, :rm
|
|
1866
1918
|
source(sync: false, stderr: true)
|
|
1867
1919
|
else
|
|
1868
|
-
source
|
|
1920
|
+
success?(source, flag == :'sparse-checkout' || (flag == :add && !op.arg?('verbose')))
|
|
1869
1921
|
end
|
|
1870
1922
|
end
|
|
1871
1923
|
|
|
@@ -1884,27 +1936,28 @@ module Squared
|
|
|
1884
1936
|
private
|
|
1885
1937
|
|
|
1886
1938
|
def source(cmd = @session, exception: true, io: false, sync: true, stdout: false, stderr: false, banner: true,
|
|
1887
|
-
multiple: false, hint: nil, from: nil, send: :system, **kwargs)
|
|
1939
|
+
multiple: false, hint: nil, from: nil, timeout: nil, send: :system, **kwargs)
|
|
1888
1940
|
cmd = cmd.target if cmd.is_a?(OptionPartition)
|
|
1889
1941
|
if io && banner == false
|
|
1890
1942
|
from = nil
|
|
1891
1943
|
banner = nil
|
|
1892
|
-
args = false
|
|
1893
1944
|
else
|
|
1945
|
+
if banner
|
|
1946
|
+
banner = nil unless banner? && !multiple
|
|
1947
|
+
args = true
|
|
1948
|
+
end
|
|
1894
1949
|
if from == false
|
|
1895
1950
|
from = nil
|
|
1896
1951
|
elsif !from && cmd.respond_to?(:drop)
|
|
1897
1952
|
from = cmd.drop(1).find { |val| val.match?(/\A[a-z]{1,2}[a-z-]*\z/) }
|
|
1898
|
-
from &&=
|
|
1899
|
-
end
|
|
1900
|
-
if banner
|
|
1901
|
-
banner = cmd.temp { |val| val.start_with?(/--(work-tree|git-dir)/) } if cmd.respond_to?(:temp)
|
|
1902
|
-
args = true
|
|
1953
|
+
from &&= symjoin 'git', from
|
|
1903
1954
|
end
|
|
1955
|
+
banner &&= cmd.temp { |val| val.start_with?(/--(work-tree|git-dir)/) } if cmd.respond_to?(:temp)
|
|
1904
1956
|
end
|
|
1957
|
+
timeout = session_timeout cmd if timeout.nil?
|
|
1905
1958
|
cmd = session_done cmd
|
|
1906
|
-
log&.info cmd
|
|
1907
|
-
banner = if banner
|
|
1959
|
+
log&.info cmd
|
|
1960
|
+
banner = if banner
|
|
1908
1961
|
format_banner(banner.is_a?(String) ? banner : cmd, hint: hint, strip: true)
|
|
1909
1962
|
end
|
|
1910
1963
|
on :first, from
|
|
@@ -1915,7 +1968,11 @@ module Squared
|
|
|
1915
1968
|
return args ? [IO.popen(cmd), banner || '', from] : IO.popen(cmd)
|
|
1916
1969
|
elsif stdin? ? sync : stdout
|
|
1917
1970
|
print_item banner unless multiple
|
|
1918
|
-
ret =
|
|
1971
|
+
ret = if stdin? && timeout.to_f > 0
|
|
1972
|
+
Timeout.timeout(timeout) { `#{cmd}` }
|
|
1973
|
+
else
|
|
1974
|
+
`#{cmd}`
|
|
1975
|
+
end.chomp
|
|
1919
1976
|
raise(ret.empty? ? $?.to_s : ret) unless $?.success?
|
|
1920
1977
|
|
|
1921
1978
|
if ret.empty?
|
|
@@ -1925,25 +1982,17 @@ module Squared
|
|
|
1925
1982
|
end
|
|
1926
1983
|
elsif !kwargs[:sub] && (sync || (!exception && !stderr))
|
|
1927
1984
|
print_item banner unless multiple
|
|
1928
|
-
ret =
|
|
1985
|
+
ret = shell_t(cmd, name: send, exception: exception, timeout: timeout)
|
|
1986
|
+
elsif timeout.to_f > 0
|
|
1987
|
+
Timeout.timeout(timeout) { run_e(cmd, stderr: stderr, banner: banner, **kwargs) }
|
|
1929
1988
|
else
|
|
1930
|
-
|
|
1931
|
-
if stderr
|
|
1932
|
-
Open3.popen3(cmd) do |_, out, err|
|
|
1933
|
-
n = write_lines(out, banner: banner, pass: true, **kwargs)
|
|
1934
|
-
if n == 0
|
|
1935
|
-
n = write_lines(err, banner: banner)
|
|
1936
|
-
success?(n == 0, n == 0 && !banner.nil?)
|
|
1937
|
-
else
|
|
1938
|
-
write_lines(err, loglevel: Logger::DEBUG)
|
|
1939
|
-
end
|
|
1940
|
-
end
|
|
1941
|
-
else
|
|
1942
|
-
Open3.popen2e(cmd) { |_, out| write_lines(out, banner: banner, **kwargs) }
|
|
1943
|
-
end
|
|
1989
|
+
run_e(cmd, stderr: stderr, banner: banner, **kwargs)
|
|
1944
1990
|
end
|
|
1945
|
-
rescue
|
|
1946
|
-
|
|
1991
|
+
rescue Timeout::Error => e
|
|
1992
|
+
print_error(Logger::ERROR, cmd, subject: name, hint: e)
|
|
1993
|
+
exit 1 unless exception?(Logger::DEBUG, Logger::INFO)
|
|
1994
|
+
rescue => e
|
|
1995
|
+
on_error(e, pass: true)
|
|
1947
1996
|
nil
|
|
1948
1997
|
else
|
|
1949
1998
|
on :last, from
|
|
@@ -1951,32 +2000,6 @@ module Squared
|
|
|
1951
2000
|
end
|
|
1952
2001
|
end
|
|
1953
2002
|
|
|
1954
|
-
def write_lines(data, grep: [], prefix: nil, sub: nil, banner: nil, loglevel: nil, pass: false, first: false)
|
|
1955
|
-
grep = (matchmap(grep, prefix) unless grep.empty?)
|
|
1956
|
-
sub = (as_a sub unless stdin?)
|
|
1957
|
-
ret = 0
|
|
1958
|
-
out = []
|
|
1959
|
-
data.each do |line|
|
|
1960
|
-
next if grep&.none? { |pat| pat.match?(line) }
|
|
1961
|
-
next if block_given? && !(line = yield(line, ret))
|
|
1962
|
-
|
|
1963
|
-
if loglevel
|
|
1964
|
-
log&.add loglevel, line
|
|
1965
|
-
else
|
|
1966
|
-
sub&.each { |h| sub_style!(line, **h) }
|
|
1967
|
-
if banner
|
|
1968
|
-
out << line
|
|
1969
|
-
else
|
|
1970
|
-
puts line
|
|
1971
|
-
end
|
|
1972
|
-
end
|
|
1973
|
-
ret += 1
|
|
1974
|
-
break if first
|
|
1975
|
-
end
|
|
1976
|
-
print_item banner, out if banner && (ret > 0 || (!pass && !first))
|
|
1977
|
-
ret
|
|
1978
|
-
end
|
|
1979
|
-
|
|
1980
2003
|
def list_result(size, type, action: 'found', grep: [], from: nil)
|
|
1981
2004
|
if size == 0
|
|
1982
2005
|
puts empty_status("No #{type} were #{action}", 'grep', grep.join(', '))
|
|
@@ -2012,7 +2035,7 @@ module Squared
|
|
|
2012
2035
|
ret = choice_index('Choose a commit', git_spawn(cmd, stdout: false), column: /^(\S+)/, force: force, **kwargs)
|
|
2013
2036
|
case ret
|
|
2014
2037
|
when Array
|
|
2015
|
-
ret.map
|
|
2038
|
+
ret.map(&:stripstyle)
|
|
2016
2039
|
when String
|
|
2017
2040
|
ret.stripstyle
|
|
2018
2041
|
else
|
|
@@ -2030,24 +2053,18 @@ module Squared
|
|
|
2030
2053
|
algorithm ||= Digest::SHA256
|
|
2031
2054
|
glob = kwargs.fetch(:include, [])
|
|
2032
2055
|
pass = kwargs.fetch(:exclude, [])
|
|
2033
|
-
|
|
2034
|
-
status_data(*args).each do |file,|
|
|
2056
|
+
status_data(*args).map(&:first).each_with_object({}) do |file, out|
|
|
2035
2057
|
next if !glob.empty? && glob.none? { |val| File.fnmatch?(val, file, File::FNM_DOTMATCH) }
|
|
2036
2058
|
next if pass.any? { |val| File.fnmatch?(val, file, File::FNM_DOTMATCH) }
|
|
2037
2059
|
|
|
2038
|
-
|
|
2060
|
+
out[file] = algorithm.hexdigest(File.read(basepath(file)))
|
|
2039
2061
|
end
|
|
2040
|
-
ret
|
|
2041
2062
|
end
|
|
2042
2063
|
|
|
2043
2064
|
def status_data(*args)
|
|
2044
|
-
|
|
2045
|
-
|
|
2046
|
-
next unless line =~ /^(.)(.) (.+)$/
|
|
2047
|
-
|
|
2048
|
-
ret << [$3, $2, $1]
|
|
2065
|
+
git_spawn('status -z -uall', *args).split("\x0").each_with_object([]) do |line, out|
|
|
2066
|
+
out << [$3, $2, $1] if line =~ /^(.)(.) (.+)$/
|
|
2049
2067
|
end
|
|
2050
|
-
ret
|
|
2051
2068
|
end
|
|
2052
2069
|
|
|
2053
2070
|
def append_pull(opts, list, flag:, from:, target: @session, no: nil, remote: nil)
|
|
@@ -2055,9 +2072,8 @@ module Squared
|
|
|
2055
2072
|
append_submodules(target: target, from: from)
|
|
2056
2073
|
return if !remote && opts.empty?
|
|
2057
2074
|
|
|
2058
|
-
refspec = []
|
|
2059
2075
|
op = OptionPartition.new(opts, remote ? list + ['refspec=v'] : list, target, project: self, no: no)
|
|
2060
|
-
op.
|
|
2076
|
+
refspec = op.each_with_object([]) do |opt, out|
|
|
2061
2077
|
if opt =~ op.values
|
|
2062
2078
|
case $1
|
|
2063
2079
|
when 'rebase'
|
|
@@ -2068,7 +2084,7 @@ module Squared
|
|
|
2068
2084
|
when 'recurse-submodules'
|
|
2069
2085
|
op.append?($1, $2, type: :basic)
|
|
2070
2086
|
when 'refspec'
|
|
2071
|
-
|
|
2087
|
+
out << shell_quote($2)
|
|
2072
2088
|
end
|
|
2073
2089
|
elsif op.arg?('multiple')
|
|
2074
2090
|
op.found << opt
|
|
@@ -2080,7 +2096,7 @@ module Squared
|
|
|
2080
2096
|
if remote
|
|
2081
2097
|
op.append(remote, delim: true)
|
|
2082
2098
|
if (val = option('refspec', target: target, strict: true))
|
|
2083
|
-
op.append(
|
|
2099
|
+
op.append(split_escape(val))
|
|
2084
2100
|
else
|
|
2085
2101
|
op.merge(refspec)
|
|
2086
2102
|
end
|
|
@@ -2094,27 +2110,31 @@ module Squared
|
|
|
2094
2110
|
op.clear(errors: true, subject: flag) if flag
|
|
2095
2111
|
end
|
|
2096
2112
|
|
|
2097
|
-
def append_commit(*
|
|
2098
|
-
|
|
2099
|
-
if !
|
|
2100
|
-
|
|
2113
|
+
def append_commit(*refs, target: @session, head: false)
|
|
2114
|
+
refs.compact!
|
|
2115
|
+
if !refs.empty?
|
|
2116
|
+
target.merge(refs.map { |val| commithash(val) || shell_quote(val) })
|
|
2101
2117
|
elsif head
|
|
2102
2118
|
target << (append_head(target: target) || 'HEAD')
|
|
2103
2119
|
end
|
|
2104
2120
|
end
|
|
2105
2121
|
|
|
2106
|
-
def append_pathspec(files = [], target: @session, expect: false,
|
|
2122
|
+
def append_pathspec(files = [], target: @session, expect: false, **kwargs)
|
|
2107
2123
|
if session_arg?('pathspec-from-file', target: target)
|
|
2108
|
-
|
|
2124
|
+
OptionPartition.clear(target, files, styles: theme[:inline])
|
|
2109
2125
|
true
|
|
2110
2126
|
else
|
|
2111
2127
|
option('pathspec', target: target) { |val| files = split_escape(val) } if files.empty?
|
|
2112
|
-
files = projectmap(files,
|
|
2128
|
+
files = projectmap(files, **kwargs)
|
|
2113
2129
|
if !files.empty?
|
|
2114
2130
|
target << '--' << files.join(' ')
|
|
2115
2131
|
true
|
|
2116
2132
|
elsif expect
|
|
2117
|
-
raise_error(
|
|
2133
|
+
raise_error(if expect.is_a?(String)
|
|
2134
|
+
expect
|
|
2135
|
+
else
|
|
2136
|
+
kwargs[:parent] ? 'pathspec not present' : 'pathspec not within worktree'
|
|
2137
|
+
end)
|
|
2118
2138
|
else
|
|
2119
2139
|
false
|
|
2120
2140
|
end
|
|
@@ -2123,7 +2143,9 @@ module Squared
|
|
|
2123
2143
|
|
|
2124
2144
|
def append_message(val = nil, target: @session)
|
|
2125
2145
|
val = messageopt if val.to_s.empty?
|
|
2126
|
-
|
|
2146
|
+
return unless val
|
|
2147
|
+
|
|
2148
|
+
target << quote_option('message', val)
|
|
2127
2149
|
end
|
|
2128
2150
|
|
|
2129
2151
|
def append_head(val = nil, target: @session)
|
|
@@ -2156,11 +2178,15 @@ module Squared
|
|
|
2156
2178
|
end
|
|
2157
2179
|
end
|
|
2158
2180
|
|
|
2159
|
-
def foreachref(path, *args, format: nil)
|
|
2160
|
-
path = Array(path).map
|
|
2181
|
+
def foreachref(path, *args, format: nil, chomp: true)
|
|
2182
|
+
path = Array(path).map { |val| "refs/#{val}" }
|
|
2161
2183
|
format &&= quote_option('format', format)
|
|
2162
2184
|
ret = git_spawn('for-each-ref', format, *args, *path, stdout: workspace.windows?)
|
|
2163
|
-
ret.is_a?(String)
|
|
2185
|
+
if ret.is_a?(String)
|
|
2186
|
+
ret.lines(chomp: chomp)
|
|
2187
|
+
else
|
|
2188
|
+
chomp ? ret.readlines(chomp: chomp) : ret
|
|
2189
|
+
end
|
|
2164
2190
|
end
|
|
2165
2191
|
|
|
2166
2192
|
def git_session(*cmd, opts: nil, worktree: true, **kwargs)
|
|
@@ -2207,7 +2233,9 @@ module Squared
|
|
|
2207
2233
|
raise_error(ArgumentError, "missing #{origin ? 'branch' : 'remote'} name", hint: origin)
|
|
2208
2234
|
end
|
|
2209
2235
|
branch = "#{branch}:#{origin[i.succ..-1]}" unless origin.end_with?("/#{branch}")
|
|
2210
|
-
[origin[0..i.pred], branch]
|
|
2236
|
+
ret = [origin[0..i.pred], branch]
|
|
2237
|
+
ret.quote! if quote
|
|
2238
|
+
ret
|
|
2211
2239
|
end
|
|
2212
2240
|
|
|
2213
2241
|
def commithash(val)
|
|
@@ -2232,16 +2260,22 @@ module Squared
|
|
|
2232
2260
|
[/\A[^a-z\d-]+/i, %r{\A[^=\\/*]*[\\/*]}, /\A--\z/]
|
|
2233
2261
|
end
|
|
2234
2262
|
|
|
2263
|
+
def matchfile(file, pat)
|
|
2264
|
+
file.read[pat, 0] if file.exist?
|
|
2265
|
+
rescue
|
|
2266
|
+
nil
|
|
2267
|
+
end
|
|
2268
|
+
|
|
2235
2269
|
def messageopt
|
|
2236
2270
|
option('message', 'm', prefix: 'git', ignore: false)
|
|
2237
2271
|
end
|
|
2238
2272
|
|
|
2239
2273
|
def threadargs
|
|
2240
|
-
{ stderr: true, exception: exception || !workspace.series.multiple? }
|
|
2274
|
+
{ stderr: true, exception: exception? || !workspace.series.multiple? }
|
|
2241
2275
|
end
|
|
2242
2276
|
end
|
|
2243
2277
|
|
|
2244
|
-
Application.implement Git
|
|
2278
|
+
Application.implement Git, base: 1
|
|
2245
2279
|
end
|
|
2246
2280
|
end
|
|
2247
2281
|
end
|