1Term::Shell(3pm)      User Contributed Perl Documentation     Term::Shell(3pm)
2
3
4

NAME

6       Term::Shell - A simple command-line shell framework.
7

VERSION

9       version 0.13
10

SYNOPSIS

12           package MyShell;
13           use base qw(Term::Shell);
14
15           sub run_command1  { print "command 1!\n"; }
16           sub smry_command1 { "what does command1 do?" }
17           sub help_command1 {
18               <<'END';
19           Help on 'command1', whatever that may be...
20           END
21           }
22
23           sub run_command2 { print "command 2!\n"; }
24
25           package main;
26           my $shell = MyShell->new;
27           $shell->cmdloop;
28

DESCRIPTION

30       Term::Shell lets you write simple command-line shells. All the boring
31       details like command-line parsing, terminal handling, and tab
32       completion are handled for you.
33
34       The base class comes with two commands pre-defined: exit and help.
35
36       To write a shell with an "exec" command, do something like this:
37
38          package MyShell;
39          use base qw(Term::Shell); # or manually edit @MyShell::ISA.
40
41          sub run_exec {
42              my ($o, $cmd, @args) = @_;
43              if ($cmd ne $0) {
44                  print "I'm sorry you're leaving us...\n";
45              }
46              exec $cmd, @args;
47              exit 1;
48          }
49
50       When Term::Shell needs to handle the "exec" command, it will invoke
51       this method. That's all there is to it! You write handlers, and
52       Term::Shell handles the gory details.
53

Using Term::Shell Shells

55       How do you bring your shell to life? Assuming the package "MyShell"
56       contains your actions, just do this:
57
58          use MyShell;
59          my $shell = MyShell->new;
60
61          # Setup code here (if you wish)
62
63          # Invoke the shell
64          $shell->cmdloop;
65
66          # Cleanup code here (if you wish)
67
68       Most people put the setup code in the shell itself, so you can usually
69       get away with this:
70
71          use MyShell;
72          MyShell->new->cmdloop;
73
74       It's that simple! All the actions and command handlers go in
75       "MyShell.pm", and your main program is simple. In fact, it's so simple
76       that some people like to write both the actions and the invocation in
77       the same file:
78
79          package main;
80          MyShell->new->cmdloop;
81
82          package MyShell;
83          use base qw(Term::Shell);
84
85          # Actions here
86
87       Adding commands to your shell is just as easy, if not easier.
88

Adding Commands to Your Shell

90       For every command "foo", Term::Shell needs a method called run_foo(),
91       where 'foo' is what the user will type in. The method will be called
92       with the Term::Shell object as the first parameter, followed by any
93       arguments the user typed after the command.
94
95       Several prefixes other than "run_" are supported; each prefix tells
96       Term::Shell to call that handler under different circumstances. The
97       following list enumerates all the "special" prefixes. Term::Shell will
98       ignore any method that doesn't start with a prefix listed here.
99
100       1.  run_foo()
101
102           Adds the command "foo" to the list of supported commands. The
103           method's return value is saved by Term::Shell, but is not used.
104
105           The method is called with the Term::Shell object as its first
106           argument, followed by any arguments the user typed in.
107
108           Special case: if you provide a method run_(), Term::Shell will call
109           it whenever the user enters a blank line. A blank line is anything
110           which matches the regular expression "/^\s*$/".
111
112       2.  help_foo()
113
114           Adds the command "foo" to the list of help topics. This means the
115           user may enter 'help foo' and get a help screen. It should return a
116           single string to be displayed to the user.
117
118           The method is called with the Term::Shell object as its first
119           argument, followed by any arguments the user typed in after 'help
120           foo'. You can implement hierarchical help documents by using the
121           arguments.
122
123           If you do not provide a help_foo() method, typing 'help foo'
124           produces an error message.
125
126       3.  smry_foo()
127
128           Should return a one-line summary of "foo", to be displayed in the
129           help screen.
130
131           This method is called with the Term::Shell object as its first
132           argument, and no other arguments.
133
134           If you do not provide a smry_foo() method, then the string
135           'undocumented' is used instead.
136
137       4.  comp_foo()
138
139           Provides custom tab-completion for "foo". That means if the user
140           types 'foo ' and then hits <TAB>, this method will be called. It
141           should return an array reference containing a list of possible
142           completions.
143
144           This method is called with the Term::Shell object as its first
145           argument, followed by the three arguments:
146
147           1.  $word
148
149               The word the user is trying to complete.
150
151           2.  $line
152
153               The line as typed by the user so far.
154
155           3.  $start
156
157               The offset into $line where $word starts.
158
159           If you do not provide comp_foo(), Term::Shell will always return no
160           completions for "foo".
161
162           Special case: if you provide comp_(), Term::Shell will call it when
163           the user is trying to complete the name of a command. Term::Shell
164           provides a default comp_() method, which completes the actions that
165           you have written handlers for. If you want to provide tab-
166           completion for commands that do not have handlers, override
167           comp_().
168
169       5.  alias_foo()
170
171           Returns a list of aliases for "foo". When one of the aliases is
172           used instead of "foo", the corresponding handler for "foo" is
173           called.
174
175       6.  catch_run()
176
177           catch_help()
178
179           catch_comp()
180
181           catch_smry()
182
183           Called when an undefined action is entered by the user. Normally
184           when the user enters an unrecognized command, Term::Shell will
185           print an error message and continue.
186
187           This method is called with the Term::Shell object, the command
188           typed by the user, and then the arguments which would normally be
189           passed to the real handler.
190
191           The "catch_" methods may do anything the original function would
192           have done.  If you want, you can implement all the commands in it,
193           but that means you're doing more work than you have to. Be lazy.
194
195   When you want something done right...
196       You sometimes have to do it yourself. Introducing add_handlers().
197       Naturally, it adds a handler to the list of defined handlers in the
198       shell.
199
200       Term::Shell can't always find the commands you want to implement by
201       searching the inheritance tree. Having an AUTOLOAD() method, for
202       instance, will break this system. In that situation, you may wish to
203       tell Term::Shell about the extra commands available using
204       add_handlers():
205
206          package MyShell;
207          use base qw(Term::Shell);
208
209          sub AUTOLOAD {
210              if ($AUTOLOAD =~ /::run_fuzz$/) {
211                  # code for 'fuzz' command
212              }
213              elsif ($AUTOLOAD =~ /::run_foozle$/) {
214                  # code for 'foozle' command
215              }
216          }
217
218          sub init {
219              my $o = shift;
220              $o->add_handlers("run_fuzz", "run_foozle");
221          }
222
223       There are other ways to do this. You could write a "catch_run" routine
224       and do the same thing from there. You'd have to override "comp_" so
225       that it would complete on "foozle" and "fuzz". The advantage to this
226       method is that it adds the methods to the list of commands, so they
227       show up in the help menu and you get completion for free.
228

Removing Commands from Your Shell

230       You're probably thinking "just don't write them". But remember, you can
231       inherit from another shell class, and that parent may define commands
232       you want to disable. Term::Shell provides a simple method to make
233       itself forget about commands it already knows about:
234
235       1.  remove_commands()
236
237           Removes all handlers associated with the given command (or list of
238           commands).
239
240           For example, Term::Shell comes with two commands ("exit" and
241           "help") implemented with seven handlers:
242
243           1.  smry_exit()
244
245           2.  help_exit()
246
247           3.  run_exit()
248
249           4.  smry_help()
250
251           5.  help_help()
252
253           6.  comp_help()
254
255           7.  run_help()
256
257           If you want to create a shell that doesn't implement the "help"
258           command, your code might look something like this example:
259
260              package MyShell;
261              use base qw(Term::Shell);
262
263              sub init {
264                  my $o = shift;
265                  $o->remove_commands("help");
266              }
267
268              # ... define more handlers here ...
269
270       2.  remove_handlers()
271
272           Removes the given handler (or handlers) from the list of defined
273           commands. You have to specify a full handler name, including the
274           'run_' prefix. You can obviously specify any of the other prefixes
275           too.
276
277           If you wanted to remove the help for the "exit" command, but
278           preserve the command itself, your code might look something like
279           this:
280
281              package MyShell;
282              use base qw(Term::Shell);
283
284              sub init {
285                  my $o = shift;
286                  $o->remove_handlers("help_exit");
287              }
288
289              # ... define more handlers here ...
290
291   Cover Your Tracks
292       If you do remove built in commands, you should be careful not to let
293       Term::Shell print references to them. Messages like this are guaranteed
294       to confuse people who use your shell:
295
296          shell> help
297          Unknown command 'help'; type 'help' for a list of commands.
298
299       Here's the innocuous looking code:
300
301          package MyShell;
302          use base qw(Term::Shell);
303
304          sub init {
305              my $o = shift;
306              $o->remove_commands("help");
307          }
308
309          MyShell->new->cmdloop;
310
311       The problem is that Term::Shell has to print an error message, and by
312       default it tells the user to use the "help" command to see what's
313       available. If you remove the "help" command, you still have to clean up
314       after yourself and tell Term::Shell to change its error messages:
315
316       1.  msg_unknown_cmd()
317
318           Called when the user has entered an unrecognized command, and no
319           action was available to satisfy it. It receives the object and the
320           command typed by the user as its arguments. It should return an
321           error message; by default, it is defined thusly:
322
323              sub msg_unknown_cmd {
324                  my ($o, $cmd) = @_;
325                  <<END;
326              Unknown command '$cmd'; type 'help' for a list of commands.
327              END
328              }
329
330       2.  msg_ambiguous_cmd()
331
332           Called when the user has entered a command for which more than
333           handler exists.  (For example, if both "quit" and "query" are
334           commands, then "qu" is an ambiguous command, because it could be
335           either.) It receives the object, the command, and the possible
336           commands which could complete it. It should return an error
337           message; by default it is defined thusly:
338
339              sub msg_ambiguous_cmd {
340                  my ($o, $cmd, @c) = @_;
341                  local $" = "\n\t";
342                  <<END;
343              Ambiguous command '$cmd': possible commands:
344                      @c
345              END
346              }
347

The Term::Shell API

349       Shell classes can use any of the methods in this list. Any other
350       methods in Term::Shell may change.
351
352       1.  new()
353
354           Creates a new Term::Shell object. It currently does not use its
355           arguments. The arguments are saved in '$o->{API}{args}', in case
356           you want to use them later.
357
358              my $sh = Term::Shell->new(@arbitrary_args);
359
360       2.  cmd()
361
362              cmd($txt);
363
364           Invokes $txt as if it had been typed in at the prompt.
365
366              $sh->cmd("echo 1 2 3");
367
368       3.  cmdloop()
369
370           mainloop()
371
372           Repeatedly prompts the user, reads a line, parses it, and invokes a
373           handler.  Uses cmd() internally.
374
375              MyShell->new->cmdloop;
376
377           mainloop() is a synonym for cmdloop(), provided for backwards
378           compatibility.  Earlier (unreleased) versions of Term::Shell have
379           only provided mainloop().  All documentation and examples use
380           cmdloop() instead.
381
382       4.  init()
383
384           fini()
385
386           Do any initialization or cleanup you need at shell creation
387           (init()) and destruction (fini()) by defining these methods.
388
389           No parameters are passed.
390
391       5.  preloop()
392
393           postloop()
394
395           Do any initialization or cleanup you need at shell startup
396           (preloop()) and shutdown (postloop()) by defining these methods.
397
398           No parameters are passed.
399
400       6.  precmd()
401
402           postcmd()
403
404           Do any initialization or cleanup before and after calling each
405           handler.
406
407           The parameters are:
408
409           1.  $handler
410
411               A reference to the name of the handler that is about to be
412               executed.
413
414               Passed by reference so you can control which handler will be
415               called.
416
417           2.  $cmd
418
419               A reference to the command as the user typed it.
420
421               Passed by reference so you can set the command. (If the handler
422               is a "catch_" command, it can be fooled into thinking the user
423               typed some other command, for example.)
424
425           3.  $args
426
427               The arguments as typed by the user. This is passed as an array
428               reference so that you can manipulate the arguments received by
429               the handler.
430
431              sub precmd {
432                  my $o = shift;
433                  my ($handler, $cmd, @args) = @_;
434                  # ...
435              }
436
437       7.  stoploop()
438
439           Sets a flag in the Term::Shell object that breaks out of cmdloop().
440           Note that cmdloop() resets this flag each time you call it, so code
441           like this will work:
442
443              my $sh = MyShell->new;
444              $sh->cmdloop;    # an interactive session
445              $sh->cmdloop;    # prompts the user again
446
447           Term::Shell's built-in run_exit() command just calls stoploop().
448
449       8.  idle()
450
451           If you set "check_idle" to a non-zero number (see "The Term::Shell
452           Object") then this method is called every "check_idle" seconds. The
453           idle() method defined in Term::Shell does nothing -- it exists only
454           to be redefined in subclasses.
455
456              package MyShell;
457              use base qw(Term::Shell);
458
459              sub init {
460                  my $o = shift;
461                  $o->{API}{check_idle} = 0.1; # 10/s
462              }
463
464              sub idle {
465                  print "Idle!\n";
466              }
467
468       9.  prompt_str()
469
470           Returns a string to be used as the prompt. prompt_str() is called
471           just before calling the readline() method of Term::ReadLine. If you
472           do not override this method, the string `shell> ' is used.
473
474              package MyShell;
475              use base qw(Term::Shell);
476
477              sub prompt_str { "search> " }
478
479       10. prompt()
480
481           Term::Shell provides this method for convenience. It's common for a
482           handler to ask the user for more information. This method makes it
483           easy to provide the user with a different prompt and custom
484           completions provided by you.
485
486           The prompt() method takes the following parameters:
487
488           1.  $prompt
489
490               The prompt to display to the user. This can be any string you
491               want.
492
493           2.  $default
494
495               The default value to provide. If the user enters a blank line
496               (all whitespace characters) then the this value will be
497               returned.
498
499               Note: unlike ExtUtils::MakeMaker's prompt(), Term::Shell's
500               prompt() does not modify $prompt to indicate the $default
501               response. You have to do that yourself.
502
503           3.  $completions
504
505               An optional list of completion values. When the user hits
506               <TAB>, Term::Shell prints the completions which match what
507               they've typed so far. Term::Shell does not enforce that the
508               user's response is one of these values.
509
510           4.  $casei
511
512               An optional boolean value which indicates whether the
513               completions should be matched case-insensitively or not. A true
514               value indicates that "FoO" and "foo" should be considered the
515               same.
516
517           prompt() returns the unparsed line to give you maximum flexibility.
518           If you need the line parsed, use the line_parsed() method on the
519           return value.
520
521       11. cmd_prefix()
522
523           cmd_suffix()
524
525           These methods should return a prefix and suffix for commands,
526           respectively.  For instance, an IRC client will have a prefix of
527           "/". Most shells have an empty prefix and suffix.
528
529       12. page()
530
531              page($txt)
532
533           Prints $txt through a pager, prompting the user to press a key for
534           the next screen full of text.
535
536       13. line()
537
538           line_parsed()
539
540           Although run_foo() is called with the parsed arguments from the
541           command-line, you may wish to see the raw command-line. This is
542           available through the line() method. If you want to retrieve the
543           parsed line again, use line_parsed().
544
545           line_parsed() accepts an optional string parameter: the line to
546           parse. If you have your own line to parse, you can pass it to
547           line_parsed() and get back a list of arguments. This is useful
548           inside completion methods, since you don't get a parsed list there.
549
550       14. run()
551
552           If you want to run another handler from within a handler, and you
553           have pre-parsed arguments, use run() instead of cmd(). cmd() parses
554           its parameter, whereas run() takes each element as a separate
555           parameter.
556
557           It needs the name of the action to run and any arguments to pass to
558           the handler.
559
560           Term::Shell uses this method internally to invoke command handlers.
561
562       15. help()
563
564           If you want to get the raw text of a help message, use help(). It
565           needs the name of the help topic and any arguments to pass to the
566           handler.
567
568           Term::Shell uses this method internally to invoke help handlers.
569
570       16. summary()
571
572           If you want to get the summary text of an action, use summary(). It
573           needs the name of the action.
574
575           Term::Shell uses this method internally to display the help page.
576
577       17. possible_actions()
578
579           You will probably want this method in comp_foo().
580           possible_actions() takes a word and a list, and returns a list of
581           possible matches. Term::Shell uses this method internally to decide
582           which handler to run when the user enters a command.
583
584           There are several arguments, but you probably won't use them all in
585           the simple cases:
586
587           1.  $needle
588
589               The (possible incomplete) word to try to match against the list
590               of actions (the haystack).
591
592           2.  $type
593
594               The type with which to prefix $action. This is useful when
595               completing a real action -- you have to specify whether you
596               want it to look for "run_" or "help_" or something else. If you
597               leave it blank, it will use $action without prefixing it.
598
599           3.  $strip
600
601               If you pass in a true value here, possible_actions() will
602               remove an initial $type from the beginning of each result
603               before returning the results. This is useful if you want to
604               know what the possible "run_" commands are, but you don't want
605               to have the "run_" in the final result.
606
607               If you do not specify this argument, it uses '0' (the default
608               is not to strip the results).
609
610           4.  $haystack
611
612               You can pass in a reference to a list of strings here. Each
613               string will be compared with $needle.
614
615               If you do not specify this argument, it uses the list of
616               handlers. This is how Term::Shell matches commands typed in by
617               the user with command handlers written by you.
618
619       18. print_pairs()
620
621           This overloaded beast is used whenever Term::Shell wants to print a
622           set of keys and values. It handles wrapping long values, indenting
623           the whole thing, inserting the separator between the key and value,
624           and all the rest.
625
626           There are lots of parameters, but most of them are optional:
627
628           1.  $keys
629
630               A reference to a list of keys to print.
631
632           2.  $values
633
634               A reference to a list of values to print.
635
636           3.  $sep
637
638               The string used to separate the keys and values. If omitted, ':
639               ' is used.
640
641           4.  $left
642
643               The justification to be used to line up the keys. If true, the
644               keys will be left-justified. If false or omitted, the keys will
645               be right-justified.
646
647           5.  $ind
648
649               A string used to indent the whole paragraph. Internally,
650               print_pairs() uses length(), so you shouldn't use tabs in the
651               indent string. If omitted, the empty string is used (no
652               indent).
653
654           6.  $len
655
656               An integer which describes the minimum length of the keys.
657               Normally, print_pairs() calculates the longest key and assigns
658               the column width to be as wide as the longest key plus the
659               separator. You can force the column width to be larger using
660               $len. If omitted, 0 is used.
661
662           7.  $wrap
663
664               A boolean which indicates whether the value should be text-
665               wrapped using Text::Autoformat. Text is only ever wrapped if it
666               contains at least one space.  If omitted, 0 is used.
667
668           8.  $cols
669
670               An integer describing the number of columns available on the
671               current terminal.  Normally 78 is used, or the environment
672               variable COLUMNS, but you can override the number here to
673               simulate a right-indent.
674
675       19. term()
676
677           Returns the underlying "Term::ReadLine" object used to interact
678           with the user. You can do powerful things with this object; in
679           particular, you will cripple Term::Shell's completion scheme if you
680           change the completion callback function.
681
682       20. process_esc()
683
684           This method may be overridden to provide shell-like escaping of
685           backslashes inside quoted strings. It accepts two parameters:
686
687           1.  $c
688
689               The character which was escaped by a backslash.
690
691           2.  $quote
692
693               The quote character used to delimit this string. Either """ or
694               "'".
695
696           This method should return the string which should replace the
697           backslash and the escaped character.
698
699           By default, process_esc() uses escaping rules similar to Perl's
700           single-quoted string:
701
702           1.  Escaped backslashes return backslashes. The string "123\\456"
703               returns "123\456".
704
705           2.  Escaped quote characters return the quote character (to allow
706               quote characters in strings). The string "abc\"def" returns
707               "abc"def".
708
709           3.  All other backslashes are returned verbatim. The string
710               "123\456" returns "123\456".
711
712           Term::Shell's quote characters cannot be overridden, unless you
713           override line_parsed(): they are """ or "'". This may change in a
714           future version of Term::Shell.
715
716       21. add_handlers()
717
718           See "Adding Commands to Your Shell" for information on
719           add_handlers().
720
721       22. remove_commands()
722
723           remove_handlers()
724
725           See "Removing Commands from Your Shell" for information on
726           remove_handlers().
727

The Term::Shell Object

729       Term::Shell creates a hash based Perl object. The object contains
730       information like what handlers it found, the underlying Term::ReadLine
731       object, and any arguments passed to the constructor.
732
733       This hash is broken into several subhashes. The only two subhashes that
734       a Shell should ever use are $o->{API} and $o->{SHELL}. The first one
735       contains all the information that Term::Shell has gathered for you. The
736       second one is a private area where your Shell can freely store data
737       that it might need later on.
738
739       This section will describe all the Term::Shell object "API" attributes:
740
741   The args Attribute
742       This an array reference containing any arguments passed to the
743       Term::Shell constructor.
744
745   The case_ignore Attribute
746       This boolean controls whether commands should be matched without regard
747       to case. If this is true, then typing "FoO" will have the same effect
748       as typing "foo".
749
750       Defaults to true on MSWin32, and false on other platforms.
751
752   The class Attribute
753       The class of the object. This is probably the package containing the
754       definition of your shell, but if someone subclasses your shell, it's
755       their class.
756
757   The command Attribute
758       Whenever Term::Shell invokes an action, it stores information about the
759       action in the "command" attribute. Information about the last "run"
760       action to be invoked is stored in $o->{API}{command}{run}. The
761       information itself is stored in a subhash containing these fields:
762
763       name
764           The name of the command, as typed by the user.
765
766       found
767           The a boolean value indicating whether a handler could be found.
768
769       handler
770           The full name of the handler, if found.
771
772       Note that this facility only stores information about the last action
773       to be executed. It's good enough for retrieving the information about
774       the last handler which ran, but not for much else.
775
776       The following example shows a case where run_foo() calls run_add(), and
777       prints its return value (in this case, 42).
778
779          sub run_foo {
780              my $o = shift;
781              my $sum = $o->run("add", 21, 21);
782              print "21 + 21 = ", $sum, "\n";
783          }
784
785          sub run_add {
786              my $o = shift;
787              my $sum = 0;
788              $sum += $_ for @_;
789              print "add(): sum = $sum\n";
790              return $sum;
791          }
792
793       At the end of run_foo(), $o->{API}{command}{run}{handler} contains the
794       string "run_add".
795
796   The match_uniq Attribute
797       This boolean controls whether the user can type in only enough of the
798       command to make it unambiguous. If true, then if the shell has the
799       commands "foo" and "bar" defined, the user can type "f" to run "foo",
800       and "b" to run "bar".
801
802       Defaults to true.
803
804   The readline Attribute
805       Which Term::ReadLine module is being used. Currently, this is always
806       one of "Term::ReadLine::Stub", "Term::ReadLine::Perl", or
807       "Term::ReadLine::Gnu".
808
809   The script Attribute
810       The name of the script that invoked your shell.
811
812   The version Attribute
813       The version of Term::Shell you are running under.
814

SEE ALSO

816       For more information about the underlying ReadLine module, see
817       Term::ReadLine. You may also want to look at Term::ReadLine::Gnu and
818       Term::ReadLine::Perl.
819
820       For more information about the underlying formatter used by
821       print_pairs(), see Text::Autoformat.
822
823       The API for Term::Shell was inspired by (gasp!) a Python package called
824       "cmd". For more information about this package, please look in the
825       Python Library Reference, either in your Python distribution or at
826       <https://docs.python.org/3/library/cmd.html> .
827

AUTHOR

829       Neil Watkiss (NEILW@cpan.org)
830
832       Copyright (c) 2001, Neil Watkiss. All Rights Reserved.
833
834       All Rights Reserved. This module is free software. It may be used,
835       redistributed and/or modified under the same terms as Perl itself.
836
837       See http://www.perl.com/perl/misc/Artistic.html
838

SUPPORT

840   Websites
841       The following websites have more information about this module, and may
842       be of help to you. As always, in addition to those websites please use
843       your favorite search engine to discover more resources.
844
845       •   MetaCPAN
846
847           A modern, open-source CPAN search engine, useful to view POD in
848           HTML format.
849
850           <https://metacpan.org/release/Term-Shell>
851
852       •   RT: CPAN's Bug Tracker
853
854           The RT ( Request Tracker ) website is the default bug/issue
855           tracking system for CPAN.
856
857           <https://rt.cpan.org/Public/Dist/Display.html?Name=Term-Shell>
858
859       •   CPANTS
860
861           The CPANTS is a website that analyzes the Kwalitee ( code metrics )
862           of a distribution.
863
864           <http://cpants.cpanauthors.org/dist/Term-Shell>
865
866       •   CPAN Testers
867
868           The CPAN Testers is a network of smoke testers who run automated
869           tests on uploaded CPAN distributions.
870
871           <http://www.cpantesters.org/distro/T/Term-Shell>
872
873       •   CPAN Testers Matrix
874
875           The CPAN Testers Matrix is a website that provides a visual
876           overview of the test results for a distribution on various
877           Perls/platforms.
878
879           <http://matrix.cpantesters.org/?dist=Term-Shell>
880
881       •   CPAN Testers Dependencies
882
883           The CPAN Testers Dependencies is a website that shows a chart of
884           the test results of all dependencies for a distribution.
885
886           <http://deps.cpantesters.org/?module=Term::Shell>
887
888   Bugs / Feature Requests
889       Please report any bugs or feature requests by email to "bug-term-shell
890       at rt.cpan.org", or through the web interface at
891       <https://rt.cpan.org/Public/Bug/Report.html?Queue=Term-Shell>. You will
892       be automatically notified of any progress on the request by the system.
893
894   Source Code
895       The code is open to the world, and available for you to hack on. Please
896       feel free to browse it and play with it, or whatever. If you want to
897       contribute patches, please send me a diff or prod me to pull from your
898       repository :)
899
900       <https://github.com/shlomif/Term-Shell>
901
902         git clone git://git@github.com:shlomif/Term-Shell.git
903

AUTHOR

905       Shlomi Fish <shlomif@cpan.org>
906

BUGS

908       Please report any bugs or feature requests on the bugtracker website
909       <http://rt.cpan.org/NoAuth/Bugs.html?Dist=Term-Shell> or by email to
910       bug-term-shell@rt.cpan.org <mailto:bug-term-shell@rt.cpan.org>.
911
912       When submitting a bug or request, please include a test-file or a patch
913       to an existing test-file that illustrates the bug or desired feature.
914
916       This software is copyright (c) 2001 by Neil Watkiss.
917
918       This is free software; you can redistribute it and/or modify it under
919       the same terms as the Perl 5 programming language system itself.
920
921
922
923perl v5.38.0                      2023-07-21                  Term::Shell(3pm)
Impressum