1 package DBM::Deep::Engine::Sector::Scalar;
6 use warnings FATAL => 'all';
8 use base qw( DBM::Deep::Engine::Sector::Data );
13 my $chain_loc = $self->chain_loc;
18 $self->engine->_load_sector( $chain_loc )->free;
24 sub type { $_[0]{engine}->SIG_DATA }
28 my $engine = $self->engine;
30 unless ( $self->offset ) {
31 my $data_section = $self->size - $self->base_size - $engine->byte_size - 1;
33 $self->{offset} = $engine->_request_data_sector( $self->size );
35 my $data = delete $self->{data};
36 my $dlen = length $data;
38 my $curr_offset = $self->offset;
43 my ($leftover, $this_len, $chunk);
44 if ( $dlen > $data_section ) {
46 $this_len = $data_section;
47 $chunk = substr( $data, 0, $this_len );
49 $dlen -= $data_section;
50 $next_offset = $engine->_request_data_sector( $self->size );
51 $data = substr( $data, $this_len );
54 $leftover = $data_section - $dlen;
61 $engine->storage->print_at( $curr_offset, $self->type ); # Sector type
63 $engine->storage->print_at( $curr_offset + $self->base_size,
64 pack( $StP{$engine->byte_size}, $next_offset ), # Chain loc
65 pack( $StP{1}, $this_len ), # Data length
66 $chunk, # Data to be stored in this sector
67 chr(0) x $leftover, # Zero-fill the rest
70 $curr_offset = $next_offset;
80 my $buffer = $self->engine->storage->read_at(
81 $self->offset + $self->base_size + $self->engine->byte_size, 1
84 return unpack( $StP{1}, $buffer );
90 $StP{$self->engine->byte_size},
91 $self->engine->storage->read_at(
92 $self->offset + $self->base_size,
93 $self->engine->byte_size,
105 my $chain_loc = $self->chain_loc;
107 $data .= $self->engine->storage->read_at(
108 $self->offset + $self->base_size + $self->engine->byte_size + 1, $self->data_length,
111 last unless $chain_loc;
113 $self = $self->engine->_load_sector( $chain_loc );