diff options
| author | Steve Slaven <bpk@hoopajoo.net> | 2009-07-23 21:45:31 (GMT) | 
|---|---|---|
| committer | Steve Slaven <bpk@hoopajoo.net> | 2009-07-23 21:45:31 (GMT) | 
| commit | c5ac8d9dfddf293db4987fd0f06068dec369f2d0 (patch) | |
| tree | decc05641e967ec91fccc90c7e9e3b551ae7caae | |
| parent | 0171712a2516e638f1dd2a8e247fc44433babbd8 (diff) | |
| download | fusearchive-c5ac8d9dfddf293db4987fd0f06068dec369f2d0.zip fusearchive-c5ac8d9dfddf293db4987fd0f06068dec369f2d0.tar.gz fusearchive-c5ac8d9dfddf293db4987fd0f06068dec369f2d0.tar.bz2 | |
Data reading seems to work
| -rwxr-xr-x | fusearchive.py | 28 | 
1 files changed, 20 insertions, 8 deletions
| diff --git a/fusearchive.py b/fusearchive.py index f648235..bcfed7c 100755 --- a/fusearchive.py +++ b/fusearchive.py @@ -435,21 +435,33 @@ class FuseArchive(Fuse):                  + " length: " + str( length ) )              data_read = 0 -            data = None +            data = ''              index = int( offset / self.chunk_size )              rest = offset % self.chunk_size +            is_eof = False              # Keep reading chunks until we have at least this much data -            while data_read < length: +            while data_read < length and not is_eof:                  dmsg( 3, "Pulling chunk data" )                  self._load_chunk( index ) -                chunk_remaining = self.chunk_size - rest -                data += substr( self.chunk[ rest:chunk_remaining ] ) -                data_read = len( data ) -                index += 1 -                rest = 0 +                if len(self.chunk): +                    chunk_remaining = len(self.chunk) - rest +                    to_read = chunk_remaining +                    data_left = length - data_read +                    if data_left < chunk_remaining: +                        to_read = data_left + +                    dmsg( 3, "Copying " + str(to_read) + " bytes" ) + +                    data += self.chunk[ rest:chunk_remaining ] +                    data_read += to_read +                    index += 1 +                    rest = 0 +                else: +                    dmsg( 3, "No more chunk data, bye" ) +                    is_eof = True -            return data[ :length ] +            return data          def write(self, buf, offset):              dmsg( 3, "Writing to " + self.orig_path + " offset: " + str( offset ) ) | 
