#!/bin/sh
-#$Id: snom.pl,v 1.39 2006-05-22 12:27:16 michael Exp $
+#$Id: snom.pl,v 1.44 2006-05-24 14:31:16 michael Exp $
PATH=/opt/csw/bin:/opt/local/bin:/usr/bin:/bin exec perl -w -x "$0" "$@"
use LWP::UserAgent;
my %g_key = ();
+my %g_arrows;
my $g_host = Gtk2::ComboBox->new_text();
my $g_identity = Gtk2::ComboBox->new_text();
my $ua = LWP::UserAgent->new;
$g_host->set_active(0);
UpdatePhoneInfo();
$g_host->signal_connect(changed => \&UpdatePhoneInfo);
-$g_host->show();
+$g_host->show() if($#sections);
$g_identity->signal_connect(changed => \&SwitchIdentity);
-$g_identity->show();
set_locale Gtk2;
my $n = 0;
foreach my $key (@$keys) {
if ($key ne '_') {
- $g_key{$key} = Gtk2::Button->new("${key}");
+ if($key=~m/^ARROWS(.*)$/) {
+ $g_key{$key} = Gtk2::Button->new;
+ $g_key{$key}->add($g_arrows{"${1}"});
+ } else {
+ $g_key{$key} = Gtk2::Button->new("${key}");
+ }
$g_key{$key}->signal_connect(clicked => \&KeyPressed, $key);
$table->attach_defaults($g_key{$key}, (($n)%$cols), (($n)%$cols)+1, int(($n)/$cols), int((($n)/$cols)+1));
$g_key{$key}->show();
my $softkeys = gen_table(1, 4, FALSE, 0, 6, ['F1', 'F2', 'F3', 'F4']);
+$g_arrows{up} = Gtk2::Arrow->new('up', 'none');
+$g_arrows{up}->show();
+$g_arrows{down} = Gtk2::Arrow->new('down', 'none');
+$g_arrows{down}->show();
+$g_arrows{left} = Gtk2::Arrow->new('left', 'none');
+$g_arrows{left}->show();
+$g_arrows{right} = Gtk2::Arrow->new('right', 'none');
+$g_arrows{right}->show();
+
my $navi = gen_table(3, 5, FALSE, 0, 0,
- ['_', '_', '^', '_', '_', 'X', '<', '_', '>', 'OK', '_', '_', 'V', '_', '_']);
+ ['_', '_', 'ARROWSup', '_', '_', 'X', 'ARROWSleft', '_', 'ARROWSright', 'OK', '_', '_', 'ARROWSdown', '_', '_']);
my $output = gen_table(2, 3, FALSE, 2, 2, ['-', '+', '_', '_Mute', '_Speaker', '_Headset']);
snom_key("CANCEL") if ( $text eq "X" );
snom_key("ENTER") if ( $text eq "OK" );
- snom_key("UP") if ( $text eq "^" );
- snom_key("DOWN") if ( $text eq "V" );
- snom_key("LEFT") if ( $text eq "<" );
- snom_key("RIGHT") if ( $text eq ">" );
+ snom_key("UP") if ( $text eq "ARROWSup" );
+ snom_key("DOWN") if ( $text eq "ARROWSdown" );
+ snom_key("LEFT") if ( $text eq "ARROWSleft" );
+ snom_key("RIGHT") if ( $text eq "ARROWSright" );
snom_key("F_REC") if ( $text eq "Record" );
snom_key("F_RETRIEVE") if ( $text eq "Retrieve" );
}
}
- if (!$event->state || $event->state eq 'shift-mask') {
+ if (!$event->state || !($event->state & "control-mask" || $event->state & "mod1-mask")) {
if ($keyval == $Gtk2::Gdk::Keysyms{asterisk}) {snom_key('*'); return TRUE;}
if ($keyval == $Gtk2::Gdk::Keysyms{KP_Multiply}) {snom_key('*'); return TRUE;}
if ($keyval == $Gtk2::Gdk::Keysyms{numbersign}) {snom_key('#'); return TRUE;}
}
}
} else {
- if ($event->state eq 'mod1-mask') {
+ if ($event->state & "mod1-mask") {
for (my $i=1; $i<13; $i++) {
if ($keyval == $Gtk2::Gdk::Keysyms{"F${i}"}) {
snom_key("P${i}");
$g_identity->set_active(0);
}
my @lines=split("\n", $response->content());
+ my $num = 0;
foreach (@lines) {
chomp;
#<option value="1" selected>51@stargate.gernoth.loc</option>
#<option value="2">89@asterix.ear-projekt.de</option>
#<option value="3">41@grumpy.gernoth.loc</option>
- if (m/^\<option value=\"(.+)\"( selected)?\>([^<]*)\<\/option\>$/) {
+ if (m/^\<option value=\"(.+)\"( selected)?\>([^<\@]*)\@([^<]*)\<\/option\>$/) {
+ my $line = $3;
$g_identity->append_text("${3}");
$g_identity->set_active(${1}-1) if(defined($2));
+ $num++;
}
}
+ if ($num > 1) {
+ $g_identity->show;
+ } else {
+ $g_identity->hide;
+ }
}
sub SwitchIdentity