From 789f6481b53542ff939c2dd7746dd702541089a0 Mon Sep 17 00:00:00 2001 From: Tzafrir Cohen Date: Sun, 24 Jan 2010 19:57:40 +0000 Subject: Not all Astribanks have a 'serial' attribute. Make it optional. Originally r7824 from the perl-sysstate branch. git-svn-id: http://svn.asterisk.org/svn/dahdi/tools/trunk@7953 a0bf4364-ded3-4de4-8d8a-66a801d63aff --- xpp/perl_modules/Dahdi/Hardware/USB.pm | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/xpp/perl_modules/Dahdi/Hardware/USB.pm b/xpp/perl_modules/Dahdi/Hardware/USB.pm index 3eb9fe6..dff25ef 100644 --- a/xpp/perl_modules/Dahdi/Hardware/USB.pm +++ b/xpp/perl_modules/Dahdi/Hardware/USB.pm @@ -121,6 +121,15 @@ sub _get_attr($) { return $value; } +sub _get_attr_optional($$) { + my ($attr_file, $def_val) = $@; + + eval {return _get_attr($attr_file)}; + + # If we got here, _get_attr exploded. Return the default value: + return $def_val; +} + sub scan_devices_sysfs($) { my $pack = shift || die; my @devices = (); @@ -137,7 +146,7 @@ sub scan_devices_sysfs($) { my $model = $usb_ids{"$vendor:$product"}; next unless defined $model; my $devnum = _get_attr("$_/devnum"); - my $serial = _get_attr("$_/serial"); + my $serial = _get_attr_optional("$_/serial", ''); my $devname = sprintf("%03d/%03d", $busnum, $devnum); my $d = Dahdi::Hardware::USB->new( IS_ASTRIBANK => ($model->{DRIVER} eq 'xpp_usb')?1:0, -- cgit v1.2.3