X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FDXM.pm;h=b6d191bbd30a03f1c019c8ae35303e226d3ed08a;hb=24550808f9ee4ba5cf6a720bb364977f7ed586af;hp=41c2bbff05e17fb818f3f1b6ce591704082bb5e4;hpb=f46017e7bef9ee062cd5a8648d214eabe585da25;p=spider.git diff --git a/perl/DXM.pm b/perl/DXM.pm index 41c2bbff..b6d191bb 100644 --- a/perl/DXM.pm +++ b/perl/DXM.pm @@ -16,22 +16,56 @@ package DXM; -require Exporter; -@ISA = qw(Exporter); -@EXPORT = qw(msg); +use strict; + +use DXVars; +use DXDebug; -%msgs = ( - l1 => 'Sorry $_[0], you are already logged on on another channel', - l2 => 'Hello $_[0], this is $main::mycall located in $main::myqth', - pr => '$_[0] de $main::mycall $main::cldate $main::ztime >', -); +my $localfn = "$main::root/local/Messages"; +my $fn = "$main::root/perl/Messages"; + +use vars qw($VERSION $BRANCH); +$VERSION = sprintf( "%d.%03d", q$Revision$ =~ /(\d+)\.(\d+)/ ); +$BRANCH = sprintf( "%d.%03d", q$Revision$ =~ /\d+\.\d+\.(\d+)\.(\d+)/ || (0,0)); +$main::build += $VERSION; +$main::branch += $BRANCH; + +use vars qw(%msgs); sub msg { - my $self = shift; - my $s = $msgs{$self}; - return "unknown message '$self'" if !defined $s; + my $lang = shift; + my $m = shift; + my $ref = $msgs{$lang}; + my $s = $ref->{$m} if $ref; + if (!$s && $lang ne 'en') { + $ref = $msgs{'en'}; + $s = $ref->{$m}; + } + return "unknown message '$m' in lang '$lang'" if !defined $s; + my $ans = eval qq{ "$s" }; + warn $@ if $@; + return $ans; +} + +sub load +{ + my $ref = shift; + if (-e $localfn) { + do $localfn; + return ($@) if $@ && ref $ref; + confess $@ if $@; + return (); + } + do $fn; + return ($@) if $@ && ref $ref; + confess $@ if $@; + return (); +} - return eval '"'. $s . '"'; +sub init +{ + load(); } - + +1;