--- deliantra/Deliantra-Client/DC/Protocol.pm 2012/01/04 11:23:23 1.220 +++ deliantra/Deliantra-Client/DC/Protocol.pm 2012/11/04 02:13:53 1.221 @@ -29,12 +29,58 @@ my $self = $class->SUPER::new (%arg, setup_req => { extmap => 1, - excmd => 1, widget => 2, %{$arg{setup_req} || {}}, }, ); + $self->update_fx_want; + + my $guard = $self->addme_guard; + $self->send_exti_req (resource => "exp_table", sub { + my ($idx) = @_; + + $self->register_face_handler ($idx, sub { + my ($face) = @_; + + undef $guard; + $self->{exp_table} = $self->{json_coder}->decode (delete $face->{data}); + $_->() for values %{ $self->{on_exp_update} }; + }); + + () + }); + + my $guard = $self->addme_guard; + $self->send_exti_req (resource => "skill_info", sub { + my ($idx) = @_; + + $self->register_face_handler ($idx, sub { + my ($face) = @_; + + undef $guard; + my $info = $self->{json_coder}->decode (delete $face->{data}); + $self->{skill_info} = { map { CS_STAT_SKILLINFO + $_ => $info->[$_][0] } 0 .. $#$info }; + }); + + () + }); + + my $guard = $self->addme_guard; + $self->send_exti_req (resource => "spell_paths", sub { + my ($idx) = @_; + + $self->register_face_handler ($idx, sub { + my ($face) = @_; + + undef $guard; + my $info = $self->{json_coder}->decode (delete $face->{data}); + $self->{spell_paths} = { map { (1 << $_) => $info->[$_][0] } 0 .. $#$info }; + }); + + () + }); + $self->{map_widget}->clr_commands; my @cmd_help = map { @@ -132,21 +178,6 @@ sub ext_capabilities { my ($self, %cap) = @_; - $self->update_fx_want; - - $self->send_exti_req (resource => "exp_table", sub { - my ($exp_table) = @_; - - $self->register_face_handler ($exp_table, sub { - my ($face) = @_; - - $self->{exp_table} = $self->{json_coder}->decode (delete $face->{data}); - $_->() for values %{ $self->{on_exp_update} || {} }; - }); - - () - }); - if (my $ts = $cap{tileset}) { if (my ($default) = grep $_->[2] & 1, @$ts) { $self->{tileset} = $default; @@ -456,7 +487,7 @@ ( ($stats->{+CS_STAT_EXP64} > $prev->{+CS_STAT_EXP64} ? ($stats->{+CS_STAT_EXP64} - $prev->{+CS_STAT_EXP64}) . " experience gained" : ()), map { - $stats->{$_} && $prev->{$_} + $stats->{$_} && $prev->{$_} && $stats->{$_}[1] > $prev->{$_}[1] ? "($self->{skill_info}{$_}+" . ($stats->{$_}[1] - $prev->{$_}[1]) . ")" : () } sort { $a <=> $b } keys %{$self->{skill_info}} ) @@ -671,7 +702,7 @@ sub feed_map1a { my ($self, $data) = @_; - my $missing = $self->{map}->map1a_update ($data, $self->{setup}{extmap}); + my $missing = $self->{map}->map1a_update ($data); my $delay; for my $tile (@$missing) { @@ -1350,12 +1381,7 @@ $::SERVER_INFO->set_markup ( "server $self->{host}:$self->{port}\n" . "protocol version $version\n" - . "minimap support $yesno[$self->{setup}{mapinfocmd} > 0]\n" - . "extended command support $yesno[$self->{setup}{extcmd} > 0]\n" - . "examine command support $yesno[$self->{setup}{excmd} > 0]\n" . "editing support $yesno[!!$self->{editor_support}]\n" - . "map attributes $yesno[$self->{setup}{extmap} > 0]\n" - . "big image protocol support $yesno[$self->{setup}{fxix} > 0]\n" . "client support $yesno[$self->{cfplus_ext} > 0]" . ($self->{cfplus_ext} > 0 ? ", version $self->{cfplus_ext}" : "") ."\n" . "map size $self->{mapw}×$self->{maph}\n"