What's new? | Help | Directory | Sign in
Google
gears
Improving Your Web Browser
  
  
  
    
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// Copyright 2008, Google Inc.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// 2. Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// 3. Neither the name of Google Inc. nor the names of its contributors may be
// used to endorse or promote products derived from this software without
// specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
// EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

#include <assert.h>

#include "gears/blob/slice_blob.h"

SliceBlob::SliceBlob(BlobInterface *source, int64 offset, int64 length)
: blob_(source), offset_(offset), length_(length) {
// We explicitly allow offset and length to indicate a slice that extends
// beyond the end of the source blob, although Read will return no data for
// that portion.
assert(offset_ >= 0);
assert(length_ >= 0);
}

int64 SliceBlob::Read(uint8 *destination, int64 offset, int64 max_bytes) const {
if (offset < 0 || max_bytes < 0) {
return -1;
}
if (offset >= length_) {
return 0;
}
int64 available = length_ - offset;
if (available > max_bytes) {
available = max_bytes;
}
return blob_->Read(destination, offset_ + offset, available);
}

int64 SliceBlob::ReadDirect(Reader *reader, int64 offset,
int64 max_bytes) const {
if (offset < 0 || max_bytes < 0) {
return -1;
}
if (offset >= length_) {
return 0;
}
int64 available = length_ - offset;
if (available > max_bytes) {
available = max_bytes;
}
return blob_->ReadDirect(reader, offset_ + offset, available);
}


int64 SliceBlob::Length() const {
return length_;
}

bool SliceBlob::GetDataElements(std::vector<DataElement> *elements) const {
assert(elements && elements->empty());

std::vector<DataElement> nested_elements;
if (!blob_->GetDataElements(&nested_elements)) {
return false;
}

if (!nested_elements.empty()) {
std::vector<DataElement>::iterator iter = nested_elements.begin();

// Skip over elements until we reach our offset_
uint64 skip_remaining = static_cast<uint64>(offset_);
while (skip_remaining > 0 && iter != nested_elements.end()) {
uint64 content_length = (*iter).GetContentLength();
if (content_length > skip_remaining) {
(*iter).TrimFront(skip_remaining);
break; // don't advance the iter, this element is included below
}
skip_remaining -= content_length;
++iter;
}

// Include elements until we reach our length_
uint64 include_remaining = static_cast<uint64>(length_);
while (include_remaining > 0 && iter != nested_elements.end()) {
uint64 content_length = (*iter).GetContentLength();
if (content_length > include_remaining) {
(*iter).TrimToLength(include_remaining);
content_length = include_remaining;
}
elements->push_back(*iter);
include_remaining -= content_length;
++iter;
}
}

return true;
}
Show details Hide details

Change log

r2413 by gears.daemon on Jul 17 (6 days ago)   Diff
[Author: bgarcia]

Add an interface to blobs to allow direct
access to the internal
buffer.  Update blob stream
implementations to use this interface.

PRESUBMIT=passed
R=bpm
CC=gears-eng@googlegroups.com
DELTA=315  (246 added, 29 deleted, 40
changed)
...
Go to: 
Project members, sign in to write a code review

Older revisions

r2261 by gears.daemon on Jul 07, 2008   Diff
[Author: michaeln]

Add a method to peer into the
constituent DataElements that make up
a Blob.
...
r1936 by gears.daemon on Jun 11, 2008   Diff
[Author: fry]

make blob support official!

PRESUBMIT=passed
...
r1245 by gears.daemon on Mar 24, 2008   Diff
[Author: bpm]

- Migrate BlobInterface::Read,
ReadFileSegmentToBuffer, and
BufferBlob::Append to use 64-bit
...
All revisions of this file

File info

Size: 4005 bytes, 111 lines