ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra-Client/DC.pm
(Generate patch)

Comparing deliantra/Deliantra-Client/DC.pm (file contents):
Revision 1.77 by root, Mon May 29 21:54:15 2006 UTC vs.
Revision 1.84 by elmex, Wed May 31 12:44:17 2006 UTC

86 -Cachesize => 1_000_000, 86 -Cachesize => 1_000_000,
87 -ErrFile => "$Crossfire::VARDIR/cfplus/errorlog.txt", 87 -ErrFile => "$Crossfire::VARDIR/cfplus/errorlog.txt",
88# -ErrPrefix => "DATABASE", 88# -ErrPrefix => "DATABASE",
89 -Verbose => 1, 89 -Verbose => 1,
90 -Flags => DB_CREATE | DB_RECOVER | DB_INIT_MPOOL | DB_INIT_LOCK | DB_INIT_TXN | $recover, 90 -Flags => DB_CREATE | DB_RECOVER | DB_INIT_MPOOL | DB_INIT_LOCK | DB_INIT_TXN | $recover,
91 -SetFlags => DB_AUTO_COMMIT | DB_LOG_AUTOREMOVE | DB_TXN_WRITE_NOSYNC, 91 -SetFlags => DB_AUTO_COMMIT | DB_LOG_AUTOREMOVE,
92 or die "unable to create/open database home $Crossfire::VARDIR/cfplus: $BerkeleyDB::Error"; 92 or die "unable to create/open database home $Crossfire::VARDIR/cfplus: $BerkeleyDB::Error";
93} 93}
94 94
95sub db_table($) { 95sub db_table($) {
96 my ($table) = @_; 96 my ($table) = @_;
203 203
204package CFClient::Item; 204package CFClient::Item;
205 205
206use strict; 206use strict;
207use Crossfire::Protocol::Constants; 207use Crossfire::Protocol::Constants;
208
209my $last_enter_count = 1;
208 210
209sub desc_string { 211sub desc_string {
210 my ($self) = @_; 212 my ($self) = @_;
211 213
212 my $desc = 214 my $desc =
238 my $weight = ($self->{nrof} || 1) * $self->{weight}; 240 my $weight = ($self->{nrof} || 1) * $self->{weight};
239 241
240 $weight < 0 ? "?" : $weight * 0.001 242 $weight < 0 ? "?" : $weight * 0.001
241} 243}
242 244
245sub do_n_dialog {
246 my ($cb) = @_;
247
248 my $w = new CFClient::UI::FancyFrame;
249 $w->add (my $vb = new CFClient::UI::VBox x => "center", y => "center");
250 $vb->add (new CFClient::UI::Label text => "Enter item count:");
251 $vb->add (my $entry = new CFClient::UI::Entry
252 text => $last_enter_count,
253 on_activate => sub {
254 my ($entry) = @_;
255 $last_enter_count = $entry->get_text;
256 $cb->($last_enter_count);
257 $w->hide;
258 $w = undef;
259 }
260 );
261 $entry->focus_in;
262 $w->show;
263
264}
265
243sub update_widgets { 266sub update_widgets {
244 my ($self) = @_; 267 my ($self) = @_;
245 268
246 my $button_cb = sub { 269 my $button_cb = sub {
247 my (undef, $ev, $x, $y) = @_; 270 my (undef, $ev, $x, $y) = @_;
248 271
272 my $targ = $::CONN->{player}{tag};
273
274 if ($self->{container} == $::CONN->{player}{tag}) {
275 $targ = $::CONN->{open_container};
276 }
277
249 if (($ev->{mod} & CFClient::KMOD_SHIFT) && $ev->{button} == 1) { 278 if (($ev->{mod} & CFClient::KMOD_SHIFT) && $ev->{button} == 1) {
250 my $targ = $::CONN->{player}{tag};
251
252 if ($self->{container} == $::CONN->{player}{tag}) {
253 $targ = $::CONN->{open_container};
254 }
255
256 $::CONN->send ("move $targ $self->{tag} 0"); 279 $::CONN->send ("move $targ $self->{tag} 0")
280 if $targ || !($self->{flags} & F_LOCKED);
257 } elsif ($ev->{button} == 1) { 281 } elsif ($ev->{button} == 1) {
258 $::CONN->send ("examine $self->{tag}"); 282 $::CONN->send ("examine $self->{tag}");
259 } elsif ($ev->{button} == 2) { 283 } elsif ($ev->{button} == 2) {
260 $::CONN->send ("apply $self->{tag}"); 284 $::CONN->send ("apply $self->{tag}");
261 } elsif ($ev->{button} == 3) { 285 } elsif ($ev->{button} == 3) {
269 ["unlock", sub { $::CONN->send ("lock " . pack "CN", 0, $self->{tag}) }], 293 ["unlock", sub { $::CONN->send ("lock " . pack "CN", 0, $self->{tag}) }],
270 ) 294 )
271 : ( 295 : (
272 ["lock", sub { $::CONN->send ("lock " . pack "CN", 1, $self->{tag}) }], 296 ["lock", sub { $::CONN->send ("lock " . pack "CN", 1, $self->{tag}) }],
273 ["drop", sub { $::CONN->send ("move $::CONN->{open_container} $self->{tag} 0") }], 297 ["drop", sub { $::CONN->send ("move $::CONN->{open_container} $self->{tag} 0") }],
298 ["move n",
299 sub {
300 do_n_dialog (sub { $::CONN->send ("move $targ $self->{tag} $_[0]") })
301 }
302 ]
274 ) 303 )
275 ), 304 ),
276 ); 305 );
277 306
278 CFClient::UI::Menu->new (items => \@menu_items)->popup ($ev); 307 CFClient::UI::Menu->new (items => \@menu_items)->popup ($ev);
331 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ") 360 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ")
332 . "\n\n$tooltip_std" 361 . "\n\n$tooltip_std"
333 ); 362 );
334} 363}
335 364
336package CFClient::Recorder; 365package CFClient::Binder;
337
338our $RECORD_WINDOW;
339
340my $CMDBOX;
341my $CURRENT_CMDS;
342my $REC_BTN;
343 366
344my @ALLOWED_MODIFIER_KEYS = ( 367my @ALLOWED_MODIFIER_KEYS = (
345 (CFClient::SDLK_LSHIFT) => "LSHIFT", 368 (CFClient::SDLK_LSHIFT),
346 (CFClient::SDLK_LCTRL ) => "LCTRL", 369 (CFClient::SDLK_LCTRL ),
347 (CFClient::SDLK_LALT ) => "LALT", 370 (CFClient::SDLK_LALT ),
348 (CFClient::SDLK_LMETA ) => "LMETA", 371 (CFClient::SDLK_LMETA ),
349 372
350 (CFClient::SDLK_RSHIFT) => "RSHIFT", 373 (CFClient::SDLK_RSHIFT),
351 (CFClient::SDLK_RCTRL ) => "RCTRL", 374 (CFClient::SDLK_RCTRL ),
352 (CFClient::SDLK_RALT ) => "RALT", 375 (CFClient::SDLK_RALT ),
353 (CFClient::SDLK_RMETA ) => "RMETA", 376 (CFClient::SDLK_RMETA ),
354); 377);
355 378
356my %ALLOWED_MODIFIERS = ( 379my %ALLOWED_MODIFIERS = (
357 (CFClient::KMOD_LSHIFT) => "LSHIFT", 380 (CFClient::KMOD_LSHIFT) => "LSHIFT",
358 (CFClient::KMOD_LCTRL ) => "LCTRL", 381 (CFClient::KMOD_LCTRL ) => "LCTRL",
383 CFClient::SDLK_F14, 406 CFClient::SDLK_F14,
384 CFClient::SDLK_F15, 407 CFClient::SDLK_F15,
385); 408);
386 409
387# this binding dialog asks for a key-combo to be pressed 410# this binding dialog asks for a key-combo to be pressed
388# and if successful it binds the modifier+symbol to the 411# and if successful it calls the $cb with $mod and $sym as args.
389# supplied actions in $cmd.
390# (Bindings are stored in $::CFG->{bindings}->{$mod}->{$sym})
391sub open_binding_dialog { 412sub open_binding_dialog {
392 my ($cmd) = @_; 413 my ($cb) = @_;
393 414
394 my $w = new CFClient::UI::FancyFrame 415 my $w = new CFClient::UI::FancyFrame
395 title => "Bind Action"; 416 title => "Bind Action",
417 x => "center",
418 y => "center";
396 419
397 $w->add (my $vb = new CFClient::UI::VBox); 420 $w->add (my $vb = new CFClient::UI::VBox);
398 $vb->add (new CFClient::UI::Label 421 $vb->add (new CFClient::UI::Label
399 text => "Press a modifier (CTRL, ALT and/or SHIFT) and a key." 422 text => "Press a modifier (CTRL, ALT and/or SHIFT) and a key."
400 ."You can only bind 0-9 and F1-F15 without modifiers." 423 ."You can only bind 0-9 and F1-F15 without modifiers."
423 return; 446 return;
424 } 447 }
425 448
426 $entry->focus_out; 449 $entry->focus_out;
427 450
428 $::CFG->{bindings}->{$mod}->{$sym} = $cmd; 451 $cb->($mod, $sym);
429 $::STATUSBOX->add ("Bound actions to '".keycombo_to_name ($mod, $sym)."'. Don't forget 'Save Config'!");
430 452
431 $w->destroy 453 $w->destroy
432 }); 454 });
433 455
434 $entry->focus_in; 456 $entry->focus_in;
435 $w->center;
436 $w->show; 457 $w->show;
437} 458}
438 459
439sub keycombo_to_name { 460sub keycombo_to_name {
440 my ($mod, $sym) = @_; 461 my ($mod, $sym) = @_;
441 462
442 my $mods = join '+', 463 my $mods = join '+',
443 map { $ALLOWED_MODIFIERS{$_} } 464 map { $ALLOWED_MODIFIERS{$_} }
444 grep { $_ & $mod } 465 grep { ($_ + 0) & ($mod + 0) }
445 keys %ALLOWED_MODIFIERS; 466 keys %ALLOWED_MODIFIERS;
446 $mods .= "+" if $mods ne ''; 467 $mods .= "+" if $mods ne '';
447 468
448 return $mods . CFClient::SDL_GetKeyName ($sym); 469 return $mods . CFClient::SDL_GetKeyName ($sym);
449} 470}
450 471
451sub clear_command_list {
452 $CMDBOX->clear () if $CMDBOX;
453}
454
455sub set_command_list {
456 my ($list) = @_;
457
458 return unless $CMDBOX;
459
460 $CMDBOX->clear ();
461 $CURRENT_CMDS = $list;
462
463 my $idx = 0;
464
465 for (@$list) {
466 $CMDBOX->add (my $hb = new CFClient::UI::HBox);
467
468 my $i = $idx;
469 $hb->add (new CFClient::UI::Button
470 text => "delete",
471 tooltip => "Deletes the action from the record",
472 on_activate => sub {
473 $CMDBOX->remove ($hb);
474 $list->[$i] = undef;
475 });
476
477 $hb->add (new CFClient::UI::Label text => $_);
478
479 $idx++
480 }
481}
482
483# if $show is 1 the recorder will be shown
484sub start {
485 my ($show) = @_;
486
487 $RECORD_WINDOW->show if $show;
488
489 $REC_BTN->set_text ("stop recording");
490 $REC_BTN->{recording} = 1;
491 clear_command_list;
492 $::CONN->start_record;
493}
494
495# if $autobind is 1 the recorder will be automatically
496# jump into the binding query and hide the recorder window
497sub stop {
498 my ($autobind) = @_;
499
500 $REC_BTN->set_text ("start recording");
501 $REC_BTN->{recording} = 0;
502
503 my $rec = $::CONN->stop_record;
504 return unless ref $rec eq 'ARRAY';
505 set_command_list ($rec);
506
507 if ($autobind) {
508 open_binding_dialog ([ grep { defined $_ } @$CURRENT_CMDS ]);
509 $RECORD_WINDOW->hide;
510 }
511}
512
513sub make_window {
514 $RECORD_WINDOW = new CFClient::UI::FancyFrame
515 req_y => 1,
516 req_x => -1,
517 title => "Action Recorder";
518
519 $RECORD_WINDOW->add (my $vb = new CFClient::UI::VBox);
520 $vb->add ($REC_BTN = new CFClient::UI::Button
521 text => "start recording",
522 tooltip => "Start/Stops recording of actions."
523 ."(CTRL+Insert Starts the recorder, Insert Stops recorder and binds automatically)"
524 ."All subsequent actions after the recording started will be captured."
525 ."The actions are displayed after the record was stopped."
526 ."To bind the action you have to click on the 'Bind' button",
527 on_activate => sub {
528 my ($btn) = @_;
529
530 unless ($btn->{recording}) {
531 start;
532 } else {
533 stop;
534 }
535 });
536 $vb->add ($CMDBOX = new CFClient::UI::VBox);
537 $vb->add (new CFClient::UI::Button
538 text => "bind",
539 tooltip => "This opens a query where you have to press the key combination to bind the recorded actions",
540 on_activate => sub {
541 open_binding_dialog ([ grep { defined $_ } @$CURRENT_CMDS ]);
542 });
543
544 $RECORD_WINDOW
545}
546
5471; 4721;
548 473
549=back 474=back
550 475
551=head1 AUTHOR 476=head1 AUTHOR

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines