Commit 5bc1fd42 authored by Raghavendra Nagaraj's avatar Raghavendra Nagaraj Committed by Robert Griesemer

container/list: combining insert and remove operations while moving elements within a list.

Fixes #27747

Change-Id: I843e9e121d33440648b364650ee8a8a1639a0144
GitHub-Last-Rev: c614e91e23d4d3dea80bc78886a1b7e96456596b
GitHub-Pull-Request: golang/go#28413
Reviewed-on: https://go-review.googlesource.com/c/144998Reviewed-by: default avatarRobert Griesemer <gri@golang.org>
Run-TryBot: Robert Griesemer <gri@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent 18b84cbd
...@@ -116,6 +116,23 @@ func (l *List) remove(e *Element) *Element { ...@@ -116,6 +116,23 @@ func (l *List) remove(e *Element) *Element {
return e return e
} }
// move moves e to next to at and returns e.
func (l *List) move(e, at *Element) *Element {
if e == at {
return e
}
e.prev.next = e.next
e.next.prev = e.prev
n := at.next
at.next = e
e.prev = at
e.next = n
n.prev = e
return e
}
// Remove removes e from l if e is an element of list l. // Remove removes e from l if e is an element of list l.
// It returns the element value e.Value. // It returns the element value e.Value.
// The element must not be nil. // The element must not be nil.
...@@ -170,7 +187,7 @@ func (l *List) MoveToFront(e *Element) { ...@@ -170,7 +187,7 @@ func (l *List) MoveToFront(e *Element) {
return return
} }
// see comment in List.Remove about initialization of l // see comment in List.Remove about initialization of l
l.insert(l.remove(e), &l.root) l.move(e, &l.root)
} }
// MoveToBack moves element e to the back of list l. // MoveToBack moves element e to the back of list l.
...@@ -181,7 +198,7 @@ func (l *List) MoveToBack(e *Element) { ...@@ -181,7 +198,7 @@ func (l *List) MoveToBack(e *Element) {
return return
} }
// see comment in List.Remove about initialization of l // see comment in List.Remove about initialization of l
l.insert(l.remove(e), l.root.prev) l.move(e, l.root.prev)
} }
// MoveBefore moves element e to its new position before mark. // MoveBefore moves element e to its new position before mark.
...@@ -191,7 +208,7 @@ func (l *List) MoveBefore(e, mark *Element) { ...@@ -191,7 +208,7 @@ func (l *List) MoveBefore(e, mark *Element) {
if e.list != l || e == mark || mark.list != l { if e.list != l || e == mark || mark.list != l {
return return
} }
l.insert(l.remove(e), mark.prev) l.move(e, mark.prev)
} }
// MoveAfter moves element e to its new position after mark. // MoveAfter moves element e to its new position after mark.
...@@ -201,7 +218,7 @@ func (l *List) MoveAfter(e, mark *Element) { ...@@ -201,7 +218,7 @@ func (l *List) MoveAfter(e, mark *Element) {
if e.list != l || e == mark || mark.list != l { if e.list != l || e == mark || mark.list != l {
return return
} }
l.insert(l.remove(e), mark) l.move(e, mark)
} }
// PushBackList inserts a copy of an other list at the back of list l. // PushBackList inserts a copy of an other list at the back of list l.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment