Pico (text editor)

Pico (Pine composer) is a text editor for Unix and Unix-based computer systems. It is integrated with the Pine e-mail client, which was designed by the Office of Computing and Communications at the University of Washington.[1]

Pico
Developer(s)University of Washington
Initial release1989 (1989)
Written inC
Operating systemUnix-like
Available inEnglish
TypeText editor
LicenseApache License
Websitewww.washington.edu/pine/ (Archived 28 March 2019 at the Wayback Machine)

From the Pine FAQ: "Pine's message composition editor is also available as a separate stand-alone program, called PICO. PICO is a very simple and easy-to-use text editor offering paragraph justification, cut/paste, and a spelling checker...".[2]

Pico does not support working with several files simultaneously and cannot perform a find and replace across multiple files. It also cannot copy partial text from one file to another (though it is possible to read text into the editor from a whole file in its working directory). Pico does support search and replace operations.

By comparison, some popular Unix text editors such as vi and Emacs provide a wider range of features than Pico; including regular expression search and replace, and working with multiple files at the same time. By comparison, Pico's simplicity makes it suitable for beginners.[3]

A clone of Pico called nano, which is part of the GNU Project,[4] was developed because Pico's earlier license had unclear redistribution terms.[5] Newer versions of Pico as part of Alpine are released under the Apache License.

Basic commands and navigation

Pico features a number of commands for editing. Arrow keys move the cursor a character at the time in the direction of the movement. Inserting a character is done by pressing the corresponding character key in the keyboard, while giving commands (such as save, spell check, justify, search, etc.) is done using a control key.

The Ctrl+T command is used to spell check. The speller is defined from the command line using the -s option. When a person writes files in different languages, the speller can be set to be a script that interacts with the user to select the language to be spelled.

The Ctrl+J command is used to left justify text. Text is flowed in each line of a paragraph up to a limit set with the -r option in the command line. If no limit is given in the command line, then a default value of 72 characters per line is used. This limit is used to wrap lines during composition, as well as to justify text. The Ctrl+J command justifies the text in the paragraph that the cursor is placed on. The command Ctrl+W Ctrl+U is used to justify the full file. In case that justification is not done correctly, or by mistake, it can be undone by pressing the Ctrl+U command immediately after justification has been done.

The Ctrl+W command is used to search for text. Search is done case insensitively, The search and replace command is not available by default, but must be enabled through the -b option in the command line.

Moving inside the editor can be done using the keyboard by using the arrow keys. Keys such as Page Up, or Page Down, scroll the text up or down (towards the beginning or end of the file, respectively). The commands Ctrl+W Ctrl+Y, and Ctrl+W Ctrl+V move the cursor to the beginning or end of the file respectively, while the commands Ctrl+A and Ctrl+E move the cursor to the beginning and the end of the line that the cursor is located on.

Command-line options

The following command line options allow users to configure Pico before editing a file. This information can be obtained by starting Pico with the -h command. When Pico is invoked from Pine or Alpine some of the options below can be configured from their Setup Configuration Screen by either enabling a specific feature, or configuring a variable. Below is indicated the way to configure Pico from the command line, as well as how to configure it from Alpine. Possible starting arguments for the Pico editor are:

Command Line ArgumentMeaningAlpine Configuration Option
-eComplete - allow file name completion[X] Enable Tab Completion (enabled by default)
-kCut - let ^K cut from cursor position to end of line[X] Ctrl-K Cuts From Cursor
-aShowDot - show dot files in file browser[X] Enable Dot Files
-jGoto - allow 'Goto' command in file browser[X] Enable Goto in File Browser (enabled by default)
-gShow - show cursor in file browser[X] Show Cursor
-mMouse - turn on mouse support[X] Enable Mouse in Xterm
-xNoKeyhelp - suppress keyhelp[X] Disable Keymenu
-pPreserveStartStop - preserve "start"(^Q) and "stop"(^S) characters[X] Preserve Start/Stop Characters
-q TermdefWins - termcap or terminfo takes precedence over defaults[X] Termdef Takes Precedence
-Q <quotestr>Set quote string (e.g. "> ") esp. for composing emailReply Indent String =
-dRebind - let delete key delete current character[X] Delete Key Maps to Ctrl-D
-fKeys - force use of function keys
-bReplace - allow search and replace[X] Enable Search and Replace (enabled by default)
-hHelp - give this list of options
-r[#cols]Fill - set fill column to #cols columns, default=72Composer Wrap Column =
-n[#s]Mail - notify about new mail every #s seconds, default=180Mail Check Interval =
-s <speller>Speller - specify alternative spellerSpeller =
-tShutdown - enable special shutdown mode
-o <dir>Operation - specify the operating directoryOperating Dir =
-zSuspend - allow use of ^Z suspension[X] Enable Suspend
-wNo Wrap - turn off word wrap
-W <wordseps>Set word separators other than whitespaceComposer Word Separators =
-dcs <display_character_set>default uses LANG or LC_CTYPE from environmentDisplay Character Set =
-kcs <keyboard_character_set>defaults to display_character_setKeyboard Character Set =
-syscsuse system-supplied translation routines[X] Use System Translation
+[line#]Line - start on line# line, default=1
-vView - view file
-no_setlocale_collatedo not do setlocale(LC_COLLATE)[X] Disable Setlocale Collate
-versionPico version number

All arguments may be followed by a file name to edit.

The options -dcs, -kcs and -syscs are not available in the Windows version of Pico. However, the Windows version of Pico also has four options (-cnf, -cnb, -crf, -crb) that are not available in unix versions of Pico; each option is defined as follows: -cnf for Color for Normal Foreground, -cnb for Color for Normal Background, -crf for Color for Reverse Foreground and -crf for Color for Reverse Background. Their possible values are black, red, green, yellow, blue, magenta, cyan, and white or a 3 digit number, such as 009, 064, or 137.

gollark: If you care, consider the "pinephone", which at least has a hardware switch for its modem.
gollark: Radio stuff is all done on a separate, utterly proprietary baseband processor anyway.
gollark: I mean, Android is at least *nominally* open source and *sometimes* lets you reflash the ROM.
gollark: I don't think an iPhone is actually likely to be better in terms of potentially doing evilness than Android ones.
gollark: Nope. Phones use a wide range of frequencies.

See also

References

  1. "Pine Project History". University of Washington. January 4, 2002. Archived from the original on December 25, 2018. Retrieved December 23, 2018.
  2. "2.2 What is PICO?". University of Washington. January 29, 2002. Archived from the original on August 5, 2018. Retrieved December 23, 2018.
  3. "PICO - the PIne COmposer - a simple editor". Guckes.net. Archived from the original on October 9, 2018. Retrieved December 23, 2018.
  4. "[Nano-devel] nano to remain in GNU". GNU Project. August 19, 2016. Archived from the original on August 4, 2017. Retrieved December 23, 2018.
  5. "GNU nano -- an enhanced clone of the Pico text editor". GNU nano. Archived from the original on December 24, 2018. Retrieved December 23, 2018.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.