Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
ac9229a3
Commit
ac9229a3
authored
Aug 04, 2016
by
Sean McGivern
Committed by
Fatih Acet
Aug 12, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Clarify Conflict::File#sections method
parent
427e7246
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
31 additions
and
14 deletions
+31
-14
lib/gitlab/conflict/file.rb
lib/gitlab/conflict/file.rb
+19
-3
spec/lib/gitlab/conflict/file_spec.rb
spec/lib/gitlab/conflict/file_spec.rb
+12
-11
No files found.
lib/gitlab/conflict/file.rb
View file @
ac9229a3
...
@@ -79,6 +79,9 @@ module Gitlab
...
@@ -79,6 +79,9 @@ module Gitlab
def
sections
def
sections
return
@sections
if
@sections
return
@sections
if
@sections
# Any line beginning with a letter, an underscore, or a dollar can be used in a
# match line header. Only context sections can contain match lines, as match lines
# have to exist in both versions of the file.
candidate_match_headers
=
lines
.
map
do
|
line
|
candidate_match_headers
=
lines
.
map
do
|
line
|
"
#{
line
.
text
}
"
if
line
.
text
.
match
(
/\A[A-Za-z$_]/
)
&&
line
.
type
.
nil?
"
#{
line
.
text
}
"
if
line
.
text
.
match
(
/\A[A-Za-z$_]/
)
&&
line
.
type
.
nil?
end
end
...
@@ -89,19 +92,24 @@ module Gitlab
...
@@ -89,19 +92,24 @@ module Gitlab
@sections
=
chunked_lines
.
flat_map
.
with_index
do
|
(
no_conflict
,
lines
),
i
|
@sections
=
chunked_lines
.
flat_map
.
with_index
do
|
(
no_conflict
,
lines
),
i
|
section
=
nil
section
=
nil
# We need to reduce context sections to CONTEXT_LINES. Conflict sections are
# always shown in full.
if
no_conflict
if
no_conflict
conflict_before
=
i
>
0
conflict_before
=
i
>
0
conflict_after
=
chunked_lines
.
peek
conflict_after
=
chunked_lines
.
peek
if
conflict_before
&&
conflict_after
if
conflict_before
&&
conflict_after
# Create a gap in a long context section.
if
lines
.
length
>
CONTEXT_LINES
*
2
if
lines
.
length
>
CONTEXT_LINES
*
2
head_lines
=
lines
.
first
(
CONTEXT_LINES
)
head_lines
=
lines
.
first
(
CONTEXT_LINES
)
tail_lines
=
lines
.
last
(
CONTEXT_LINES
)
tail_lines
=
lines
.
last
(
CONTEXT_LINES
)
# Ensure any existing match line has text for all lines up to the last
# line of its context.
update_match_line_text
(
match_line
,
head_lines
.
last
,
candidate_match_headers
)
update_match_line_text
(
match_line
,
head_lines
.
last
,
candidate_match_headers
)
# Insert a new match line after the created gap.
match_line
=
create_match_line
(
tail_lines
.
first
)
match_line
=
create_match_line
(
tail_lines
.
first
)
update_match_line_text
(
match_line
,
tail_lines
.
last
,
candidate_match_headers
)
section
=
[
section
=
[
{
conflict:
false
,
lines:
head_lines
},
{
conflict:
false
,
lines:
head_lines
},
...
@@ -111,7 +119,8 @@ module Gitlab
...
@@ -111,7 +119,8 @@ module Gitlab
elsif
conflict_after
elsif
conflict_after
tail_lines
=
lines
.
last
(
CONTEXT_LINES
)
tail_lines
=
lines
.
last
(
CONTEXT_LINES
)
if
lines
.
length
>
CONTEXT_LINES
# Create a gap and insert a match line at the start.
if
lines
.
length
>
tail_lines
.
length
match_line
=
create_match_line
(
tail_lines
.
first
)
match_line
=
create_match_line
(
tail_lines
.
first
)
tail_lines
.
unshift
(
match_line
)
tail_lines
.
unshift
(
match_line
)
...
@@ -119,10 +128,14 @@ module Gitlab
...
@@ -119,10 +128,14 @@ module Gitlab
lines
=
tail_lines
lines
=
tail_lines
elsif
conflict_before
elsif
conflict_before
# We're at the end of the file (no conflicts after), so just remove extra
# trailing lines.
lines
=
lines
.
first
(
CONTEXT_LINES
)
lines
=
lines
.
first
(
CONTEXT_LINES
)
end
end
end
end
# We want to update the match line's text every time unless we've already
# created a gap and its corresponding match line.
update_match_line_text
(
match_line
,
lines
.
last
,
candidate_match_headers
)
unless
section
update_match_line_text
(
match_line
,
lines
.
last
,
candidate_match_headers
)
unless
section
section
||=
{
conflict:
!
no_conflict
,
lines:
lines
}
section
||=
{
conflict:
!
no_conflict
,
lines:
lines
}
...
@@ -139,10 +152,13 @@ module Gitlab
...
@@ -139,10 +152,13 @@ module Gitlab
Gitlab
::
Diff
::
Line
.
new
(
''
,
'match'
,
line
.
index
,
line
.
old_pos
,
line
.
new_pos
)
Gitlab
::
Diff
::
Line
.
new
(
''
,
'match'
,
line
.
index
,
line
.
old_pos
,
line
.
new_pos
)
end
end
# Set the match line's text for the current line. A match line takes its start
# position and context header (where present) from itself, and its end position from
# the line passed in.
def
update_match_line_text
(
match_line
,
line
,
headers
)
def
update_match_line_text
(
match_line
,
line
,
headers
)
return
unless
match_line
return
unless
match_line
header
=
headers
.
first
(
line
.
index
).
compact
.
last
header
=
headers
.
first
(
match_
line
.
index
).
compact
.
last
match_line
.
text
=
"@@ -
#{
match_line
.
old_pos
}
,
#{
line
.
old_pos
}
+
#{
match_line
.
new_pos
}
,
#{
line
.
new_pos
}
@@
#{
header
}
"
match_line
.
text
=
"@@ -
#{
match_line
.
old_pos
}
,
#{
line
.
old_pos
}
+
#{
match_line
.
new_pos
}
,
#{
line
.
new_pos
}
@@
#{
header
}
"
end
end
...
...
spec/lib/gitlab/conflict/file_spec.rb
View file @
ac9229a3
...
@@ -86,19 +86,20 @@ describe Gitlab::Conflict::File, lib: true do
...
@@ -86,19 +86,20 @@ describe Gitlab::Conflict::File, lib: true do
end
end
describe
'#sections'
do
describe
'#sections'
do
it
'returns match lines when there is a gap between sections'
do
it
'only inserts match lines when there is a gap between sections'
do
section
=
conflict_file
.
sections
[
5
]
conflict_file
.
sections
.
each_with_index
do
|
section
,
i
|
match_line
=
section
[
:lines
][
0
]
previous_line_number
=
0
current_line_number
=
section
[
:lines
].
map
(
&
:old_line
).
compact
.
min
expect
(
section
[
:conflict
]).
to
be_falsey
if
i
>
0
expect
(
match_line
.
type
).
to
eq
(
'match'
)
previous_line_number
=
conflict_file
.
sections
[
i
-
1
][
:lines
].
map
(
&
:old_line
).
compact
.
last
expect
(
match_line
.
text
).
to
eq
(
'@@ -46,53 +46,53 @@ module Gitlab'
)
end
end
it
'does not return match lines when there is no gap between sections'
do
if
current_line_number
==
previous_line_number
+
1
conflict_file
.
sections
.
each_with_index
do
|
section
,
i
|
expect
(
section
[
:lines
].
first
.
type
).
not_to
eq
(
'match'
)
unless
i
==
5
else
expect
(
section
[
:lines
][
0
].
type
).
not_to
eq
(
5
)
expect
(
section
[
:lines
].
first
.
type
).
to
eq
(
'match'
)
expect
(
section
[
:lines
].
first
.
text
).
to
match
(
/\A@@ -
#{
current_line_number
}
,\d+ \+\d+,\d+ @@ module Gitlab\Z/
)
end
end
end
end
end
end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment