… | |
… | |
6 | my ($self) = @_; |
6 | my ($self) = @_; |
7 | |
7 | |
8 | $self->{random_id} = $1; |
8 | $self->{random_id} = $1; |
9 | |
9 | |
10 | if (0 < Coro::AIO::aio_load "$cf::RANDOMDIR/$self->{random_id}.meta", my $data) { |
10 | if (0 < Coro::AIO::aio_load "$cf::RANDOMDIR/$self->{random_id}.meta", my $data) { |
11 | $self->{random} = cf::from_json $data; |
11 | $self->{random} = cf::decode_json $data; |
12 | $self->{random}{custom} ||= "$self->{random}{origin_map}+$self->{random}{origin_x}+$self->{random}{origin_y}"; |
12 | $self->{random}{custom} ||= "$self->{random}{origin_map}+$self->{random}{origin_x}+$self->{random}{origin_y}"; |
13 | } else { |
13 | } else { |
14 | warn "unable to read meta file for $self->{random_id}\n"; |
14 | warn "unable to read meta file for $self->{random_id}\n"; |
15 | return 0; |
15 | return 0; |
16 | } |
16 | } |
… | |
… | |
74 | } |
74 | } |
75 | } |
75 | } |
76 | } |
76 | } |
77 | |
77 | |
78 | # clean up old temp maps regularly |
78 | # clean up old temp maps regularly |
79 | Event->timer ( |
79 | our $CLEAN_RANDOM_MAPS = cf::periodic 3600, Coro::unblock_sub { |
80 | reentrant => 0, |
80 | clean_random_maps; |
81 | data => cf::WF_AUTOCANCEL, |
81 | }; |
82 | interval => 3600, |
|
|
83 | after => 60, |
|
|
84 | cb => Coro::unblock_sub { clean_random_maps }, |
|
|
85 | ); |
|
|
86 | |
82 | |
87 | # map generator stresstest, never enable under normal circumstances |
83 | # map generator stresstest, never enable under normal circumstances |
88 | if (0) { |
84 | if (0) { |
89 | cf::async { |
85 | cf::async { |
90 | my $seed = 0; |
86 | my $seed = 0; |