ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/maps/perl/rent.ext
(Generate patch)

Comparing deliantra/maps/perl/rent.ext (file contents):
Revision 1.3 by root, Mon Sep 18 18:34:16 2006 UTC vs.
Revision 1.6 by root, Tue Sep 19 20:14:16 2006 UTC

2 2
3use List::Util; 3use List::Util;
4 4
5my %apartment = ( 5my %apartment = (
6 "/scorn/apartment/apartments" => [ 1, "scorn", "skorn"], 6 "/scorn/apartment/apartments" => [ 1, "scorn", "skorn"],
7 "/santo/dominion/sdomino/appartment" => [ 10, "santo dominion", "domino"], 7 "/santo_dominion/sdomino_appartment" => [ 10, "santo dominion", "domino"],
8 "/darcap/darcap/apartment" => [ 30, "darcap", "thecap"], 8 "/darcap/darcap/apartment" => [ 30, "darcap", "thecap"],
9 "/navar_city/apartments/apartment" => [ 250, "navar", "navar"], 9 "/navar_city/apartments/apartment" => [ 250, "navar", "navar"],
10 "/azumauindo/ranbounagisatoshi/apartments/sapartment" => [ 100, "乱暴渚都市", "benjo"], 10 "/azumauindo/ranbounagisatoshi/apartments/sapartment" => [ 100, "乱暴渚都市", "benjo"],
11 "/azumauindo/suno-yamatoshi/apartments/lapartment1" => [ 1000, "スノー大和島根", "sama"], 11 "/azumauindo/suno-yamatoshi/apartments/lapartment1" => [ 1000, "スノー大和島根", "sama"],
12 "/pup_land/nurnberg/apartment/main" => [ 300, "nürnberg", "sauerkraut"], 12 "/pup_land/nurnberg/apartment/main" => [ 300, "nürnberg", "sauerkraut"],
13 "/pup_land/lone_town/apartment/groundfloor" => [50000, "lone town", "looney"], 13 "/pup_land/lone_town/apartment/groundfloor" => [50000, "lone town", "looney"],
14 "/brest/apartments/brest/town/house" => [30000, "brest", "brecht"], 14 "/brest/apartments/brest_town_house" => [30000, "brest", "brecht"],
15); 15);
16 16
17sub teleport { 17sub teleport {
18 my ($pl, $map, $x, $y) = @_; 18 my ($pl, $map, $x, $y) = @_;
19 19
31 my ($pl) = @_; 31 my ($pl) = @_;
32 32
33 cf::override; 33 cf::override;
34 34
35 teleport $pl, "/world/world_105_115", 2, 34 35 teleport $pl, "/world/world_105_115", 2, 34
36 unless
37 $pl->ob->map
36 unless $pl->ob->map && $pl->ob->map->path !~ /nimbus/; 38 && $pl->ob->map->path !~ /nimbus/
39 && $pl->ob->map->path !~ m%/var/crossfire/players/%;
37} 40}
38 41
39sub update_balance { 42sub update_balance {
40 my ($pl) = @_; 43 my ($pl) = @_;
41 44
169 172
170cf::register_map_attachment rent => 173cf::register_map_attachment rent =>
171 on_enter => sub { 174 on_enter => sub {
172 my ($map, $pl, $x, $y) = @_; 175 my ($map, $pl, $x, $y) = @_;
173 176
177 # can freely enter homes of other people
178 {
179 my $path = sprintf "%s/%s/%s/",
180 cf::localdir, cf::playerdir, $pl->ob->name;
181
182 return if $path ne substr $map->path, 0, length $path;
183 }
184
174 for my $path (keys %{ $pl->{rent}{apartment} }) { 185 for my $path (keys %{ $pl->{rent}{apartment} }) {
175 $path =~ y/\//_/; 186 $path =~ y/\//_/;
176 $path = sprintf "%s/%s/%s/%s", 187 $path = sprintf "%s/%s/%s/%s",
177 cf::localdir, cf::playerdir, $pl->ob->name, $path; 188 cf::localdir, cf::playerdir, $pl->ob->name, $path;
178 189

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines