summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRuss Cox <rsc@golang.org>2010-05-01 13:00:01 -0700
committerRuss Cox <rsc@golang.org>2010-05-01 13:00:01 -0700
commit3696f3a6f5e76706405160ea1f6495c4e252ea78 (patch)
treeed0b2746cac657949a2630caea24867bca514035
parente381f86f6e779eea898e6b75811ce76616ede607 (diff)
downloadgolang-3696f3a6f5e76706405160ea1f6495c4e252ea78.tar.gz
vector: use correct capacity in call to make
R=gri, r, bflm CC=golang-dev http://codereview.appspot.com/1032043
-rw-r--r--src/pkg/container/vector/intvector.go7
-rw-r--r--src/pkg/container/vector/stringvector.go7
-rw-r--r--src/pkg/container/vector/vector.go3
3 files changed, 11 insertions, 6 deletions
diff --git a/src/pkg/container/vector/intvector.go b/src/pkg/container/vector/intvector.go
index a1754a94f..708108b18 100644
--- a/src/pkg/container/vector/intvector.go
+++ b/src/pkg/container/vector/intvector.go
@@ -12,6 +12,9 @@ func (p *IntVector) realloc(length, capacity int) (b []int) {
if capacity < initialSize {
capacity = initialSize
}
+ if capacity < length {
+ capacity = length
+ }
b = make(IntVector, length, capacity)
copy(b, *p)
*p = b
@@ -186,9 +189,7 @@ func (p *IntVector) Pop() int {
// AppendVector appends the entire vector x to the end of this vector.
-func (p *IntVector) AppendVector(x *IntVector) {
- p.InsertVector(len(*p), x)
-}
+func (p *IntVector) AppendVector(x *IntVector) { p.InsertVector(len(*p), x) }
// Swap exchanges the elements at indexes i and j.
diff --git a/src/pkg/container/vector/stringvector.go b/src/pkg/container/vector/stringvector.go
index fad20f58a..86563ca20 100644
--- a/src/pkg/container/vector/stringvector.go
+++ b/src/pkg/container/vector/stringvector.go
@@ -12,6 +12,9 @@ func (p *StringVector) realloc(length, capacity int) (b []string) {
if capacity < initialSize {
capacity = initialSize
}
+ if capacity < length {
+ capacity = length
+ }
b = make(StringVector, length, capacity)
copy(b, *p)
*p = b
@@ -186,9 +189,7 @@ func (p *StringVector) Pop() string {
// AppendVector appends the entire vector x to the end of this vector.
-func (p *StringVector) AppendVector(x *StringVector) {
- p.InsertVector(len(*p), x)
-}
+func (p *StringVector) AppendVector(x *StringVector) { p.InsertVector(len(*p), x) }
// Swap exchanges the elements at indexes i and j.
diff --git a/src/pkg/container/vector/vector.go b/src/pkg/container/vector/vector.go
index 99c7753da..077172096 100644
--- a/src/pkg/container/vector/vector.go
+++ b/src/pkg/container/vector/vector.go
@@ -12,6 +12,9 @@ func (p *Vector) realloc(length, capacity int) (b []interface{}) {
if capacity < initialSize {
capacity = initialSize
}
+ if capacity < length {
+ capacity = length
+ }
b = make(Vector, length, capacity)
copy(b, *p)
*p = b