Change log for psh - The Perl SHell
A reverse-chronological ordered list of changes
Applied patch from rafalka: http://sourceforge.net/support/tracker.php?aid=1635389 to fix path behavior on Windows.
Removed module-specific VERSION variables (some were based on their CVS revision numbers.
Incremented version so $Psh::VERSION > 1.67, which was the version for that module in the 0.009 release (because at that time, version was set according to the CVS revision, rather than to match the release). This should (finally) make CPAN happy.
Put VERSION back in Psh.pm instead of in the main psh script.
Some copyright updates.
The new if builtin allows mixing evaluation strategies. Example:
if ( -r 'README' ) { if ( grep -q "Perl Shell" README ) { print "OK\n"; } }
New forfile builtin:
forfile *.txt less $_
is equivalent to
for i in *; do less $i; done
in (ba)sh
New redirection and piping syntax - incompatible to the old sh-like syntax. The new syntax is allowing many nice things like redirecting to opened Perl filehandles ( command >[=FILEHANDLE])
Perl shell now integrates with Perl backticks, you you can finally do things like:
$foo=`help strategy` chomp $foo if ( $foo =~ /.../ ) ...
New -F command line switch to disable processing of any pshrc files
New default strategy perl - send everything after 'p!' unparsed to the perl interpreter (might be used later on for a special rc file compiler)
New strategy darwin_apps - tries to locate Darwin/Mac OS X Appbundle programs and execute them.
Alias expansion is escapable using backslash: alias ls='ls --color' \ls
The sequence ESC-h is now per default bound to the new readline function "run-help" which will display any help about the current input line it can find. (works only in Term::ReadLine::Gnu)
It's now possible to bind simple commands with && and || like in a normal shell.
&&
||
Global precommand modifiers: You can put noglob, noalias, noexpand in front of any command to disable the specified expansion or all of them.
Prompt themes - see the theme builtin.
Completion modules - allows large sets of predefined completion rules without loading them all at startup time - see the complete builtin.
modules
ulimit
printenv
hash
rehash
jobs has new flags -rsp
fc has protection against endless loops and a more sensible range parsing
which largely extended with flags -mrav
package for switching Perl namespace
Added a sudo builtin which adds some capabilities to the sudo command. (Michael Graham)
Major startup speedup
There was a small, not very often occurring bug related to the usage of Env::Array, due to a typo
Handling of ~ for username expansion should be bug-free now
The help builtin sometimes returned the wrong help (e.g. help set returned the help of setenv)
help set
The parser parsed '&&' as if the user entered '& &&'.
@_ and $_ are saved between input lines.
@_
$_
If you're redirecting perl code, a new fork will be created. You'll therefore lose all variable changes etc. in redirected perl code. That's not as bad as it seems, as before the change, psh segfaulted most of the time you tried redirecting perl code.
Completion was a improved a bit - completions of filenames like "foo\ bar" (where backslash is used to escape whitespace) works a little bit better now. A complete rewrite of Completion is currently scheduled for 0.11
The package Psh::Job is now in the same file with Psh::Joblist. Psh::Job stays an object while Psh::Joblist was converted to a procedural interface as there was no need for OO here.
The package Psh::Locale::Base was renamed to Psh::Locale, so the Psh::Locale:: tree now only contains valid locales.
Many configuration variables have been removed. Please see README.upgrade and the new option builtin. Tieable options by Michael Graham.
Switch to new evaluation strategies system. Please also see README.upgrade
The builtin pshtokenize was removed as it duplicated code from the debug strategy.
The builtin which more conforms to the 'standard' which - it will only locate an executable by default. Strategy debug is similar to the old function of which. which knows some toggles tough for more advanced searches.
The comment strategy was removed. Comments are now already recognized and ignored by the parser.
A limited version of the perlfunc strategy is now loaded by default. The old strategy perlfunc was renamed to perlfunc_heavy.
New builtin rename - this does the same as Larry Wall's PPT program but profits from being integrated into psh (it can use psh subs and variables for the modification). - warp [2000-05-01]
Psh::OS::backtick() now can call and capture the output of psh builtins on Unix. - warp [2000-05-01]
Psh::OS::backtick()
Added new builtin fc which is similar to the command of the same name from bash - inspired by a comment on the SourceForge message board (and I finally start to like this command ;-). - warp [2000-05-03]
The builtin history now also accepts a text as argument. In that case it will only print commands containing that text. - warp [2000-07-08]
The builtin fc now understands the switch -p. Also it's more behaviour compatible with bash's fc.
-p
New builtin bind which does keybindings (similar to bash). - Andrew Turner [2000-08-11]
New builtin drives which shows the available drives on Windows. - warp [2000-08-26]
New sub Psh::Util::prompt() for interactive prompting. - warp [2000-05-01]
Psh::Util::prompt()
Cleanups in Psh::OS::Unix::_setup_redirects and ...::_remove_redirects. - warp [2000-05-01]
Psh::OS::Unix::_setup_redirects
...::_remove_redirects
Added Psh::add_history so builtins etc. can modify history easily. - warp [2000-07-08]
Psh::add_history
Quotes are removed from file names in redirections. - warp [2000-07-08]
Fixed variable substitution in Psh::PerlEval so that whitespace after a backslash does not split words anymore. - warp [2000-07-08]
Psh::PerlEval
Half-hearted attempt at getting whitespace and special characters in TAB completion right. - warp [2000-07-08]
Psh::OS::exit renamed to Psh::OS::exit_psh due to problems with POSIX's exit. - warp [2000-08-26]
Psh::OS::exit
Psh::OS::exit_psh
Removed/reduced usage of Cwd.pm due to partly strange behaviour on non-UNIX systems. - warp [2000-08-26]
The help builtin cleans up the temp files it creates. - warp [2000-08-26]
The parser now allows usage of ->. - warp [2000-07-27]
Should work on Perl 5.004 again. - warp [2000-07-31]
Windows port works and tested on ActiveState Perl 5.6. - warp [2000-08-26]
Removed some errors and problems with Windows in prompt package. - warp [2000-07-31]
The cd builtin now has a (currently unlimited) history list, accessible using:
cd -/+/%number
The new builtin dirs displays the stack.
Adds a mightier and bash compatible way to define custom completions.
A firsttime user setup utility for the .pshrc file. It cannot do a lot currently but will grow in future.
Tries to emulate bash's behaviour.
Does not remove builtins of the same name anymore.
Extended Completion code for Perl (supports $#foo, $foo->{key, $foo->method, subroutine without &, perl reserved symbol)
$#foo
$foo->{key
$foo->method
&
Executable completion now even after initial ! for shell escape
!
Some minimal status code testing and error handling for user input.
Understands environment variable $IGNOREEOF.
$IGNOREEOF
Accepts the -i command line switch and ignores it for bash compatibility.
If the line you entered matches the last line it won't be added to the history.
On Unix, support for a global .pshrc file at /etc/pshrc.
New variable @Psh::executable_noexpand.
@Psh::executable_noexpand
New variable $Psh::interactive which is set if psh is currently in interactive mode.
$Psh::interactive
Fixed some small problems with globbing code.
Fixed problem with pod2man and CHANGES.pod reported on Sourceforge.
SIGTERM and SIGHUP are not ignored anymore and cause psh to exit instead.
SIGTERM
SIGHUP
Switch -r now reserved for restricted mode, new switch -f for alternative resource file.
Fixed problem with quoting which was not removed for the executable strategy.
Piping is now possible in aliases.
The parser now allows nesting aliases.
Contributions primarily by Markus Peter (warp) and Simon Huggins (huggie).
warp
huggie
Support for window titles. New environment variable $PSH_TITLE, $Psh::change_title, $Psh::window_title. The behavior is like prompt strings.
$PSH_TITLE
$Psh::change_title
$Psh::window_title
Strategy perlfunc is a default strategy again. $Psh::perlfunc_builtins determines wether Perl builtins should be evaled (default 0)
$Psh::perlfunc_builtins
eval
Builtin kill now supports sending a signal to a named job (e.g. "emacs & ; kill emacs").
emacs & ; kill emacs
Builtin strategy for loading strategies on demand and adding them to the list of strategies to use. Handy for strategies that are used less often than the core strategies.
Properly pipeable aliases.
Fallback and most other builtins are loaded on demand.
Converted &Psh::symbols() into a builtin, symbols.
&Psh::symbols()
New builtin set. Acts like bash's set and returns environment. Could be extended to allow set -o noclobber bash-isms to work.
set -o noclobber
New strategy auto_cd.
auto_cd
Builtin strategy now knows command available to list available strategies
The Unix resize handler now works correctly in big xterms.
Added print "\n" on CTRL-C to clean up display.
print "\n"
Fixed generation of $Psh::history_file.
$Psh::history_file
Added README.perl5.004 to explain about File::Spec
File::Spec
Strategies fallback_builtin and perlfunc modularized and moved into Psh::Strategy::*
fallback_builtin
perlfunc
Psh::Strategy::*
Perlfunc configuration variables are now in Psh::Strategy::Perlfunc for cleanliness.
Perlfunc
Psh::Strategy::Perlfunc
Removed &Psh::news() since there's no need for it being included in psh just for the tryme script.
&Psh::news()
List of builtins for which autoloading is supported is built automatically during startup.
Refinements to 0.005.
New Features:
New builtin delenv.
Builtin kill accepts multiple PIDs.
Saving the history file now respects $Psh::history_size if Term::ReadLine::Perl is used
$Psh::history_size
Term::ReadLine::Perl
Manifest Filters for pipeline code, e.g. try:
ls | s/y/k/ # Substitution. Example is a Y2K fix. ls | { print ++$i, ": $_"; }q # Quick. Iterate over lines. netstat | { $_[1]>2; }g # Grepish. Print line if { ... } evaluates to true.
See the psh documentation for more information.
New recursive globbing using **/ (Example: grep anything **/*.pm).
**/
grep anything **/*.pm
Win32 Port Enhancements:
It now works. 0.005 was missing a couple of patches.
Makes use of system registry.
Implementations of execute_complex_command(), get_hostname(), get_all_users(), get_home_dir(), and get_known_hosts().
execute_complex_command()
get_hostname()
get_all_users()
get_home_dir()
get_known_hosts()
Internals:
Moved prompt code and perl evaluation code into own packages.
Implementing redirects and pipes in psh.
Clean-ups for all code using filenames (now using File::Spec).
More I18N.
Removed usage of $ENV{HOME} in portable code.
$ENV{HOME}
A very functional release.
brace
Builtins of this type (currently searched in package Psh::Builtins::Fallback) will be executed AFTER no program of that name was found. This allows simulation of common commands like ls and env on systems not having such binaries.
Psh::Builtins::Fallback
auto_resume
builtin
env
On systems with an env binary installed it will use the binary, on other systems (namely Win32) it will print a list of environment variables.
help
unalias
alias
Changed builtin alias so that 'alias name' displays the alias definition for that name.
alias name
bg
It's now possible to do 'bg commandname' (e.g. 'bg emacs') fg has the same behaviour for consistency.
bg commandname
bg emacs
cd
Respects CDPATH now and sets OLDPWD.
CDPATH
OLDPWD
Added portability infrastructure.
Working Win32 port (though it has limited features).
Variables for bookmark completion are now @Psh::Completion::bookmarks and @Psh::Completion::netprograms.
@Psh::Completion::bookmarks
@Psh::Completion::netprograms
New Perl Hashkey completion will TAB complete the name of keys for Perl hashes (if they are not written in quotes).
Support for user defined completions by %Psh::Completion::custom_completions.
%Psh::Completion::custom_completions
Perl Symbol completion now supports package names and package name completion.
Support for TAB completions for builtins.
A custom_completions entry may now also be code. If the value of a custom_completions key/value pair is a sub that sub will be called and the result used as rules.
custom_completions
sub
A rule for custom_completions may now have an optional third argument. If that argument is true, the custom_completion will replace the standard completions instead of adding to them.
custom_completion
Filename Completion respects the FIGNORE environment variable now.
FIGNORE
Documentation updates.
Locales defined for: Default (English), French, German, Italian, Portuguese, and Spanish.
New fallback builtins: ls
Prompt evaluation is now more bash compatible and handles even more complex prompts.
Replaced Psh::OS::Unix::glob() - now uses its own glob routine instead of CORE::glob() - and is significantly faster (important for executable completion).
Psh::OS::Unix::glob()
CORE::glob()
New variables: $Psh::Prompt_cont, $Psh::result_array.
$Psh::Prompt_cont
$Psh::result_array
Moved almost all code from psh into Psh, Psh::Builtins and Psh::Util.
psh
Psh
Psh::Builtins
Psh::Util
Environment variable CURRENT_SHELL is set to the path to psh.
CURRENT_SHELL
Generation of weekday names.
Small fixes for setenv, print_list and abs_path.
Fixed signal description generation.
This release fixes bugs, refactors the code, and adds the following features:
Background process management much more like bash.
Perl code in addition to executables may be put in the background.
Pipelines.
Initial internationalization.
New built-ins: alias, export, setenv.
export
setenv
A flexible set of evaluation strategies that can be selected or reordered by setting a configuration variable.
Prompt strings can have escapes like \07 (ASCII BEL) or \10 (ASCII LF).
\07
BEL
\10
LF
avoided trying to save history if there wasn't even a ReadLine module.
ReadLine
added $psh::debugging variable to hold the debugging state, so it can be turned on and off in a running psh.
$psh::debugging
A $psh::echo variable to control whether perl results of evaluation are printed.
$psh::echo
The which builtin now shows which strategy will apply to a given command line
which
Grab more input automatically if <<BLOCK appears anywhere on the line, or if the line ends with an open brace.
<<BLOCK
results of &psh::which() searches are hashed.
&psh::which()
Thorough documentation of every user-accessible variable and function
Contributions from Markus Peter:
Rudimentary background jobs handling and job management.
Signal handling.
Filename completion.
Updates to history handling.
Flexible %built_ins mechanism for adding built-in functions.
%built_ins
Smart mode is on by default.
Changed prompting to pass prompt string into &iget(), which passes it on to &Term::ReadLine::readline() or prints it out if the ReadLine module is not available. Thanks to Sam Tregar and tmb at lumo.com.
&iget()
&Term::ReadLine::readline()
Changed history handling so that empty lines and those consisting of entirely whitespace are not recorded.
Fixed a couple of typos.
Changed the regular expression for `smart mode' to allow vi +3 psh in addition to ls -l.
vi +3 psh
ls -l
Now uses Getopt::Std for option processing.
Getopt::Std
Fixed the code that detects the presence of Term::ReadLine.
Term::ReadLine
Made more use of debug mode to print out advisory information.
Use zero instead of undef to set Term::ReadLine::MinLine so that we don't get undef usage trouble in the guts of Term::ReadLine::Gnu.
undef
Term::ReadLine::MinLine
Term::ReadLine::Gnu
Added a bunch of stuff to the TODO file.
TODO
Added parens around each part of the $interactive detection expression.
$interactive
Prompt variables are now dealt with via %prompt_vars, which can be modified, so that custom prompt variables can be created.
%prompt_vars
Added %built_ins.
Fixed typo that caused a bug where prompt variable $ didn't work. Thanks to John Labovitz.
$
Patch.
Second release.
Initial release
To install Psh, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Psh
CPAN shell
perl -MCPAN -e shell install Psh
For more information on module installation, please visit the detailed CPAN module installation guide.