… | |
… | |
218 | }, |
218 | }, |
219 | }, |
219 | }, |
220 | kiss => { |
220 | kiss => { |
221 | noparams => { |
221 | noparams => { |
222 | other => "<self> makes a weird facial contortion", |
222 | other => "<self> makes a weird facial contortion", |
223 | self => "All the lonely people..", |
223 | self => "All the lonely people...", |
224 | }, |
224 | }, |
225 | params => { |
225 | params => { |
226 | target => "<self> kisses you.", |
226 | target => "<self> kisses you.", |
227 | other => "<self> kisses <other>.", |
227 | other => "<self> kisses <other>.", |
228 | self => "You kiss <other>.", |
228 | self => "You kiss <other>.", |
229 | }, |
229 | }, |
230 | self => { |
230 | self => { |
231 | }, |
231 | }, |
232 | }, |
232 | }, |
|
|
233 | hug => { |
|
|
234 | noparams => { |
|
|
235 | other => "<self> makes weird body movements.", |
|
|
236 | self => "All the lonely people...", |
|
|
237 | }, |
|
|
238 | params => { |
|
|
239 | target => "<self> suddenly grabs you and gives you a bear hug.", |
|
|
240 | other => "<self> hugs <other>.", |
|
|
241 | self => "You hug <other>.", |
|
|
242 | }, |
|
|
243 | self => { |
|
|
244 | other => "<self> tries to hug G<himself|herself>, but stumbles and now feels stupid.", |
|
|
245 | self => "You try and fail to hug yourself.", |
|
|
246 | }, |
|
|
247 | }, |
233 | smother => { |
248 | smother => { |
234 | noparams => { |
249 | noparams => { |
235 | other => "<self> makes weird facial contortions", |
250 | other => "<self> makes weird facial contortions", |
236 | self => "All the lonely people..", |
251 | self => "All the lonely people...", |
237 | }, |
252 | }, |
238 | params => { |
253 | params => { |
239 | target => "<self> smothers you with kisses.", |
254 | target => "<self> smothers you with kisses.", |
240 | other => "<self> smothers <other> with kisses.", |
255 | other => "<self> smothers <other> with kisses.", |
241 | self => "You smother <other> with kisses.", |
256 | self => "You smother <other> with kisses.", |
… | |
… | |
775 | |
790 | |
776 | send_msg $_, $cf::SAY_CHANNEL => "$name says: $msg", cf::NDI_GREY, "msg_say" |
791 | send_msg $_, $cf::SAY_CHANNEL => "$name says: $msg", cf::NDI_GREY, "msg_say" |
777 | for grep $_ != $ob->contr, @plonmap; |
792 | for grep $_ != $ob->contr, @plonmap; |
778 | $ob->contr->send_msg ($cf::SAY_CHANNEL => "$name says: $msg", cf::NDI_GREY | cf::NDI_REPLY); |
793 | $ob->contr->send_msg ($cf::SAY_CHANNEL => "$name says: $msg", cf::NDI_GREY | cf::NDI_REPLY); |
779 | |
794 | |
|
|
795 | my @npc; |
|
|
796 | |
780 | # npcs, magic_ears etc. |
797 | # npcs, magic_ears etc. |
781 | # first find all objects and their first-level inventories |
798 | # first find all objects and their first-level inventories |
782 | # within a 5x5 square that have something resembling |
799 | # within a 5x5 square that have something resembling |
783 | # dialogue or support on_say. |
800 | # dialogue or support on_say. |
|
|
801 | # we prefer the nearest items NOT in the player, otherwise in player. |
784 | my ($map, $x, $y) = ($ob->map, $ob->x - 2, $ob->y - 2); |
802 | my ($map, $x, $y) = ($ob->map, $ob->x, $ob->y); |
785 | |
803 | |
786 | for my $npc ( |
804 | for my $dir ( |
787 | grep +($_->invoke (cf::EVENT_OBJECT_SAY, $ob->contr, $msg) && return) || $_->has_dialogue, |
805 | 0, |
788 | map +($_, $_->inv), |
806 | 1, 3, 5, 7, |
789 | grep $_, |
807 | 2, 4, 6, 8, |
790 | map $map->at ($x + $_ % 5, $y + (int $_ / 5)), |
808 | 9 .. cf::SIZEOFFREE2 |
791 | 0..24 |
|
|
792 | ) { |
809 | ) { |
|
|
810 | @npc = grep $_->should_invoke (cf::EVENT_OBJECT_SAY) || $_->has_dialogue, |
|
|
811 | map +($_, $_->inv), |
|
|
812 | grep $_ != $ob, |
|
|
813 | $map->at ($x, $y, $dir) |
|
|
814 | and last; |
|
|
815 | } |
|
|
816 | |
|
|
817 | unless (@npc) { |
|
|
818 | # nothing found, try the player inventory |
|
|
819 | @npc = grep $_->should_invoke (cf::EVENT_OBJECT_SAY) || $_->has_dialogue, |
|
|
820 | $ob->inv; |
|
|
821 | } |
|
|
822 | |
|
|
823 | for my $npc (@npc) { |
|
|
824 | return if $npc->invoke (cf::EVENT_OBJECT_SAY); |
|
|
825 | |
793 | # if some listener teleported us somewhere else, stop right here |
826 | # if some listener teleported us somewhere else, stop right here |
794 | last unless $map->path == $ob->map->path; |
827 | last unless $map->path == $ob->map->path; |
795 | |
828 | |
|
|
829 | if ($npc->has_dialogue) { |
796 | my $dialog = new NPC_Dialogue pl => $ob->contr, npc => $npc; |
830 | my $dialog = new NPC_Dialogue pl => $ob->contr, npc => $npc; |
797 | my ($reply, @kw) = $dialog->tell ($msg); |
831 | my ($reply, @kw) = $dialog->tell ($msg); |
798 | |
832 | |
799 | if (defined $reply) { |
833 | if (defined $reply) { |
800 | if ($npc->type == cf::MAGIC_EAR) { |
834 | if ($npc->type == cf::MAGIC_EAR) { |
801 | send_msg $_, $cf::SAY_CHANNEL => $reply, cf::NDI_BROWN, "msg_say" |
835 | send_msg $_, $cf::SAY_CHANNEL => $reply, cf::NDI_BROWN, "msg_say" |
802 | for @plonmap; |
836 | for @plonmap; |
803 | } else { |
837 | } else { |
804 | send_msg $_, $cf::SAY_CHANNEL => $npc->name . " says: $reply", cf::NDI_BROWN, "msg_say" |
838 | send_msg $_, $cf::SAY_CHANNEL => $npc->name . " says: $reply", cf::NDI_BROWN, "msg_say" |
|
|
839 | for @plonmap; |
|
|
840 | } |
|
|
841 | } |
|
|
842 | |
|
|
843 | if (@kw) { |
|
|
844 | $_->send_msg ($cf::SAY_CHANNEL => "[further topics: " . (join ", ", @kw) . "]", cf::NDI_BROWN) |
805 | for @plonmap; |
845 | for @plonmap; |
806 | } |
846 | } |
807 | } |
|
|
808 | |
|
|
809 | if (@kw) { |
|
|
810 | $_->send_msg ($cf::SAY_CHANNEL => "[further topics: " . (join ", ", @kw) . "]", cf::NDI_BROWN) |
|
|
811 | for @plonmap; |
|
|
812 | } |
847 | } |
813 | } |
848 | } |
814 | |
849 | |
815 | } else { |
850 | } else { |
816 | $ob->send_msg ($cf::SAY_CHANNEL => "What do you want to say?", cf::NDI_GREY | cf::NDI_REPLY); |
851 | $ob->send_msg ($cf::SAY_CHANNEL => "What do you want to say?", cf::NDI_GREY | cf::NDI_REPLY); |