add URL to pod and about
[clawsker.git] / clawsker
index 84821f98d1626c4963fe7357566fe0c4bd71a401..f0861539e478ee9c82f3ccfba8e181f667cc2865 100755 (executable)
--- a/clawsker
+++ b/clawsker
@@ -31,8 +31,11 @@ using Clawsker.
 --help
        Shows a brief help screen.
 
+--version
+       Show information about program, Claws Mail and Perl-GTK versions.
+
 --verbose
-       Tell more on the standard output.
+       Tells more on the standard output.
 
 --alternate-config-dir <dir>
        Uses <dir> as Claws Mail configuration dir.
@@ -50,13 +53,19 @@ A running Claws Mail cannot be detected if using the --clawsrc option because
 the directory is not assumed to be a Claws Mail configuration dir. If that is 
 the case use the --alternate-config-dir option instead.
 
+=head1 SEE ALSO
+
+Clawsker homepage "L<http://www.claws-mail.org/clawsker>"
+
 =head1 AUTHOR
 
-Ricardo Mones E<lt>ricardo@mones.orgE<gt>
+Main author is Ricardo Mones E<lt>ricardo@mones.orgE<gt> with the help of
+others. See the AUTHORS file on source tarball for a detailed list of 
+contributors.
 
 =head1 LICENSE
 
-Copyright (c) 2007-2008 by Ricardo Mones Lastra
+Copyright (c) 2007-2009 by Ricardo Mones Lastra
 
 This program is free software: you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published by
@@ -85,6 +94,7 @@ my $PREFIX = '@PREFIX@';
 my $LIBDIR = '@LIBDIR@';
 my $VERSION = '@VERSION@';
 my $VERBOSE = FALSE;
+my $CLAWSV = undef;
 my $main_window = undef;
 
 my $locale = (defined($ENV{LC_MESSAGES}) ? $ENV{LC_MESSAGES} : $ENV{LANG});
@@ -120,6 +130,7 @@ sub _ {
     tab_behaviour => _('Behaviour'),
     tab_gui => _('GUI'),
     tab_other => _('Other'),
+    tab_winpos => _('Windows'),
 
     ab_frame => _('Addressbook'),
     mem_frame => _('Memory'),
@@ -130,13 +141,13 @@ sub _ {
     msgs_frame => _('Messages'),
     stripes_frame => _('Coloured stripes'),
     sbar_frame => _('Scroll bars'),
-    mlist_frame => _('Message list'),
+    mlist_frame => _('Message List'),
     netm_frame => _('NetworkManager'),
 
     l_oth_use_dlg => _('Use detached address book edit dialogue'),
     h_oth_use_dlg => _('If true use a separate dialogue to edit a person\'s details. Otherwise will use a form embedded in the address book\'s main window.'),
-    l_oth_max_use => _('Maximum memory for message cache (Kb)'),
-    h_oth_max_use => _('The maximum amount of memory to use to cache messages, in kB.'),
+    l_oth_max_use => _('Maximum memory for message cache (kB)'),
+    h_oth_max_use => _('The maximum amount of memory to use to cache messages, in kilobytes.'),
     l_oth_min_time => _('Minimun time for cache elements (minutes)'),
     h_oth_min_time => _('The minimum time in minutes to keep a cache in memory. Caches more recent than this time will not be freed, even if the memory usage is too high.'),
     l_oth_use_netm => _('Use NetworkManager'),
@@ -146,18 +157,18 @@ sub _ {
     h_gui_b_unread => _('Show unread messages in the Message List using a bold font.'),
     l_gui_no_markup => _('Don\'t use markup in compose window'),
     h_gui_no_markup => _('Don\'t use bold and italic text in Compose dialogue\'s account selector.'),
-    l_gui_dot_lines => _('Use dotted lines in tree views'),
-    h_gui_dot_lines => _('Use the old dotted line look in the main window tree views (folder and message lists) instead of the modern lineless look.'),
+    l_gui_dot_lines => _('Use dotted lines in tree view components'),
+    h_gui_dot_lines => _('Use the old dotted line look in the main window tree views (Folder, Message and other lists) instead of the modern lineless look.'),
     l_gui_h_scroll => _('Enable horizontal scrollbar'),
     h_gui_h_scroll => _('Enable the horizontal scrollbar in the Message List.'),
-    l_gui_swp_from => _('Dislay To header in From field in Sent folder'),
-    h_gui_swp_from => _('Display the sender\'s email address in the To column of the Sent folder instead of the recipient\'s.'),
-    l_gui_v_scroll => _('Folder list scrollbar behaviour'),
+    l_gui_swp_from => _('Display To column instead From column in Sent folder'),
+    h_gui_swp_from => _('Display the recipient\'s email address in a To column of the Sent folder instead of the originator\'s one in a From column.'),
+    l_gui_v_scroll => _('Folder List scrollbar behaviour'),
     h_gui_v_scroll => _('Specify the policy of vertical scrollbar of Folder List: show always, automatic or hide always.'),
     l_gui_v_scroll_show => _('Show always'),
     l_gui_v_scroll_auto => _('Automatic'),
     l_gui_v_scroll_hide => _('Hide always'),
-    l_gui_strip_off => _('Striped lines contrast'),
+    l_gui_strip_off => _('Coloured lines contrast'),
     h_gui_strip_off => _('Specify the value to use when creating alternately coloured lines in tree view components. The smaller the value, the less visible the difference in the alternating colours of the lines.'),
     l_gui_cursor_v => _('Show Cursor in message view'),
     h_gui_cursor_v => _('Display the cursor in the message view.'),
@@ -166,9 +177,9 @@ sub _ {
     l_gui_strip_all => _('Use stripes in all tree view components'),
     h_gui_strip_all => _('Enable alternately coloured lines in all tree view components.'),
     l_gui_strip_sum => _('Use stripes in Folder List and Message List'),
-    h_gui_strip_sum => _('Enable alternately coloured lines in message list and folder list'),
+    h_gui_strip_sum => _('Enable alternately coloured lines in Message list and Folder list.'),
     l_gui_two_line_v => _('2 lines per Message List item in 3-column layout'),
-    h_gui_two_line_v => _('Spread Message List information over two lines when using the three column mode'),
+    h_gui_two_line_v => _('Spread Message List information over two lines when using the three column mode.'),
 
     l_beh_hover_t => _('Drag \'n\' drop hover timeout (ms)'),
     h_beh_hover_t => _('Time in milliseconds that will cause a folder tree to expand when the mouse cursor is held over it during drag and drop.'),
@@ -192,20 +203,36 @@ sub _ {
     h_beh_warn_dnd => _('Display a confirmation dialogue on drag \'n\' drop of folders.'),
     l_beh_out_ascii => _('Ougoing messages fallback to ASCII'),
     h_beh_out_ascii => _('If content allows, ASCII will be used to encode outgoing messages, otherwise the user-defined encoding is enforced always.'),
+    l_beh_pp_unsel => _('Primary paste unselects selection'),
+    h_beh_pp_unsel => _('Controls how pasting using middle-click changes the selected text and insertion point.'),
 
     l_col_emphasis => _('X-Mailer header'),
     h_col_emphasis => _('The colour used for the X-Mailer line when its value is Claws Mail.'),
     l_col_log_err => _('Error messages'),
     h_col_log_err => _('Colour for error messages in log window.'),
     l_col_log_in => _('Server messages'),
-    h_col_log_in => _('Colour for input messages in log window.'),
+    h_col_log_in => _('Colour for messages received from servers in log window.'),
     l_col_log_msg => _('Standard messages'),
     h_col_log_msg => _('Colour for messages in log window.'),
     l_col_log_out => _('Client messages'),
-    h_col_log_out => _('Colour for output messages in log window.'),
+    h_col_log_out => _('Colour for messages sent to servers in log window.'),
     l_col_log_warn => _('Warnings'),
     h_col_log_warn => _('Colour for warning messages in log window.'),
 
+    l_win_x => _('X position'),
+    h_win_x => _('X coordinate for window\'s top-left corner.'),
+    l_win_y => _('Y position'),
+    h_win_y => _('Y coordinate for window\'s top-left corner.'),
+    l_win_w => _('Width'),
+    h_win_w => _('Window\'s width in pixels.'),
+    l_win_h => _('Height'),
+    h_win_h => _('Window\'s height in pixels.'),
+
+    l_win_main_mx => _('Maximized'),
+    h_win_main_mx => _('Changes window maximized status.'),
+    l_win_main_fs => _('Full-screen'),
+    h_win_main_fs => _('Changes full screen status.'),
+
     e_error => _('Error: '),
     e_noclawsrc => _('resource file for Claws Mail was not found.'),
     e_running => _('seems Claws Mail is currently running, close it first.'),
@@ -238,6 +265,52 @@ use constant HBOX_SPC => 5;
 use constant FRAME_SPC => 2;
 use constant PAGE_SPC => 5;
 
+# version functions
+
+sub version_greater_or_equal() {
+  my ($version, $refvers) = @_;
+  my @version = split (/\./, $version);
+  my @refvers = split (/\./, $refvers);
+  while ($#version < $#refvers) {
+    push (@version, '0');
+  }
+  my $idx = 0;
+  while (($idx <= $#refvers) 
+         and (int ($version[$idx]) == int ($refvers[$idx]))) {
+    ++$idx;
+  }
+  return TRUE if (($idx > $#refvers) 
+               or (int ($version[$idx]) >= int ($refvers[$idx])));
+  return FALSE;
+}
+
+sub get_claws_version() {
+    my @cmbin = (
+        'claws-mail',
+    );
+    my $res = "";
+    foreach my $bin (@cmbin) {
+        $_ = qx/which $bin/;
+        chomp;
+        last if ($_ ne "");
+    }
+    return "" unless ($_); # not installed
+    $_ = qx/$_ -v/;
+    chomp;
+    my @fver = split (/ /);
+    die "Invalid version string" unless ($fver[2] eq "version");
+    my @ver = split (/\./, $fver[3]);
+    $res .= "$ver[0].";
+    $res .= "$ver[1].";
+    if ($ver[2] =~ /(\d+)cvs(\d+)/) {
+        $res .= "$1.$2";
+    }
+    else {
+        $res .= "$ver[2].0";
+    }
+    return $res;
+}
+
 # data handlers and auxiliar functions
 
 sub handle_bool_value {
@@ -361,6 +434,11 @@ sub set_widget_hint() {
     }
 }
 
+sub set_widget_sens() {
+    my ($wdgt, $minver) = @_;
+    $wdgt->set_sensitive (&version_greater_or_equal ($CLAWSV, $minver));
+}
+
 # graphic element creation 
 
 sub new_check_button_for {
@@ -371,33 +449,43 @@ sub new_check_button_for {
     my $hbox = Gtk2::HBox->new (FALSE, 5);
     my $cb = Gtk2::CheckButton->new ($label);
     $$hash{$key}[GUI] = $cb;
-    $cb->set_active ($HPVALUE{$name} eq '1');
+    if (defined ($HPVALUE{$name})) {
+        $cb->set_active ($HPVALUE{$name} eq '1');
+    }
     $cb->signal_connect (clicked => sub {
             my ($w, $e) = @_;
            &handle_bool_value($w, $e, \$HPVALUE{$name});
         });
     &set_widget_hint ($cb, $$hash{$key}[DESC]);
+    &set_widget_sens ($cb, $$hash{$key}[CMVER]);
     $hbox->pack_start ($cb, FALSE, FALSE, HBOX_SPC);
     #
     return $hbox;
 }
 
-sub new_text_box_for {
+sub new_text_box_for_int {
     my ($hash, $key) = @_;
     my $name = $$hash{$key}[NAME];
     my $label = $$hash{$key}[LABEL];
+    my @type = split (/,/, $$hash{$key}[TYPE]);
+    push (@type, 0), push (@type, 10000) unless ($#type > 0); 
     #
     my $hbox = Gtk2::HBox->new (FALSE, 5);
     my $glabel = Gtk2::Label->new ($label);
-    my $gentry = Gtk2::Entry->new;
-    $gentry->set_width_chars (8);
+    my $pagei = int (($type[2] - $type[1]) / 10);
+    my $adjust = Gtk2::Adjustment->new (
+            $HPVALUE{$name}, $type[1], $type[2], 1, $pagei, 10
+       );
+    my $gentry = Gtk2::SpinButton->new ($adjust, 1, 0);
+    $gentry->set_numeric (TRUE);
     $$hash{$key}[GUI] = $gentry;
-    $gentry->set_text($HPVALUE{$name});
-    $gentry->signal_connect(changed => sub {
+    $gentry->signal_connect('value-changed' => sub {
             my ($w, $e) = @_;
-           &handle_int_value($w, $e, \$HPVALUE{$name}); # FIXME int only
+           &handle_int_value($w, $e, \$HPVALUE{$name});
         });
     &set_widget_hint ($gentry, $$hash{$key}[DESC]);
+    &set_widget_sens ($gentry, $$hash{$key}[CMVER]);
+    $glabel->set_sensitive ($gentry->sensitive);
     $hbox->pack_start ($glabel, FALSE, FALSE, HBOX_SPC);
     $hbox->pack_start ($gentry, FALSE, FALSE, HBOX_SPC);
     #
@@ -421,6 +509,8 @@ sub new_color_button_for {
            &handle_color_value($w, $e, \$HPVALUE{$name}); 
         });
     &set_widget_hint ($button, $$hash{$key}[DESC]);
+    &set_widget_sens ($button, $$hash{$key}[CMVER]);
+    $glabel->set_sensitive ($button->sensitive);
     $hbox->pack_start ($button, FALSE, FALSE, HBOX_SPC);
     $hbox->pack_start ($glabel, FALSE, FALSE, HBOX_SPC);
     #
@@ -447,12 +537,42 @@ sub new_selection_box_for {
         });
     $combo->set_active ($HPVALUE{$name});
     &set_widget_hint ($combo, $$hash{$key}[DESC]);
+    &set_widget_sens ($combo, $$hash{$key}[CMVER]);
+    $glabel->set_sensitive ($combo->sensitive);
     $hbox->pack_start ($glabel, FALSE, FALSE, HBOX_SPC);
     $hbox->pack_start ($combo, FALSE, FALSE, HBOX_SPC);
     #
     return $hbox;
 }
 
+# more graphic helpers
+
+sub new_hbox_pack() {
+    my $hbox = Gtk2::HBox->new (FALSE, 5);
+    $hbox->set_border_width (PAGE_SPC);
+    foreach my $item (@_) {
+        $hbox->pack_start ($item, FALSE, FALSE, 0);
+    }
+    return $hbox;
+}    
+
+sub new_vbox_pack() {
+    my $vbox = Gtk2::VBox->new (FALSE, 5);
+    $vbox->set_border_width (PAGE_SPC);
+    foreach my $item (@_) {
+        $vbox->pack_start ($item, FALSE, FALSE, 0);
+    }
+    return $vbox;
+}    
+
+sub new_subpage_frame () {
+    my ($box, $title, $notpacked) = @_;
+    my $frame = Gtk2::Frame->new ($title);
+    $frame->add ($box);    
+    return &new_vbox_pack ($frame) unless defined ($notpacked);
+    return $frame;
+}
+
 # preference maps and corresponding page creation subs
 
 %pr::oth = ( # other preferences
@@ -469,7 +589,7 @@ sub new_selection_box_for {
        'cache_max_mem_usage',
        $xl::s{l_oth_max_use},
        $xl::s{h_oth_max_use},
-       'int',
+       'int,0,262144', # 0 Kb - 256 Mb
        '0.0.0',
        '4096',
        undef,
@@ -478,7 +598,7 @@ sub new_selection_box_for {
         'cache_min_keep_time',
        $xl::s{l_oth_min_time},
        $xl::s{h_oth_min_time},
-       'int',
+       'int,0,120', # 0 minutes - 2 hours
        '0.0.0',
        '15',
        undef,
@@ -506,8 +626,8 @@ sub new_other_page() {
     $ab_frame->add ($vb1);
 
     my $mem_frame = Gtk2::Frame->new ($xl::s{mem_frame}); 
-    my $tb_max_use = &new_text_box_for(\%pr::oth, 'max_use');
-    my $tb_min_time = &new_text_box_for(\%pr::oth, 'min_time');
+    my $tb_max_use = &new_text_box_for_int(\%pr::oth, 'max_use');
+    my $tb_min_time = &new_text_box_for_int(\%pr::oth, 'min_time');
     my $vb2 = Gtk2::VBox->new (FALSE, 5);
     $vb2->set_border_width (PAGE_SPC); 
     $vb2->pack_start ($tb_max_use, FALSE, FALSE, 0);
@@ -587,7 +707,7 @@ sub new_other_page() {
         'stripes_color_offset',
        $xl::s{l_gui_strip_off},
        $xl::s{h_gui_strip_off},
-       'int',
+       'int,0,10000', # no idea what this number means
        '0.0.0',
        '4000',
        undef,
@@ -646,7 +766,7 @@ sub new_gui_page() {
     my $stripes_frame = Gtk2::Frame->new ($xl::s{stripes_frame});
     my $cb_strip_all = &new_check_button_for (\%pr::gui, 'strip_all');
     my $cb_strip_sum = &new_check_button_for (\%pr::gui, 'strip_sum');
-    my $tb_strip_off = &new_text_box_for (\%pr::gui, 'strip_off');
+    my $tb_strip_off = &new_text_box_for_int (\%pr::gui, 'strip_off');
     my $vb1 = Gtk2::VBox->new (FALSE, 5);
     $vb1->set_border_width (PAGE_SPC);
     $vb1->pack_start ($cb_strip_all, FALSE, FALSE, 0);
@@ -695,7 +815,7 @@ sub new_gui_page() {
         'hover_timeout',
         $xl::s{l_beh_hover_t},
         $xl::s{h_beh_hover_t},
-       'int',
+       'int,100,3000', # 0.1 seconds - 3 seconds
        '0.0.0',
        '500',
        undef,
@@ -740,7 +860,7 @@ sub new_gui_page() {
         'statusbar_update_step',
         $xl::s{l_beh_up_step},
         $xl::s{h_beh_up_step},
-       'int',
+       'int,1,200', # 1 item - 200 items
        '0.0.0',
        '10',
        undef,
@@ -749,7 +869,7 @@ sub new_gui_page() {
         'thread_by_subject_max_age',
         $xl::s{l_beh_thread_a},
         $xl::s{h_beh_thread_a},
-       'int',
+       'int,1,30', # 1 day - 30 days
        '0.0.0',
        '10',
        undef,
@@ -790,6 +910,15 @@ sub new_gui_page() {
        '1',
        undef,
     ],
+    pp_unsel => [
+        'primary_paste_unselects',
+        $xl::s{l_beh_pp_unsel},
+        $xl::s{h_beh_pp_unsel},
+        'bool',
+        '3.6.1.35',
+        '0',
+        undef,
+    ],
 );
 
 sub new_behaviour_page() {
@@ -797,7 +926,7 @@ sub new_behaviour_page() {
     $bf->set_border_width (PAGE_SPC);
 
     my $dnd_frame = Gtk2::Frame->new ($xl::s{dnd_frame});
-    my $tb_hoover_t = &new_text_box_for (\%pr::beh, 'hover_t');
+    my $tb_hoover_t = &new_text_box_for_int (\%pr::beh, 'hover_t');
     my $cb_warn_dnd = &new_check_button_for (\%pr::beh, 'warn_dnd');
     my $vb1 = Gtk2::VBox->new (FALSE, 5);
     $vb1->set_border_width (PAGE_SPC);
@@ -814,8 +943,8 @@ sub new_behaviour_page() {
     $hb1->pack_start ($cb_unsafe_ssl, FALSE, FALSE, 0);
     $ssl_frame->add ($hb1);
 
-    my $tb_up_step = &new_text_box_for (\%pr::beh, 'up_step');
-    my $tb_thread_a = &new_text_box_for (\%pr::beh, 'thread_a');
+    my $tb_up_step = &new_text_box_for_int (\%pr::beh, 'up_step');
+    my $tb_thread_a = &new_text_box_for_int (\%pr::beh, 'thread_a');
 
     my $msgs_frame = Gtk2::Frame->new ($xl::s{msgs_frame});
     my $cb_flowed = &new_check_button_for (\%pr::beh, 'flowed');
@@ -823,6 +952,7 @@ sub new_behaviour_page() {
     my $cb_use_utf8 = &new_check_button_for (\%pr::beh, 'use_utf8');
     my $cb_dangerous = &new_check_button_for (\%pr::beh, 'dangerous');
     my $cb_out_ascii = &new_check_button_for (\%pr::beh, 'out_ascii');
+    my $cb_pp_unsel = &new_check_button_for (\%pr::beh, 'pp_unsel');
     my $vb2 = Gtk2::VBox->new (FALSE, 5);    
     $vb2->set_border_width (PAGE_SPC);
     $vb2->pack_start ($cb_flowed, FALSE, FALSE, 0);
@@ -830,6 +960,7 @@ sub new_behaviour_page() {
     $vb2->pack_start ($cb_use_utf8, FALSE, FALSE, 0);
     $vb2->pack_start ($cb_dangerous, FALSE, FALSE, 0);
     $vb2->pack_start ($cb_out_ascii, FALSE, FALSE, 0);
+    $vb2->pack_start ($cb_pp_unsel, FALSE, FALSE, 0);
     $msgs_frame->add ($vb2);
 
     $bf->pack_start ($dnd_frame, FALSE, FALSE, FRAME_SPC);
@@ -930,10 +1061,750 @@ sub new_colours_page() {
     return $cf;
 }
 
-# the command line help
-sub print_help() {
-    my $line = '-' x length ($xl::s{about_title}) . "\n";
-    print $line;
+%pr::win = ( # tweak window positions and/or sizes
+    main_x => [
+        'mainwin_x',
+        $xl::s{l_win_x},
+        $xl::s{h_win_x},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '16',
+       undef,
+    ],
+    main_y => [
+        'mainwin_y',
+        $xl::s{l_win_y},
+        $xl::s{h_win_y},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '16',
+       undef,
+    ],
+    main_w => [
+        'mainwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '779',
+       undef,
+    ],
+    main_h => [
+        'mainwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '568',
+       undef,
+    ],
+    main_mx => [
+        'mainwin_maximised',
+        $xl::s{l_win_main_mx},
+        $xl::s{h_win_main_mx},
+        'bool',
+        '0.0.0',
+        '0',
+        undef,
+    ],
+    main_fs => [
+        'mainwin_fullscreen',
+        $xl::s{l_win_main_fs},
+        $xl::s{h_win_main_fs},
+        'bool',
+        '0.0.0',
+        '0',
+        undef,
+    ],
+    msgs_x => [
+        'main_messagewin_x',
+        $xl::s{l_win_x},
+        $xl::s{h_win_x},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '256',
+       undef,
+    ],
+    msgs_y => [
+        'main_messagewin_y',
+        $xl::s{l_win_y},
+        $xl::s{h_win_y},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '210',
+       undef,
+    ],
+    msgs_w => [
+        'messagewin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '600',
+       undef,
+    ],
+    msgs_h => [
+        'messagewin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '540',
+       undef,
+    ],
+    send_w => [
+        'sendwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+        '0.0.0',
+        '460',
+        undef,
+    ],
+    send_h => [
+        'sendwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+        '0.0.0',
+        '-1',
+        undef,
+    ],
+    recv_w => [
+        'receivewin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+        '0.0.0',
+        '460',
+        undef,
+    ],
+    recv_h => [
+        'receivewin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+        '0.0.0',
+        '-1',
+        undef,
+    ],
+    fold_x => [
+        'folderwin_x',
+        $xl::s{l_win_x},
+        $xl::s{h_win_x},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '16',
+       undef,
+    ],
+    fold_y => [
+        'folderwin_y',
+        $xl::s{l_win_y},
+        $xl::s{h_win_y},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '16',
+       undef,
+    ],
+    fold_w => [
+        'folderitemwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '500',
+       undef,
+    ],
+    fold_h => [
+        'folderitemwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    fsel_w => [
+        'folderselwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '300',
+       undef,
+    ],
+    fsel_h => [
+        'folderselwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    sour_w => [
+        'sourcewin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '600',
+       undef,
+    ],
+    sour_h => [
+        'sourcewin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '500',
+       undef,
+    ],
+    addr_w => [
+        'addressbookwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '520',
+       undef,
+    ],
+    addr_h => [
+        'addressbookwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    adep_w => [
+        'addressbookeditpersonwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '640',
+       undef,
+    ],
+    adep_h => [
+        'addressbookeditpersonwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '320',
+       undef,
+    ],
+    adeg_w => [
+        'addressbookeditgroupwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '580',
+       undef,
+    ],
+    adeg_h => [
+        'addressbookeditgroupwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '340',
+       undef,
+    ],
+    adda_w => [
+        'addressaddwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '300',
+       undef,
+    ],
+    adda_h => [
+        'addressaddwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    addf_w => [
+        'addressbook_folderselwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '300',
+       undef,
+    ],
+    addf_h => [
+        'addressbook_folderselwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    acce_w => [
+        'editaccountwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '500',
+       undef,
+    ],
+    acce_h => [
+        'editaccountwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    acco_w => [
+        'accountswin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '500',
+       undef,
+    ],
+    acco_h => [
+        'accountswin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    filt_w => [
+        'filteringwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '500',
+       undef,
+    ],
+    filt_h => [
+        'filteringwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    fila_w => [
+        'filteringactionwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '490',
+       undef,
+    ],
+    fila_h => [
+        'filteringactionwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    fild_w => [
+        'filtering_debugwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '600',
+       undef,
+    ],
+    fild_h => [
+        'filtering_debugwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    matc_w => [
+        'matcherwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '520',
+       undef,
+    ],
+    matc_h => [
+        'matcherwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    pref_w => [
+        'prefswin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '600',
+       undef,
+    ],
+    pref_h => [
+        'prefswin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    temp_w => [
+        'templateswin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '480',
+       undef,
+    ],
+    temp_h => [
+        'templateswin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    acti_w => [
+        'actionswin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '486',
+       undef,
+    ],
+    acti_h => [
+        'actionswin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    tags_w => [
+        'tagswin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '486',
+       undef,
+    ],
+    tags_h => [
+        'tagswin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    plug_w => [
+        'pluginswin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    plug_h => [
+        'pluginswin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    logw_w => [
+        'logwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '520',
+       undef,
+    ],
+    logw_h => [
+        'logwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+    prin_w => [
+        'print_previewwin_width',
+        $xl::s{l_win_w},
+        $xl::s{h_win_w},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '600',
+       undef,
+    ],
+    prin_h => [
+        'print_previewwin_height',
+        $xl::s{l_win_h},
+        $xl::s{h_win_h},
+       'int,0,3000', # 0 pixels - 3000 pixels
+       '0.0.0',
+       '-1',
+       undef,
+    ],
+);
+
+sub new_winpos_subpage_main() {
+    return &new_subpage_frame (
+               &new_vbox_pack (
+                   &new_text_box_for_int (\%pr::win, 'main_x'), 
+                   &new_text_box_for_int (\%pr::win, 'main_y'), 
+                   &new_text_box_for_int (\%pr::win, 'main_w'), 
+                   &new_text_box_for_int (\%pr::win, 'main_h'), 
+                   &new_hbox_pack (
+                       &new_check_button_for (\%pr::win, 'main_fs'), 
+                       &new_check_button_for (\%pr::win, 'main_mx'))),
+               _('Main window')
+           );
+}
+
+sub new_winpos_subpage_msgs() {
+    return &new_subpage_frame (
+               &new_vbox_pack (
+                   &new_text_box_for_int (\%pr::win, 'msgs_x'),
+                   &new_text_box_for_int (\%pr::win, 'msgs_y'),
+                   &new_text_box_for_int (\%pr::win, 'msgs_w'),
+                   &new_text_box_for_int (\%pr::win, 'msgs_h')),
+               _('Message window')
+           );
+}
+
+sub new_winpos_subpage_sendrecv() {
+    return &new_vbox_pack (
+               &new_subpage_frame (
+                   &new_vbox_pack (
+                       &new_hbox_pack (
+                           &new_text_box_for_int (\%pr::win, 'send_w'),
+                           &new_text_box_for_int (\%pr::win, 'send_h'))),
+                   _('Send window'), 'not-packed'),
+               &new_subpage_frame (
+                   &new_vbox_pack (
+                       &new_hbox_pack (
+                           &new_text_box_for_int (\%pr::win, 'recv_w'),
+                           &new_text_box_for_int (\%pr::win, 'recv_h'))),
+                   _('Receive window'), 'not-packed')
+           );
+}
+
+sub new_winpos_subpage_fold() {
+    return &new_vbox_pack (
+               &new_subpage_frame (
+                   &new_vbox_pack (
+                       &new_text_box_for_int (\%pr::win, 'fold_x'), 
+                       &new_text_box_for_int (\%pr::win, 'fold_y'), 
+                       &new_text_box_for_int (\%pr::win, 'fold_w'), 
+                       &new_text_box_for_int (\%pr::win, 'fold_h')),
+                   _('Folder window'), 'not-packed'),
+               &new_subpage_frame (
+                   &new_vbox_pack (
+                       &new_text_box_for_int (\%pr::win, 'fsel_w'),
+                       &new_text_box_for_int (\%pr::win, 'fsel_h')),
+                   _('Folder selection window'), 'not-packed')
+           );
+}
+
+sub new_winpos_subpage_sour() {
+    return &new_subpage_frame (
+               &new_vbox_pack (
+                   &new_text_box_for_int (\%pr::win, 'sour_w'),
+                   &new_text_box_for_int (\%pr::win, 'sour_h')),
+               _('View source window')
+           );
+}
+
+sub new_winpos_subpage_addrbook() {
+    return &new_vbox_pack (
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'addr_w'),
+                               &new_text_box_for_int (\%pr::win, 'addr_h'))),
+                     _('Addressbook main window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'adep_w'),
+                               &new_text_box_for_int (\%pr::win, 'adep_h'))),
+                     _('Edit person window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'adeg_w'),
+                               &new_text_box_for_int (\%pr::win, 'adeg_h'))),
+                     _('Edit group window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'adda_w'),
+                               &new_text_box_for_int (\%pr::win, 'adda_h'))),
+                     _('Add address window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'addf_w'),
+                               &new_text_box_for_int (\%pr::win, 'addf_h'))),
+                     _('Folder select window'), 'not-packed')
+           );
+}
+
+sub new_winpos_subpage_accounts() {
+    return &new_vbox_pack (
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'acco_w'),
+                               &new_text_box_for_int (\%pr::win, 'acco_h'))),
+                     _('Accounts window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'acce_w'),
+                               &new_text_box_for_int (\%pr::win, 'acce_h'))),
+                     _('Edit account window'), 'not-packed')
+           );
+}
+
+sub new_winpos_subpage_filtering() {
+    return &new_vbox_pack (
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'filt_w'),
+                               &new_text_box_for_int (\%pr::win, 'filt_h'))),
+                     _('Filtering window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'fila_w'),
+                               &new_text_box_for_int (\%pr::win, 'fila_h'))),
+                     _('Filtering actions window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'fild_w'),
+                               &new_text_box_for_int (\%pr::win, 'fild_h'))),
+                     _('Filtering debug window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'matc_w'),
+                               &new_text_box_for_int (\%pr::win, 'matc_h'))),
+                     _('Matcher window'), 'not-packed')
+           );
+}
+
+sub new_winpos_subpage_prefs() {
+    return &new_vbox_pack (
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'pref_w'),
+                               &new_text_box_for_int (\%pr::win, 'pref_h'))),
+                     _('Preferences window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'temp_w'),
+                               &new_text_box_for_int (\%pr::win, 'temp_h'))),
+                     _('Templates window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'acti_w'),
+                               &new_text_box_for_int (\%pr::win, 'acti_h'))),
+                     _('Actions window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'tags_w'),
+                               &new_text_box_for_int (\%pr::win, 'tags_h'))),
+                     _('Tags window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'plug_w'),
+                               &new_text_box_for_int (\%pr::win, 'plug_h'))),
+                     _('Plugins window'), 'not-packed')
+           );
+}
+
+sub new_winpos_subpage_misc() {
+    return &new_vbox_pack (
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'logw_w'),
+                               &new_text_box_for_int (\%pr::win, 'logw_h'))),
+                     _('Log window'), 'not-packed'),
+                &new_subpage_frame (
+                     &new_vbox_pack (
+                          &new_hbox_pack (
+                               &new_text_box_for_int (\%pr::win, 'prin_w'),
+                               &new_text_box_for_int (\%pr::win, 'prin_h'))),
+                     _('Print preview window'), 'not-packed')
+           );
+}
+
+sub new_winpos_page() {
+    my $winbook = Gtk2::Notebook->new;
+    $winbook->set_tab_pos ('right');
+    $winbook->append_page (&new_winpos_subpage_main, _('Main'));
+    $winbook->append_page (&new_winpos_subpage_msgs, _('Message'));
+    $winbook->append_page (&new_winpos_subpage_sendrecv, _('Send/Receive'));
+    $winbook->append_page (&new_winpos_subpage_fold, _('Folder'));
+    $winbook->append_page (&new_winpos_subpage_sour, _('View source'));
+    $winbook->append_page (&new_winpos_subpage_addrbook, _('Addressbook'));
+    $winbook->append_page (&new_winpos_subpage_accounts, _('Accounts'));
+    $winbook->append_page (&new_winpos_subpage_filtering, _('Filtering'));
+    $winbook->append_page (&new_winpos_subpage_prefs, _('Preferences'));
+    $winbook->append_page (&new_winpos_subpage_misc, _('Other'));
+    return $winbook;
+}
+
+# version info
+sub print_version() {
     print $xl::s{about_title} . "\n";
     print $xl::s{about_version} . " $VERSION\n";
     print "Perl-GLib " . $Glib::VERSION;
@@ -951,11 +1822,23 @@ sub print_help() {
                  &Gtk2::minor_version, &Gtk2::micro_version);
     }
     print "\n";
+    my $clawsver = ($CLAWSV eq "") ? 
+                _("was not found!") : 
+                (_("returned version ") . $CLAWSV);
+    print "Claws Mail " . $clawsver . "\n";
+}
+
+# the command line help
+sub print_help() {
+    my $line = '-' x length ($xl::s{about_title}) . "\n";
+    print $line;
+    print $xl::s{about_title} . "\n";
     print $line;
     print _("Syntax:\n");
     print _("    clawsker [options]\n");
     print _("Options:\n");
     print _("    --help                         Prints this help screen.\n");
+    print _("    --version                      Prints version infos.\n");
     print _("    --verbose                      More messages on standard output.\n");
     print _("    --alternate-config-dir <dir>   Uses <dir> as Claws Mail config dir.\n");
     print _("    --clawsrc <file>               Uses <file> as full resource name.\n");
@@ -971,6 +1854,7 @@ sub command_line_fatal() {
 
 # parse the command line
 sub parse_command_line() {
+    $CLAWSV = &get_claws_version;
     my $arg = 0;
     while (defined($ARGV[$arg])) {
         for ($ARGV[$arg]) {
@@ -978,10 +1862,23 @@ sub parse_command_line() {
                &print_help; 
                 return FALSE;
            };
+            /--version/ && do { 
+               &print_version; 
+                return FALSE;
+           };
            /--verbose/ && do {
                $VERBOSE = TRUE;
                last;
            };
+           /--use-claws-version/ && do {
+               ++$arg;
+               &command_line_fatal ("required version")
+                   unless defined($ARGV[$arg]);
+               &command_line_fatal ("required a dotted numeric value")
+                   unless ($ARGV[$arg] =~ /[\d\.]+/);
+               $CLAWSV = $ARGV[$arg];
+               last;
+           };
            /--alternate-config-dir/ && do {
                ++$arg;
                &command_line_fatal ($xl::s{e_requireddir})
@@ -989,6 +1886,8 @@ sub parse_command_line() {
                &command_line_fatal ($xl::s{e_notadir})
                    unless -d $ARGV[$arg];
                $CONFIGDIR = $ARGV[$arg];
+               $CONFIGDIR .= "/" 
+                   unless ($CONFIGDIR =~ /.*\/$/);
                $ALTCONFIGDIR = TRUE;
                last;
            };
@@ -1012,7 +1911,7 @@ sub parse_command_line() {
 
 # update the hidden preferences status from loaded values
 sub init_hidden_preferences() {
-    foreach my $hash (\%pr::beh, \%pr::col, \%pr::gui, \%pr::oth) {
+    foreach my $hash (\%pr::beh, \%pr::col, \%pr::gui, \%pr::oth, \%pr::win) {
         foreach my $key (keys %$hash) { 
            $HPVALUE{${$hash}{$key}[NAME]} = $PREFS{${$hash}{$key}[NAME]};
         }
@@ -1074,6 +1973,7 @@ sub new_notebook() {
     $nb->append_page (&new_colours_page, $xl::s{tab_colours});
     $nb->append_page (&new_gui_page, $xl::s{tab_gui});
     $nb->append_page (&new_other_page, $xl::s{tab_other});
+    $nb->append_page (&new_winpos_page, $xl::s{tab_winpos});
 
     return $nb;
 }
@@ -1097,14 +1997,16 @@ GNU General Public License for more details.
 
 You should have received a copy of the GNU General Public License
 along with this program.  If not, see &lt;http://www.gnu.org/licenses/&gt;.";
-    my $year = "2007";
+    my $year = "2007-2009";
     my $holder = "Ricardo Mones &lt;ricardo\@mones.org&gt;";
+    my $url = "http://www.claws-mail.org/clawsker";
 
     my $dialog = Gtk2::MessageDialog->new_with_markup ($parent, 
                     [qw/modal destroy-with-parent/], 
                    'info', 'close', 
                    "<span size=\"x-large\" weight=\"bold\">$title</span>\n"
-                   . "<span size=\"large\">$vers</span>\n"
+                   . "<span size=\"large\">$vers</span>\n\n"
+                   . "<span color=\"blue\" size=\"large\">$url</span>\n\n"
                    . "<span>Copyright $year by $holder</span>\n\n"
                    . "<span size=\"large\">$lic</span>\n\n"
                    . "<span size=\"small\">$license</span>");