1 | package CFPlus::Protocol; |
1 | package CFPlus::Protocol; |
2 | |
2 | |
3 | use utf8; |
3 | use utf8; |
4 | use strict; |
4 | use strict; |
5 | |
5 | |
6 | use Crossfire::Protocol::Constants; |
6 | use Deliantra::Protocol::Constants; |
7 | |
7 | |
8 | use CFPlus; |
8 | use CFPlus; |
9 | use CFPlus::DB; |
9 | use CFPlus::DB; |
10 | use CFPlus::UI; |
10 | use CFPlus::UI; |
11 | use CFPlus::Pod; |
11 | use CFPlus::Pod; |
12 | use CFPlus::Macro; |
12 | use CFPlus::Macro; |
13 | use CFPlus::Item; |
13 | use CFPlus::Item; |
14 | |
14 | |
15 | use base 'Crossfire::Protocol::Base'; |
15 | use base 'Deliantra::Protocol::Base'; |
16 | |
16 | |
17 | sub new { |
17 | sub new { |
18 | my ($class, %arg) = @_; |
18 | my ($class, %arg) = @_; |
19 | |
19 | |
20 | my $self = $class->SUPER::new (%arg, |
20 | my $self = $class->SUPER::new (%arg, |
21 | setup_req => { |
21 | setup_req => { |
22 | extmap => 1, |
22 | extmap => 1, |
23 | excmd => 1, |
23 | excmd => 1, |
24 | #xwidget2 => 1,#d# |
24 | widget => 1, |
25 | %{$arg{setup_req} || {}}, |
25 | %{$arg{setup_req} || {}}, |
26 | msg => 0, |
|
|
27 | }, |
26 | }, |
28 | ); |
27 | ); |
29 | |
28 | |
30 | $self->{map_widget}->clr_commands; |
29 | $self->{map_widget}->clr_commands; |
31 | |
30 | |
… | |
… | |
295 | ############################################################################# |
294 | ############################################################################# |
296 | |
295 | |
297 | sub logprint { |
296 | sub logprint { |
298 | my ($self, @a) = @_; |
297 | my ($self, @a) = @_; |
299 | |
298 | |
300 | CFPlus::DB::logprint "$Crossfire::VARDIR/log.$self->{host}" => (join "", @a), sub { }; |
299 | CFPlus::DB::logprint "$Deliantra::VARDIR/log.$self->{host}" => (join "", @a), sub { }; |
301 | } |
300 | } |
302 | |
301 | |
303 | sub _stat_numdiff { |
302 | sub _stat_numdiff { |
304 | my ($self, $name, $old, $new) = @_; |
303 | my ($self, $name, $old, $new) = @_; |
305 | |
304 | |
… | |
… | |
614 | } |
613 | } |
615 | } |
614 | } |
616 | |
615 | |
617 | if ($delay) { |
616 | if ($delay) { |
618 | # delay the map drawing a tiny bit in the hope of getting the missing fetched |
617 | # delay the map drawing a tiny bit in the hope of getting the missing fetched |
619 | Event->timer (after => 0.03, cb => sub { |
618 | EV::once undef, 0, 0.03, sub { |
620 | $_[0]->w->cancel; |
|
|
621 | $self->{map_widget}->update |
619 | $self->{map_widget}->update |
622 | if $self->{map_widget}; |
620 | if $self->{map_widget}; |
623 | }); |
621 | }; |
624 | } else { |
622 | } else { |
625 | $self->{map_widget}->update; |
623 | $self->{map_widget}->update; |
626 | } |
624 | } |
627 | } |
625 | } |
628 | |
626 | |
… | |
… | |
1304 | 0 |
1302 | 0 |
1305 | }); |
1303 | }); |
1306 | |
1304 | |
1307 | $self->update_server_info; |
1305 | $self->update_server_info; |
1308 | |
1306 | |
1309 | $self->send_command ("output-sync $::CFG->{output_sync}"); |
|
|
1310 | $self->send_command ("output-count $::CFG->{output_count}"); |
|
|
1311 | $self->send_command ("output-rate $::CFG->{output_rate}") if $::CFG->{output_rate} > 0; |
1307 | $self->send_command ("output-rate $::CFG->{output_rate}") if $::CFG->{output_rate} > 0; |
1312 | $self->send_command ("pickup $::CFG->{pickup}"); |
1308 | $self->send_command ("pickup $::CFG->{pickup}"); |
1313 | } |
1309 | } |
1314 | |
1310 | |
1315 | sub lookat { |
1311 | sub lookat { |