ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/ext/player-env.ext
(Generate patch)

Comparing deliantra/server/ext/player-env.ext (file contents):
Revision 1.5 by root, Thu Jul 12 18:56:33 2007 UTC vs.
Revision 1.14 by root, Thu Aug 30 08:34:40 2007 UTC

17 split /\s*,\s*/, $list 17 split /\s*,\s*/, $list
18 ] 18 ]
19} 19}
20 20
21our %MUSIC_QUEUE; 21our %MUSIC_QUEUE;
22our %MUSIC_FACE_CACHE; # cleared by reload_facedata
22 23
23our $MUSIC_SCHEDULER = cf::async_ext { 24our $MUSIC_SCHEDULER = cf::async_ext {
24 while () { 25 while () {
25 for (keys %MUSIC_QUEUE) { 26 for (keys %MUSIC_QUEUE) {
26 delete $MUSIC_QUEUE{$_}; 27 delete $MUSIC_QUEUE{$_};
27 my $pl = cf::player::find_active $_
28 or next;
29 28
30 my $ns = $pl->ns 29 cf::get_slot 0.01, -10, "music scheduler";
31 or next;
32 30
31 my $pl = cf::player::find_active $_ or next;
32 $pl->ob->active or next;
33 my $ns = $pl->ns or next;
33 $ns->extcmd 34 $ns->extcmd or next;
34 or next; 35 my $map = $pl->ob->map or next;
35 36
36 my $faces; 37 my $faces = $MUSIC_FACE_CACHE{$map} ||= do {
38 # 1. map-specific music info
39 parse_facelist "music/", $map->{music}
40 or do {
41 # 2. fall back to region if no map-specific music
42 my $rgn = $pl->ob->region
43 or next;
37 44
38 my $map = $pl->ob->map 45 my $par = $rgn;
39 or next; 46 while () {
47 last if exists $par->{music};
48 $par = $par->parent
49 or last;
50 }
40 51
41 # 1. update map-specific music info
42 unless (exists $map->{music_faces}) {
43 $map->{music_faces} = parse_facelist "music/", $map->{music}; 52 parse_facelist "music/", $par->{music}
44 }
45
46 my $faces = $map->{music_faces};
47
48 # 2. fall back to region if no map-specific music
49 unless ($faces) {
50 my $rgn = $pl->ob->region
51 or next;
52
53 unless (exists $rgn->{music_faces}) {
54 my $par = $rgn;
55 while () {
56 last if exists $par->{music};
57 $par = $par->parent
58 or last;
59 } 53 }
60
61 $rgn->{music_faces} = parse_facelist "music/", $par->{music};
62 } 54 ;
63
64 $faces = $rgn->{music_faces};
65 } 55 };
66 56
67 $faces 57 $faces
68 or next; 58 or next;
69 59
70 my $facestr = join ",", @$faces; 60 my $facestr = join ",", @$faces;
71 $ns->{current_music_faces} ne $facestr 61 $ns->{current_music_faces} ne $facestr
72 or next; 62 or next;
73 63
74 $ns->{current_music_faces} = $facestr; 64 $ns->{current_music_faces} = $facestr;
75 65
76 my $msg = { 66 my $pri = 0;
77 faces => $faces, 67 $ns->send_face ($_, --$pri - 110)
78 }; 68 for @$faces;
69 $ns->flush_fx;
79 70
80 $msg->{chksum}{$_} = cf::face::get_chksum $_
81 for grep $ns->must_send_face ($_), @$faces;
82
83 $ns->ext_event (music => %$msg); 71 $ns->ext_msg (ambient_music => $faces);
84
85 cf::cede_to_tick;
86 } 72 }
87 Coro::schedule unless %MUSIC_QUEUE; 73 Coro::schedule unless %MUSIC_QUEUE;
88 } 74 }
89}; 75};
90 76

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines