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.73 by elmex, Mon May 29 19:30:27 2006 UTC vs.
Revision 1.86 by elmex, Fri Jun 2 16:27:27 2006 UTC

68 } 68 }
69 69
70 close CFG; 70 close CFG;
71} 71}
72 72
73mkdir "$Crossfire::VARDIR/pclient", 0777; 73mkdir "$Crossfire::VARDIR/cfplus", 0777;
74 74
75our $DB_ENV;
76
77{
78 use strict;
79
80 my $recover = $BerkeleyDB::db_version >= 4.4
81 ? eval "DB_REGISTER | DB_RECOVER"
82 : 0;
83
75our $DB_ENV = new BerkeleyDB::Env 84 $DB_ENV = new BerkeleyDB::Env
76 -Home => "$Crossfire::VARDIR/pclient", 85 -Home => "$Crossfire::VARDIR/cfplus",
77 -Cachesize => 1_000_000, 86 -Cachesize => 1_000_000,
78 -ErrFile => "$Crossfire::VARDIR/pclient/errorlog.txt", 87 -ErrFile => "$Crossfire::VARDIR/cfplus/errorlog.txt",
79# -ErrPrefix => "DATABASE", 88# -ErrPrefix => "DATABASE",
80 -Verbose => 1, 89 -Verbose => 1,
81 -Flags => DB_CREATE | DB_RECOVER | DB_INIT_MPOOL | DB_INIT_LOCK | DB_INIT_TXN, 90 -Flags => DB_CREATE | DB_RECOVER | DB_INIT_MPOOL | DB_INIT_LOCK | DB_INIT_TXN | $recover,
91 -SetFlags => DB_AUTO_COMMIT | DB_LOG_AUTOREMOVE,
82 or die "unable to create/open database home $Crossfire::VARDIR/pclient: $BerkeleyDB::Error"; 92 or die "unable to create/open database home $Crossfire::VARDIR/cfplus: $BerkeleyDB::Error";
93}
83 94
84sub db_table($) { 95sub db_table($) {
85 my ($table) = @_; 96 my ($table) = @_;
86 97
87 $table =~ s/([^a-zA-Z0-9_\-])/sprintf "=%x=", ord $1/ge; 98 $table =~ s/([^a-zA-Z0-9_\-])/sprintf "=%x=", ord $1/ge;
88 99
89 new CFClient::Database 100 new CFClient::Database
90 -Env => $DB_ENV, 101 -Env => $DB_ENV,
91 -Filename => $table, 102 -Filename => $table,
92# -Filename => "database", 103# -Filename => "database",
93# -Subname => $table, 104# -Subname => $table,
94 -Property => DB_CHKSUM, 105 -Property => DB_CHKSUM,
95 -Flags => DB_CREATE | DB_UPGRADE, 106 -Flags => DB_CREATE | DB_UPGRADE,
96 or die "unable to create/open database table $_[0]: $BerkeleyDB::Error"; 107 or die "unable to create/open database table $_[0]: $BerkeleyDB::Error"
97} 108}
98 109
99sub pod_to_pango($) { 110sub pod_to_pango($) {
100 my ($pom) = @_; 111 my ($pom) = @_;
101 112
192 203
193package CFClient::Item; 204package CFClient::Item;
194 205
195use strict; 206use strict;
196use Crossfire::Protocol::Constants; 207use Crossfire::Protocol::Constants;
208
209my $last_enter_count = 1;
197 210
198sub desc_string { 211sub desc_string {
199 my ($self) = @_; 212 my ($self) = @_;
200 213
201 my $desc = 214 my $desc =
227 my $weight = ($self->{nrof} || 1) * $self->{weight}; 240 my $weight = ($self->{nrof} || 1) * $self->{weight};
228 241
229 $weight < 0 ? "?" : $weight * 0.001 242 $weight < 0 ? "?" : $weight * 0.001
230} 243}
231 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
232sub update_widgets { 266sub update_widgets {
233 my ($self) = @_; 267 my ($self) = @_;
234 268
235 my $button_cb = sub { 269 my $button_cb = sub {
236 my (undef, $ev, $x, $y) = @_; 270 my (undef, $ev, $x, $y) = @_;
237 271
272 my $targ = $::CONN->{player}{tag};
273
274 if ($self->{container} == $::CONN->{player}{tag}) {
275 $targ = $::CONN->{open_container};
276 }
277
238 if (($ev->{mod} & CFClient::KMOD_SHIFT) && $ev->{button} == 1) { 278 if (($ev->{mod} & CFClient::KMOD_SHIFT) && $ev->{button} == 1) {
239 my $targ = $::CONN->{player}{tag};
240
241 if ($self->{container} == $::CONN->{player}{tag}) {
242 $targ = $::CONN->{open_container};
243 }
244
245 $::CONN->send ("move $targ $self->{tag} 0"); 279 $::CONN->send ("move $targ $self->{tag} 0")
280 if $targ || !($self->{flags} & F_LOCKED);
281 } elsif (($ev->{mod} & CFClient::KMOD_SHIFT) && $ev->{button} == 2) {
282 $self->{flags} & F_LOCKED
283 ? $::CONN->send ("lock " . pack "CN", 0, $self->{tag})
284 : $::CONN->send ("lock " . pack "CN", 1, $self->{tag})
246 } elsif ($ev->{button} == 1) { 285 } elsif ($ev->{button} == 1) {
247 $::CONN->send ("examine $self->{tag}"); 286 $::CONN->send ("examine $self->{tag}");
248 } elsif ($ev->{button} == 2) { 287 } elsif ($ev->{button} == 2) {
249 $::CONN->send ("apply $self->{tag}"); 288 $::CONN->send ("apply $self->{tag}");
250 } elsif ($ev->{button} == 3) { 289 } elsif ($ev->{button} == 3) {
258 ["unlock", sub { $::CONN->send ("lock " . pack "CN", 0, $self->{tag}) }], 297 ["unlock", sub { $::CONN->send ("lock " . pack "CN", 0, $self->{tag}) }],
259 ) 298 )
260 : ( 299 : (
261 ["lock", sub { $::CONN->send ("lock " . pack "CN", 1, $self->{tag}) }], 300 ["lock", sub { $::CONN->send ("lock " . pack "CN", 1, $self->{tag}) }],
262 ["drop", sub { $::CONN->send ("move $::CONN->{open_container} $self->{tag} 0") }], 301 ["drop", sub { $::CONN->send ("move $::CONN->{open_container} $self->{tag} 0") }],
302 ["move n",
303 sub {
304 do_n_dialog (sub { $::CONN->send ("move $targ $self->{tag} $_[0]") })
305 }
306 ]
263 ) 307 )
264 ), 308 ),
265 ); 309 );
266 310
267 CFClient::UI::Menu->new (items => \@menu_items)->popup ($ev); 311 CFClient::UI::Menu->new (items => \@menu_items)->popup ($ev);
272 316
273 my $tooltip_std = "<small>" 317 my $tooltip_std = "<small>"
274 . "Left click - examine item\n" 318 . "Left click - examine item\n"
275 . "Shift-Left click - " . ($self->{container} ? "move or drop" : "take") . " item\n" 319 . "Shift-Left click - " . ($self->{container} ? "move or drop" : "take") . " item\n"
276 . "Middle click - apply\n" 320 . "Middle click - apply\n"
321 . "Shift-Middle click - lock/unlock\n"
277 . "Right click - further options" 322 . "Right click - further options"
278 . "</small>\n"; 323 . "</small>\n";
279 324
280 $self->{face_widget} ||= new CFClient::UI::Face 325 $self->{face_widget} ||= new CFClient::UI::Face
281 can_events => 1, 326 can_events => 1,
320 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ") 365 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ")
321 . "\n\n$tooltip_std" 366 . "\n\n$tooltip_std"
322 ); 367 );
323} 368}
324 369
325package CFClient::Recorder; 370package CFClient::Binder;
326
327our $RECORD_WINDOW;
328
329my $CMDBOX;
330my $CURRENT_CMDS;
331my $REC_BTN;
332 371
333my @ALLOWED_MODIFIER_KEYS = ( 372my @ALLOWED_MODIFIER_KEYS = (
334 (CFClient::SDLK_LSHIFT) => "LSHIFT", 373 CFClient::SDLK_LSHIFT,
335 (CFClient::SDLK_LCTRL ) => "LCTRL", 374 CFClient::SDLK_LCTRL ,
336 (CFClient::SDLK_LALT ) => "LALT", 375 CFClient::SDLK_LALT ,
337 (CFClient::SDLK_LMETA ) => "LMETA", 376 CFClient::SDLK_LMETA ,
338 377
339 (CFClient::SDLK_RSHIFT) => "RSHIFT", 378 CFClient::SDLK_RSHIFT,
340 (CFClient::SDLK_RCTRL ) => "RCTRL", 379 CFClient::SDLK_RCTRL ,
341 (CFClient::SDLK_RALT ) => "RALT", 380 CFClient::SDLK_RALT ,
342 (CFClient::SDLK_RMETA ) => "RMETA", 381 CFClient::SDLK_RMETA ,
343); 382);
344 383
345my %ALLOWED_MODIFIERS = ( 384my %ALLOWED_MODIFIERS = (
346 (CFClient::KMOD_LSHIFT) => "LSHIFT", 385 CFClient::KMOD_LSHIFT => "LSHIFT",
347 (CFClient::KMOD_LCTRL ) => "LCTRL", 386 CFClient::KMOD_LCTRL => "LCTRL",
348 (CFClient::KMOD_LALT ) => "LALT", 387 CFClient::KMOD_LALT => "LALT",
349 (CFClient::KMOD_LMETA ) => "LMETA", 388 CFClient::KMOD_LMETA => "LMETA",
350 389
351 (CFClient::KMOD_RSHIFT) => "RSHIFT", 390 CFClient::KMOD_RSHIFT => "RSHIFT",
352 (CFClient::KMOD_RCTRL ) => "RCTRL", 391 CFClient::KMOD_RCTRL => "RCTRL",
353 (CFClient::KMOD_RALT ) => "RALT", 392 CFClient::KMOD_RALT => "RALT",
354 (CFClient::KMOD_RMETA ) => "RMETA", 393 CFClient::KMOD_RMETA => "RMETA",
355); 394);
356 395
357my %DIRECT_BIND_CHARS = map { $_ => 1 } qw/0 1 2 3 4 5 6 7 8 9/; 396my %DIRECT_BIND_CHARS = map { $_ => 1 } qw/0 1 2 3 4 5 6 7 8 9/;
358my @DIRECT_BIND_KEYS = ( 397my @DIRECT_BIND_KEYS = (
359 CFClient::SDLK_F1, 398 CFClient::SDLK_F1,
372 CFClient::SDLK_F14, 411 CFClient::SDLK_F14,
373 CFClient::SDLK_F15, 412 CFClient::SDLK_F15,
374); 413);
375 414
376# this binding dialog asks for a key-combo to be pressed 415# this binding dialog asks for a key-combo to be pressed
377# and if successful it binds the modifier+symbol to the 416# and if successful it calls the $cb with $mod and $sym as args.
378# supplied actions in $cmd.
379# (Bindings are stored in $::CFG->{bindings}->{$mod}->{$sym})
380sub open_binding_dialog { 417sub open_binding_dialog {
381 my ($cmd) = @_; 418 my ($cb) = @_;
382 419
383 my $w = new CFClient::UI::FancyFrame 420 my $w = new CFClient::UI::FancyFrame
384 title => "Bind Action"; 421 title => "Bind Action",
422 x => "center",
423 y => "center";
385 424
386 $w->add (my $vb = new CFClient::UI::VBox); 425 $w->add (my $vb = new CFClient::UI::VBox);
387 $vb->add (new CFClient::UI::Label 426 $vb->add (new CFClient::UI::Label
388 text => "Press a modifier (CTRL, ALT and/or SHIFT) and a key." 427 text => "Press a modifier (CTRL, ALT and/or SHIFT) and a key."
389 ."You can only bind 0-9 and F1-F15 without modifiers." 428 ."You can only bind 0-9 and F1-F15 without modifiers."
412 return; 451 return;
413 } 452 }
414 453
415 $entry->focus_out; 454 $entry->focus_out;
416 455
417 $::CFG->{bindings}->{$mod}->{$sym} = $cmd; 456 $cb->($mod, $sym);
418 $::STATUSBOX->add ("Bound actions to '".keycombo_to_name ($mod, $sym)."'. Don't forget Save Layout!");
419 457
420 $w->destroy 458 $w->destroy
421 }); 459 });
422 460
423 $entry->focus_in; 461 $entry->focus_in;
424 $w->center;
425 $w->show; 462 $w->show;
426} 463}
427 464
428sub keycombo_to_name { 465sub keycombo_to_name {
429 my ($mod, $sym) = @_; 466 my ($mod, $sym) = @_;
430 467
431 my $mods = join '+', 468 my $mods = join '+',
432 map { $ALLOWED_MODIFIERS{$_} } 469 map { $ALLOWED_MODIFIERS{$_} }
433 grep { $_ & $mod } 470 grep { ($_ + 0) & ($mod + 0) }
434 keys %ALLOWED_MODIFIERS; 471 keys %ALLOWED_MODIFIERS;
435 $mods .= "+" if $mods ne ''; 472 $mods .= "+" if $mods ne '';
436 473
437 return $mods . CFClient::SDL_GetKeyName ($sym); 474 return $mods . CFClient::SDL_GetKeyName ($sym);
438} 475}
439 476
440sub clear_command_list { 477package CFClient::Pickup;
441 $CMDBOX->clear () if $CMDBOX; 478# some pickup constants
442} 479sub PU_NOTHING { 0x00000000 }
443 480
444sub set_command_list { 481sub PU_DEBUG { 0x10000000 }
445 my ($list) = @_; 482sub PU_INHIBIT { 0x20000000 }
483sub PU_STOP { 0x40000000 }
484sub PU_NEWMODE { 0x80000000 }
446 485
447 return unless $CMDBOX; 486sub PU_RATIO { 0x0000000F }
448 487
449 $CMDBOX->clear (); 488sub PU_FOOD { 0x00000010 }
450 $CURRENT_CMDS = $list; 489sub PU_DRINK { 0x00000020 }
490sub PU_VALUABLES { 0x00000040 }
491sub PU_BOW { 0x00000080 }
451 492
452 my $idx = 0; 493sub PU_ARROW { 0x00000100 }
494sub PU_HELMET { 0x00000200 }
495sub PU_SHIELD { 0x00000400 }
496sub PU_ARMOUR { 0x00000800 }
453 497
454 for (@$list) { 498sub PU_BOOTS { 0x00001000 }
455 $CMDBOX->add (my $hb = new CFClient::UI::HBox); 499sub PU_GLOVES { 0x00002000 }
500sub PU_CLOAK { 0x00004000 }
501sub PU_KEY { 0x00008000 }
456 502
457 my $i = $idx; 503sub PU_MISSILEWEAPON { 0x00010000 }
458 $hb->add (new CFClient::UI::Button 504sub PU_ALLWEAPON { 0x00020000 }
459 text => "del", 505sub PU_MAGICAL { 0x00040000 }
460 tooltip => "Deletes the action from the record", 506sub PU_POTION { 0x00080000 }
461 on_activate => sub {
462 $CMDBOX->remove ($hb);
463 $list->[$i] = undef;
464 });
465 507
466 $hb->add (new CFClient::UI::Label text => $_); 508sub PU_SPELLBOOK { 0x00100000 }
509sub PU_SKILLSCROLL { 0x00200000 }
510sub PU_READABLES { 0x00400000 }
511sub PU_MAGIC_DEVICE { 0x00800000 }
467 512
468 $idx++ 513sub PU_NOT_CURSED { 0x01000000 }
469 }
470}
471 514
472# if $show is 1 the recorder will be shown 515sub PU_JEWELS { 0x02000000 }
473sub start {
474 my ($show) = @_;
475 516
476 $RECORD_WINDOW->show if $show;
477
478 $REC_BTN->set_text ("stop recording");
479 $REC_BTN->{recording} = 1;
480 clear_command_list;
481 $::CONN->start_record;
482}
483
484# if $autobind is 1 the recorder will be automatically
485# jump into the binding query and hide the recorder window
486sub stop {
487 my ($autobind) = @_;
488
489 $REC_BTN->set_text ("start recording");
490 $REC_BTN->{recording} = 0;
491
492 my $rec = $::CONN->stop_record;
493 return unless ref $rec eq 'ARRAY';
494 set_command_list ($rec);
495
496 if ($autobind) {
497 open_binding_dialog ([ grep { defined $_ } @$CURRENT_CMDS ]);
498 $RECORD_WINDOW->hide;
499 }
500}
501
502sub make_window {
503 $RECORD_WINDOW = new CFClient::UI::FancyFrame
504 req_y => 1,
505 req_x => -1,
506 title => "Action Recorder";
507
508 $RECORD_WINDOW->add (my $vb = new CFClient::UI::VBox);
509 $vb->add ($REC_BTN = new CFClient::UI::Button
510 text => "start recording",
511 tooltip => "Start/Stops recording of actions."
512 ."(CTRL+INS Starts the recorder, INS Stops recorder and binds automatically)"
513 ."All subsequent actions after the recording started will be captured."
514 ."The actions are displayed after the record was stopped."
515 ."To bind the action you have to click on the 'Bind' button",
516 on_activate => sub {
517 my ($btn) = @_;
518
519 unless ($btn->{recording}) {
520 start;
521 } else {
522 stop;
523 }
524 });
525 $vb->add ($CMDBOX = new CFClient::UI::VBox);
526 $vb->add (new CFClient::UI::Button
527 text => "bind",
528 tooltip => "This opens a query where you have to press the key combination to bind the recorded actions",
529 on_activate => sub {
530 open_binding_dialog ([ grep { defined $_ } @$CURRENT_CMDS ]);
531 });
532
533 $RECORD_WINDOW
534}
535 517
5361; 5181;
537 519
538=back 520=back
539 521

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines