Improve M$ Windows compatibility
[spider.git] / cmd / show / talk.pl
index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..4adeb7261355b3411c40f677b7ec14feed5c8aa0 100644 (file)
@@ -0,0 +1,42 @@
+#
+# print out the general log file for talks only
+#
+# Copyright (c) 1998 - Dirk Koopman G1TLH
+#
+#
+#
+my $self = shift;
+
+my $cmdline = shift;
+my @f = split /\s+/, $cmdline;
+my $f;
+my @out;
+my ($from, $to, $who); 
+
+$from = 0;
+while ($f = shift @f) {                 # next field
+       #  print "f: $f list: ", join(',', @list), "\n";
+       if (!$from && !$to) {
+               ($from, $to) = $f =~ /^(\d+)-(\d+)$/o;         # is it a from -> to count?
+               next if $from && $to > $from;
+       }
+       if (!$to) {
+               ($to) = $f =~ /^(\d+)$/o if !$to;              # is it a to count?
+               next if $to;
+       }
+       next if $who;
+       if ($f !~ /^\d+/) {
+               ($who) = $f;
+       }
+#      ($who) = $f =~ /^(\w+)/o;
+}
+
+$to = 20 unless $to;
+$from = 0 unless $from;
+if ($self->priv < 6) {
+       $who = $self->call unless $who;
+       return (1, $self->msg('e5')) if $who ne $self->call;
+}
+
+return (1, DXLog::print($from, $to, $main::systime, 'talk', $who)) if ($self->{_nospawn} || $main::is_win == 1);
+return (1, $self->spawn_cmd("show/talk $cmdline", \&DXLog::print, args => [$from, $to, $main::systime, 'talk', $who]));