1 | #! perl |
1 | #! perl # MANDATORY |
2 | |
2 | |
3 | use base "cf::path"; |
3 | cf::map->register (qr{^\?random/([0-9a-f]{32})}); |
4 | |
|
|
5 | __PACKAGE__->register ("random"); |
|
|
6 | |
4 | |
7 | sub init { |
5 | sub init { |
8 | my ($self) = @_; |
6 | my ($self) = @_; |
9 | |
7 | |
|
|
8 | $self->{random_id} = $1; |
|
|
9 | |
10 | Coro::AIO::aio_load "$cf::RANDOM_MAPS/$self->{path}.meta", my $data; |
10 | if (0 < Coro::AIO::aio_load "$cf::RANDOM_MAPS/$self->{random_id}.meta", my $data) { |
11 | $self->{random} = cf::from_json $data; |
11 | $self->{random} = cf::from_json $data; |
|
|
12 | $self->{random}{custom} ||= "$self->{random}{origin_map}+$self->{random}{origin_x}+$self->{random}{origin_y}"; |
|
|
13 | } |
|
|
14 | |
|
|
15 | 1 |
|
|
16 | } |
|
|
17 | |
|
|
18 | sub thawer_merge { |
|
|
19 | # we have to keep some variables in memory intact |
|
|
20 | local $_[0]{random_id}; |
|
|
21 | local $_[0]{random}; |
|
|
22 | |
|
|
23 | $_[0]->SUPER::thawer_merge ($_[1]); |
12 | } |
24 | } |
13 | |
25 | |
14 | sub visible_name { |
26 | sub visible_name { |
15 | my ($self) = @_; |
27 | my ($self) = @_; |
16 | |
28 | |
17 | # if (my $rmp = $self->{random}) { |
29 | my $rmp = $self->{random}; |
18 | # # todo: be more intelligent about this |
30 | "random map at $rmp->{custom}, level $rmp->{dungeon_level}" |
19 | # "?random/$rmp->{origin_map}+$rmp->{origin_x}+$rmp->{origin_y}/$rmp->{dungeon_level}" |
|
|
20 | # } else { |
|
|
21 | $self->as_string |
|
|
22 | # } |
|
|
23 | } |
31 | } |
24 | |
32 | |
25 | sub save_path { |
33 | sub save_path { |
26 | my ($self) = @_; |
34 | my ($self) = @_; |
27 | |
35 | |
28 | sprintf "%s/%s", $RANDOM_MAPS, $self->{path} |
36 | sprintf "%s/%s.map", $cf::RANDOM_MAPS, $self->{random_id} |
29 | } |
37 | } |
30 | |
38 | |
31 | sub uniq_path { |
39 | sub uniq_path { |
32 | undef |
40 | undef |
33 | } |
41 | } |
34 | |
42 | |
35 | sub load_orig { |
43 | sub load_orig { |
36 | my ($self) = @_; |
44 | my ($self) = @_; |
37 | |
45 | |
|
|
46 | return unless $self->{random}; |
|
|
47 | |
38 | cf::map::generate_random_map "$self", $self->{random} |
48 | $self->generate_random_map ($self->{random}); |
|
|
49 | |
|
|
50 | 1 |
39 | } |
51 | } |
|
|
52 | |
|
|
53 | sub clean_random_maps { |
|
|
54 | cf::async { |
|
|
55 | my $files = Coro::AIO::aio_readdir $cf::RANDOM_MAPS |
|
|
56 | or return; |
|
|
57 | |
|
|
58 | my $META_TIMEOUT = $cf::CFG{map_random_meta_timeout} || 86400 * 7; |
|
|
59 | my $MAP_TIMEOUT = $cf::CFG{map_random_map_timeout} || 3600 * 6; |
|
|
60 | |
|
|
61 | for my $file (@$files) { |
|
|
62 | next if $file =~ /\.pst$/; |
|
|
63 | |
|
|
64 | Coro::AIO::aio_stat "$cf::RANDOM_MAPS/$file" |
|
|
65 | and next; |
|
|
66 | |
|
|
67 | my $age = $cf::NOW - (stat _)[8]; |
|
|
68 | |
|
|
69 | if ($file =~ /\.meta$/) { |
|
|
70 | if ($age > $META_TIMEOUT) { |
|
|
71 | warn "resetting random meta data for $file"; |
|
|
72 | IO::AIO::aio_unlink "$cf::RANDOM_MAPS/$file"; |
|
|
73 | } |
|
|
74 | } else { |
|
|
75 | if ($age > $MAP_TIMEOUT) { |
|
|
76 | warn "resetting random map $file"; |
|
|
77 | IO::AIO::aioreq_pri 4; IO::AIO::aio_unlink "$cf::RANDOM_MAPS/$file"; |
|
|
78 | IO::AIO::aioreq_pri 4; IO::AIO::aio_unlink "$cf::RANDOM_MAPS/$file.pst"; |
|
|
79 | } |
|
|
80 | } |
|
|
81 | } |
|
|
82 | }; |
|
|
83 | } |
|
|
84 | |
|
|
85 | # clean up old temp maps regularly |
|
|
86 | Event->timer ( |
|
|
87 | data => cf::WF_AUTOCANCEL, |
|
|
88 | interval => 3600, |
|
|
89 | after => 600, |
|
|
90 | cb => \&clean_random_maps, |
|
|
91 | ); |
40 | |
92 | |
41 | 1 |
93 | 1 |
42 | |
94 | |