… | |
… | |
476 | } |
476 | } |
477 | } |
477 | } |
478 | } |
478 | } |
479 | |
479 | |
480 | sub object_freezer_save { |
480 | sub object_freezer_save { |
481 | my ($filename, $objs) = @_; |
481 | my ($filename, $rdata, $objs) = @_; |
482 | |
482 | |
483 | if (@$objs) { |
483 | if (length $$rdata) { |
|
|
484 | warn sprintf "saving %s (%d,%d)\n", |
|
|
485 | $filename, length $$rdata, scalar @$objs; |
|
|
486 | |
484 | open my $fh, ">:raw", "$filename.pst~"; |
487 | if (open my $fh, ">:raw", "$filename~") { |
|
|
488 | chmod SAVE_MODE, $fh; |
|
|
489 | syswrite $fh, $$rdata; |
|
|
490 | close $fh; |
|
|
491 | |
|
|
492 | if (@$objs && open my $fh, ">:raw", "$filename.pst~") { |
|
|
493 | chmod SAVE_MODE, $fh; |
485 | syswrite $fh, Storable::nfreeze { version => 1, objs => $objs }; |
494 | syswrite $fh, Storable::nfreeze { version => 1, objs => $objs }; |
486 | close $fh; |
495 | close $fh; |
487 | chmod SAVE_MODE, "$filename.pst~"; |
|
|
488 | rename "$filename.pst~", "$filename.pst"; |
496 | rename "$filename.pst~", "$filename.pst"; |
|
|
497 | } else { |
|
|
498 | unlink "$filename.pst"; |
|
|
499 | } |
|
|
500 | |
|
|
501 | rename "$filename~", $filename; |
|
|
502 | } else { |
|
|
503 | warn "FATAL: $filename~: $!\n"; |
|
|
504 | } |
489 | } else { |
505 | } else { |
|
|
506 | unlink $filename; |
490 | unlink "$filename.pst"; |
507 | unlink "$filename.pst"; |
491 | } |
508 | } |
492 | |
|
|
493 | chmod SAVE_MODE, "$filename~"; |
|
|
494 | rename "$filename~", $filename; |
|
|
495 | } |
509 | } |
496 | |
510 | |
497 | sub object_thawer_load { |
511 | sub object_thawer_load { |
498 | my ($filename) = @_; |
512 | my ($filename) = @_; |
499 | |
513 | |
… | |
… | |
773 | |
787 | |
774 | sub all_objects(@) { |
788 | sub all_objects(@) { |
775 | @_, map all_objects ($_->inv), @_ |
789 | @_, map all_objects ($_->inv), @_ |
776 | } |
790 | } |
777 | |
791 | |
|
|
792 | # TODO: compatibility cruft, remove when no longer needed |
778 | attach_to_players |
793 | attach_to_players |
779 | on_load => sub { |
794 | on_load => sub { |
780 | my ($pl, $path) = @_; |
795 | my ($pl, $path) = @_; |
781 | |
796 | |
782 | for my $o (all_objects $pl->ob) { |
797 | for my $o (all_objects $pl->ob) { |