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

Comparing deliantra/maps/perl/schmorp-neko.ext (file contents):
Revision 1.21 by root, Fri Aug 25 15:24:54 2006 UTC vs.
Revision 1.23 by root, Sun Aug 27 15:39:17 2006 UTC

1#! perl 1#! perl
2#CONVERSION: NONE
3 2
4# archetype nekosan 3# archetype nekosan
5
6use Data::Dumper;
7 4
8sub teleport { 5sub teleport {
9 my ($pl, $map, $x, $y) = @_; 6 my ($pl, $map, $x, $y) = @_;
10 7
11 my $portal = cf::object::new "exit"; 8 my $portal = cf::object::new "exit";
35 32
36 $pl 33 $pl
37} 34}
38 35
39sub on_move { 36sub on_move {
40 my ($event, $who) = @_; 37 my ($self, $enemy) = @_;
41 38
42 if (my $pl = find_target_player $who) { 39 if (my $pl = find_target_player $self) {
43 my ($d, undef, undef, $dir, undef) = $who->rangevector ($pl); 40 my ($d, undef, undef, $dir, undef) = $self->rangevector ($pl);
44 41
45 if ($d < 1.5) { 42 if ($d < 1.5) {
46 if (grep $_->type == cf::FORCE && $_->slaying eq "schmorp-neko-gave-fish", $pl->inv) { 43 if (grep $_->type == cf::FORCE && $_->slaying eq "schmorp-neko-gave-fish", $pl->inv) {
47 # she likes us! 44 # she likes us!
48 if ($pl->{neko_next_pester} < time) { 45 if ($pl->{neko_next_pester} < time) {
65 $spell->set_last_sp (100); # fill sp 62 $spell->set_last_sp (100); # fill sp
66 $spell->set_last_grace (100); # fill gr 63 $spell->set_last_grace (100); # fill gr
67 $spell->set_attacktype (cf::AT_CONFUSION | cf::AT_POISON | cf::AT_BLIND | cf::AT_DISEASE); 64 $spell->set_attacktype (cf::AT_CONFUSION | cf::AT_POISON | cf::AT_BLIND | cf::AT_DISEASE);
68 65
69 $pl->message ("(Neko-san makes strange noises)"); 66 $pl->message ("(Neko-san makes strange noises)");
70 $pl->cast_spell ($who, $dir, $spell); 67 $pl->cast_spell ($self, $dir, $spell);
71 68
72 $spell->free; 69 $spell->free;
73 } 70 }
74 71
75 } else { 72 } else {
99 96
100 # circular movement 97 # circular movement
101 $dir = $dir % 8 + 1 unless $d > 1.5; 98 $dir = $dir % 8 + 1 unless $d > 1.5;
102 } 99 }
103 100
104 $who->move ($dir); 101 $self->move ($dir);
105 } 102 }
106 103
107 1 104 cf::override;
108} 105}
109 106
110sub on_attack { 107sub on_attack {
111 my ($event, $ob, $who) = @_; 108 my ($self, $hitter) = @_;
112 109
113 if ($who->{neko_last_attack} < time - 300) { 110 if ($hitter->{neko_last_attack} < time - 300) {
114 $who->{neko_attack} = 0; 111 $hitter->{neko_attack} = 0;
115 } 112 }
116 113
117 $who->{neko_last_attack} = time; 114 $hitter->{neko_last_attack} = time;
118 $who->{neko_attack}++ 115 $hitter->{neko_attack}++
119 or ext::schmorp_irc::do_notice "Neko-san was attacked by ". $who->name . "!\n"; 116 or ext::schmorp_irc::do_notice "Neko-san was attacked by ". $hitter->name . "!\n";
120 117
121 $who->message ("Meoow! (Please do not hurt me)") 118 $hitter->message ("Meoow! (Please do not hurt me)")
122 if !($who->{neko_attack} & 15); 119 if !($hitter->{neko_attack} & 15);
123 120
124 if ($who->{neko_attack} > 512) { 121 if ($hitter->{neko_attack} > 512) {
125 $who->{neko_attack} -= 128; 122 $hitter->{neko_attack} -= 128;
126 $who->message ("Neko-san is suddenly gone!"); 123 $hitter->message ("Neko-san is suddenly gone!");
127 teleport $who, "/scorn/misc/scorn_illusions", 15, 7; 124 teleport $hitter, "/scorn/misc/scorn_illusions", 15, 7;
128 $who->message ("You hear strange noises all around you..."); 125 $hitter->message ("You hear strange noises all around you...");
129 $who->message ("You feel dumb."); 126 $hitter->message ("You feel dumb.");
130 } 127 }
131 128
132 1 129 cf::override;
133} 130}
134 131
135sub on_say { 132sub on_listen {
136 my ($event, $ob, $who, $msg) = @_; 133 my ($event, $ob, $who, $msg) = @_;
137 134
138 cf::LOG cf::llevDebug, sprintf "QBERT [Neko-fon] %s: %s\n", $who->name, $msg; 135 cf::LOG cf::llevDebug, sprintf "QBERT [Neko-fon] %s: %s\n", $who->name, $msg;
139 ext::schmorp_irc::do_notice (sprintf "[Neko-fon] %s: %s\n", $who->name, $msg); 136 ext::schmorp_irc::do_notice (sprintf "[Neko-fon] %s: %s\n", $who->name, $msg);
140} 137}
141 138
139cf::register_attachment "Nekosan", package => __PACKAGE__;
140

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines