fixed help \
[spider.git] / cmd / help.pl
1
2 # the help subsystem
3 #
4 # It is a very simple system in that you type in 'help <cmd>' and it
5 # looks for a file called command.hlp in either the local_cmd directory
6 # or the cmd directory (in that order). 
7 #
8 # Copyright (c) 1998 - Dirk Koopman G1TLH
9 #
10 # $Id$
11 #
12
13 my ($self, $line) = @_;
14 my @out;
15
16 # this is naff but it will work for now
17 my $lang = $self->lang;
18 $lang = 'en' if !$lang;
19
20 # each help file contains lines that looks like:-
21 #
22 # === 0^EN^*^Description
23 # text
24 # text
25 #
26 # === 0^EN^help^Description
27 # text
28 # text
29 # text 
30 #
31 # The fields are:- privilege level, Language, full command name, short description
32 #
33
34 my $h = new IO::File;
35
36 if (!open($h, "$main::localcmd/Commands_$lang.hlp")) {
37         if (!open($h, "$main::cmd/Commands_$lang.hlp")) {
38                 return (1, $self->msg('helpe1'));
39         }
40 }
41 my $in;
42
43 $line =~ s/[^\w\/]//g;
44 $line =~ s/\//\.\*\//g;
45 $line =~ s/^\s+//g;
46 $line =~ s/\s+$//g;
47 $line = "help" if $line =~ /^\s*$/;
48
49 # sort out aliases
50 my $alias = CmdAlias::get_hlp($line);
51 $line = $alias if $alias;
52
53 my $state = 0;
54 foreach $in (<$h>) {
55         next if $in =~ /^\#/;
56         chomp $in;
57         if ($in =~ /^===/) {
58             last if $state == 2;           # come out on next command
59                 $in =~ s/=== //;
60                 my ($priv, $cmd, $desc) = split /\^/, $in;
61                 next if $priv > $self->priv;             # ignore subcommands that are of no concern
62                 next unless $cmd =~ /^$line/i;
63                 push @out, "$cmd $desc" unless $cmd =~ /-$/o;
64                 $state = 1;
65                 next;
66         }
67         if ($state > 0) {
68             push @out, " $in";
69                 $state = 2;
70         }
71 }
72
73 close($h);
74
75 push @out, $self->msg('helpe2', $line) if @out == 0;
76
77 return (1, @out);
78