From 25c268ac886e0085a226942eff734c7fe8331ef2 Mon Sep 17 00:00:00 2001 From: "Frederick F. Kautz IV" Date: Fri, 1 May 2015 17:45:40 -0700 Subject: [PATCH] Attempt to fix memory lock on Get preventing write --- pkg/storage/drivers/memory/memory.go | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/pkg/storage/drivers/memory/memory.go b/pkg/storage/drivers/memory/memory.go index 8b2f32be5..6fef5b233 100644 --- a/pkg/storage/drivers/memory/memory.go +++ b/pkg/storage/drivers/memory/memory.go @@ -100,14 +100,16 @@ func start(ctrlChannel <-chan string, errorChannel chan<- error) { // GetObject - GET object from memory buffer func (memory *memoryDriver) GetObject(w io.Writer, bucket string, object string) (int64, error) { memory.lock.RLock() - defer memory.lock.RUnlock() if !drivers.IsValidBucket(bucket) { + memory.lock.RUnlock() return 0, iodine.New(drivers.BucketNameInvalid{Bucket: bucket}, nil) } if !drivers.IsValidObject(object) { + memory.lock.RUnlock() return 0, iodine.New(drivers.ObjectNameInvalid{Object: object}, nil) } if _, ok := memory.storedBuckets[bucket]; ok == false { + memory.lock.RUnlock() return 0, iodine.New(drivers.BucketNotFound{Bucket: bucket}, nil) } storedBucket := memory.storedBuckets[bucket] @@ -117,11 +119,13 @@ func (memory *memoryDriver) GetObject(w io.Writer, bucket string, object string) if data, ok := memory.objects.Get(objectKey); ok { dataSlice := data.([]byte) objectBuffer := bytes.NewBuffer(dataSlice) - written, err := io.Copy(w, objectBuffer) + memory.lock.RUnlock() go memory.updateAccessTime(objectKey) + written, err := io.Copy(w, objectBuffer) return written, iodine.New(err, nil) } } + memory.lock.RUnlock() return 0, iodine.New(drivers.ObjectNotFound{Bucket: bucket, Object: object}, nil) }