--- deliantra/Deliantra-Client/DC/Protocol.pm 2006/08/14 14:35:31 1.78
+++ deliantra/Deliantra-Client/DC/Protocol.pm 2006/12/22 03:43:05 1.93
@@ -8,13 +8,17 @@
use CFPlus;
use CFPlus::UI;
use CFPlus::Pod;
+use CFPlus::Macro;
+use CFPlus::Item;
+
+use Crossfire::Protocol::Base 0.95;
use base 'Crossfire::Protocol::Base';
sub new {
my $class = shift;
- my $self = $class->SUPER::new (@_);
+ my $self = $class->SUPER::new (@_, setup_req => { extmap => 1 });
$self->{map_widget}->clr_commands;
@@ -44,14 +48,23 @@
$self->{noface} = new_from_file CFPlus::Texture
CFPlus::find_rcfile "noface.png", minify => 1, mipmap => 1;
+ {
+ $self->{dialogue} = my $tex = new_from_file CFPlus::Texture
+ CFPlus::find_rcfile "dialogue.png", minify => 1, mipmap => 1;
+ $self->{map}->set_texture (1, @$tex{qw(name w h s t)}, @{$tex->{minified}});
+ }
+
$self->{open_container} = 0;
# "global"
- $self->{tilecache} = CFPlus::db_table "tilecache";
- $self->{facemap} = CFPlus::db_table "facemap";
+ $self->{tilecache} = CFPlus::db_table "tilecache"
+ or die "tilecache: unable to open database table";
+ $self->{facemap} = CFPlus::db_table "facemap"
+ or die "facemap: unable to open database table";
# per server
- $self->{mapcache} = CFPlus::db_table "mapcache_$self->{host}_$self->{port}";
+ $self->{mapcache} = CFPlus::db_table "mapcache_$self->{host}_$self->{port}"
+ or die "mapcache_$self->{host}_$self->{port}: unable to open database table";
$self
}
@@ -59,7 +72,6 @@
sub logprint {
my ($self, @a) = @_;
- return;
$self->{log_fh} ||= do {
my $path = "$Crossfire::VARDIR/log.$self->{host}";
@@ -280,10 +292,11 @@
} elsif ($ev->{button} == 2) {
$::CONN->user_send ("use_skill $name");
} elsif ($ev->{button} == 3) {
+ my $shortname = CFPlus::shorten $name, 14;
(new CFPlus::UI::Menu
items => [
- ["bind ready_skill $name to a key" => sub { $::BIND_EDITOR->do_quick_binding (["ready_skill $name"]) }],
- ["bind use_skill $name to a key" => sub { $::BIND_EDITOR->do_quick_binding (["use_skill $name"]) }],
+ ["bind ready_skill $shortname to a key" => sub { CFPlus::Macro::quick_macro ["ready_skill $name"] }],
+ ["bind use_skill $shortname to a key" => sub { CFPlus::Macro::quick_macro ["use_skill $name"] }],
],
)->popup ($ev);
} else {
@@ -310,27 +323,29 @@
}
}
+sub macro_send {
+ my ($self, $macro) = @_;
+
+ for my $cmd (@{ $macro->{action} }) {
+ $self->send_command ($cmd);
+ }
+}
+
sub user_send {
my ($self, $command) = @_;
- if ($self->{record}) {
- push @{$self->{record}}, $command;
- }
+ $self->{record}->($command)
+ if $self->{record};
$self->logprint ("send: ", $command);
$self->send_command ($command);
::status ($command);
}
-sub start_record {
- my ($self) = @_;
-
- $self->{record} = [];
-}
+sub record {
+ my ($self, $cb) = @_;
-sub stop_record {
- my ($self) = @_;
- return delete $self->{record};
+ $self->{record} = $cb;
}
sub map_scroll {
@@ -342,7 +357,7 @@
sub feed_map1a {
my ($self, $data) = @_;
- $self->{map}->map1a_update ($data);
+ $self->{map}->map1a_update ($data, $self->{setup}{extmap});
$self->{map_widget}->update;
}
@@ -615,9 +630,9 @@
[0.74, 0.65, 0.41],
);
- $self->logprint ("info: ", $text);
+ my $fg = $color[$color % @color];
- my $time = sprintf "%02d:%02d:%02d", (localtime time)[2,1,0];
+ $self->logprint ("info: ", $text);
# try to create single paragraphs of multiple lines sent by the server
$text =~ s/(?<=\S)\n(?=\w)/ /g;
@@ -626,13 +641,12 @@
$text =~ s/\[b\](.*?)\[\/b\]/\1<\/b>/g;
$text =~ s/\[color=(.*?)\](.*?)\[\/color\]/\2<\/span>/g;
- $self->{logview}->add_paragraph ({ fg => $color[$color], markup => $_ })
- for map "$time $_", split /\n/, $text;
- $self->{logview}->scroll_to_bottom;
+ ::message ({ fg => $fg, markup => $_ })
+ for split /\n/, $text;
$self->{statusbox}->add ($text,
group => $text,
- fg => $color[$color],
+ fg => $fg,
timeout => $color >= 2 ? 180 : 10,
tooltip_font => $::FONT_FIXED,
);
@@ -652,7 +666,7 @@
$spell->{message} =~ s/\n+$//;
$spell->{message} ||= "Server did not provide a description for this spell.";
- $::SPELL_PAGE->add_spell ($spell);
+ $::SPELL_LIST->add_spell ($spell);
$self->{map_widget}->add_command ("invoke $spell->{name}", CFPlus::asxml $spell->{message});
$self->{map_widget}->add_command ("cast $spell->{name}", CFPlus::asxml $spell->{message});
@@ -661,7 +675,13 @@
sub spell_delete {
my ($self, $spell) = @_;
- $::SPELL_PAGE->remove_spell ($spell);
+ $::SPELL_LIST->remove_spell ($spell);
+}
+
+sub setup {
+ my ($self, $setup) = @_;
+
+ $::MAP->resize ($self->{mapw}, $self->{maph});
}
sub addme_success {
@@ -877,10 +897,14 @@
. "protocol version $self->{version}\n"
. "minimap support $yesno[$self->{setup}{mapinfocmd} > 0]\n"
. "extended command support $yesno[$self->{setup}{extcmd} > 0]\n"
+ . "editing support $yesno[!!$self->{editor_support}]\n"
+ . "map attributes $yesno[$self->{setup}{extmap} > 0]\n"
. "cfplus support $yesno[$self->{cfplus_ext} > 0]"
. ($self->{cfplus_ext} > 0 ? ", version $self->{cfplus_ext}" : "") ."\n"
. "map size $self->{mapw}×$self->{maph}\n"
);
+
+ ::setup_build_button ($self->{editor_support}->{builder_ui});
}
sub logged_in {
@@ -890,6 +914,15 @@
$self->{cfplus_ext} = $_[0]{version};
$self->update_server_info;
+ if ($self->{cfplus_ext} >= 2) {
+ $self->send_ext_req ("editor_support", sub {
+ $self->{editor_support} = $_[0];
+ $self->update_server_info;
+
+ 0
+ });
+ }
+
0
});
@@ -900,6 +933,14 @@
$self->send_command ("pickup $::CFG->{pickup}");
}
+sub buildat {
+ my ($self, $builditem, $x, $y) = @_;
+
+ if ($self->{cfplus_ext}) {
+ $self->send_ext_msg (builder_build => dx => $x, dy => $y, (ref ($builditem) eq 'HASH') ? %$builditem : (item => $builditem));
+ }
+}
+
sub lookat {
my ($self, $x, $y) = @_;
@@ -925,7 +966,7 @@
sub destroy {
my ($self) = @_;
- $self->{npc_dialog}->destroy
+ (delete $self->{npc_dialog})->destroy
if $self->{npc_dialog};
$self->SUPER::destroy;
@@ -950,7 +991,7 @@
@_,
);
- Scalar::Util::weaken (my $this = $self);
+ CFPlus::weaken (my $this = $self);
$self->connect (delete => sub { $this->destroy; 1 });
@@ -1004,7 +1045,7 @@
sub update_options {
my ($self) = @_;
- Scalar::Util::weaken $self;
+ CFPlus::weaken $self;
$self->{options}->clear;
$self->{options}->add ($self->{bye_button});
@@ -1023,7 +1064,7 @@
sub feed {
my ($self, $msg) = @_;
- Scalar::Util::weaken $self;
+ CFPlus::weaken $self;
if ($msg->{msgtype} eq "reply") {
$self->{kw}{$_} = 1 for @{$msg->{add_topics} || []};
@@ -1084,3 +1125,4 @@
}
1
+