TEA has a long history of the development. At the autumn of year 2000, there was first implementation of TEA, written in Object Pascal using Borland Delphi. Since then, TEA was many times rewritten from zero (Pascal - C/Gtk - C++/Qt) and opened it's source. The initial TEA UI was inspired by Impulse Tracker and Sound Forge. Later, the conception of sliding panels and tabs has been implemented.
Now TEA has THREE branches. This, TEA-Qt, is the modern one. There also outdated TEA-GTK (Gtk 2) and TEA-GTK (GTK 3), the buggy one! So use TEA-Qt.
TEA has two homesites: semiletov.org/tea and tea.ourproject.org. If one of them is down, go to another one.
Normally, TEA holds its configuration data and other support files at $HOME/.config/tea (or, under Window, at drive:\Documents and Settings\username\tea). But if you want to start TEA from the flash drive in the portable mode, TEA must read/write configuration data into the directory with the TEA binary. To start TEA in the portable mode, use "--p" command line option:
tea --p
As you know, TEA under *NIX is a single binary. Under Windows TEA installation directory contains all what you need to start TEA portable. Please note, that your NORMAL-MODE settings are stills exists and available anytime when you start TEA WITHOUT the "--p" key. TEA preferences of portable and normal modes are eacj other independend and exists in parallel.
From the top to bottom, there are:
1. The main menu. Note that you can tear submenus off and place them somewhere over the desktop. Menu items are highly depended on the current task or even editor mode. Some menus can be visible or hidden according to the task (editing, file browsing, etc.).
2. The toolbars area. Actually, toolbars can be parked at the any side of TEA window. Positions are saved between sessions. To turn the toolbar on and off, use the context menu for the toolbar (right click on the toolbar). If no toolbar is visible, do the right click on the menu bar.
3. The tabbed area. It contains four main tabs - edit, manage, tune and learn. Edit - that where you see opened documents. Manage - a built-in file manager. Tune - here you can change TEA preferences. All changes will be applied immediately. Todo - the simple calendar with the organizer functions. Learn - the built-in User manual. This, the magnificious one.
4. Logmemo. It is a notification area. Destination: all warnings, information messages and the results of some text-processing functions.
5. The Famous input field (FIF). An input text field to put here values for text-processing functions. Also it is used for Find/Replace (read about a Search menu for details). FIF has three buttons - Find, Find previous and Find next. FIF is used also for a search in the TEA manual, menu items list (at the hotkeys customization page) and even the built-in file manager.
6. The status bar. You can setup the status bar's content via the preferences Interface page.
The TEA's file manager is hidden under the manage tab. It is not an additional bloatware tool, but an essential part of the editor. It replaces the standard File save/open dialogs (by the way, you can bring them back using Tune > Common > Use traditional File Save/Open dialogs option).
Let's see on the shining force of TEA's file manager.
The directory bar is located on the top. There are an entry with the current directory path, and a nice toolbar with following buttons:
Go - navigates to the directory with the path from the text entry.
Home - teleports you to your cozy home directory.
Refresh - refreshes a files list to your pleasure.
File operations button with submenu. It contains some utility actions such as Create new directory, Rename and Delete file. Please note that TEA does not deletes the directories.
The right panel of the file manager.
At the top you see the file name field. Here you can give the name for a file to open or save it. To save the current file under some name, just put the filename into the Name text entry and press the Save as button. To open a file, do the double click on the file name at the files list, or put the file name into the Name entry and press the Open button. You can use the Enter key inside of this input field. The action is related to the menu item (File open or Save as) that you used to open the file manager tab.
You can also select files multiply (Ctrl-click or INSERT key) and then press the Open button. All files are being saved/opened with the encoding that is selected at the list below from the Name entry. There is also a "?" button. Select some file and press this button - it tries to autodetect the file's character set and activate it at the encodings list. Currently only HTML files or Russian charsets are supported for automatic detection.
Bookmarks list. You can easely add and remove the directory bookmarks using the "+" and "-" buttons. The "+" button adds a bookmark to the file system tree's current directory. The "-" button removes the selected bookmark. To activate the bookmark and navigate to the according directory, double click on the bookmark.
The are some special bookmarks at the top of the list: snippets, templates, scripts. You can't remove them. They point to the TEA special directories for user's items such as templates, snippets, etc.
You can enable the Tune > Common > Automatic preview images at file manager option to show a small preview window near the file manager. Also, when the cursor is located on the image file, you can use Open at cursor (F2) function to view the image at the full-size in another built-in image viewer (see the Open at cursor description).
As you can notice, TEA has the built-in calendar-organizer under the dates tab of the main window. By double-clicking on the days, you create or open the file-per-day text documents. When you close such file, its content will be saved automatically. To remove the day record, use Calendar > Remove day record.
At the text you can specify the time signature for the alarm event. This signature has the format [hh:mm] in the 24 hour day. All text after such signature and before the next one will be treated as the alarm message. For example:
[20:00] go to the theatre
[23:00] howl at the moon
For sure, you need to have TEA running to see the alarm message!
Single click on the date cell shows the day record (if any) at the logmemo area.
At the Tune page, you can set the Start week on Sunday option to the "on". The calendar widget can work in two modes - the normal and the lunar one. Read the Calendar section for details.
New. Impossible! It's a kind of magic. This menu item creates a new blank document where you can type any words those you want. For example, type the word "hello". It's a very cheerful word. That what we usually say to all good people around. Hello! And your world becomes brighter. So, if you can type this word, it means that you can type any another one, and more than once. It's a true miracle.
Open - for sure, this menu item helps you to open any file that you already stored at your hard disk. There are many files, including the evil mature rating violent games - don't even try to open them with TEA. Oh, no! TEA is good.
If you are using the build-in file manager, read the File manager chapter. Otherwise, read the words of true about the File open dialog window.
There is a small secret at the File open dialog window. The character set combobox. Yes. With that fine tool in the box, you can open a text file in any encoding that is known by a human being. But be careful! You must know exactly which encoding you need to use to read your file correctly. Otherwise you shall see many weird letters that can harm your spiritual calmness. If so, close your eyes quickly and type "hello" at seven times! Or you can try to load your file with another encoding selected. So choose wise. By the way, TEA can try to auto-detect the encoding - just press the "?" button (on the right from the character set list).
TEA can open all plain text files, and also ODT (OpenDocument Text), KWD (old KWord's format), FB2, DOCX, RTF, SXW (old OOo/StarOffice format), ABW (Abiword) formats and gzipped files. But only the plain text files can be saved with TEA. About other mentioned formats - TEA just can extract text from them, trying to preserve the basic layout (indents, paragraphs).
Save - if your file is already saved, this menu item saves it again. That is how it works. But, if a file is not saved, you shall see a surprise! A File manager. There, put the file name into to the Name entry and press the Save as button.
Now you already know how to save and load your work. If you see the mushroom cloud from a nuclear explosion, what you gonna do? Yes, save and cover. Want to be one of those happy people on the picture below?
Save and cover! But remember, you need to place your PC to the safe place. Otherwise, the nuclear heat can destroy your files.
This man is looking disapointed. What's happen? Oh no, he lost his files!
Let's ask him: "Hey mister, why are you sad?" And he'll answer: "I'd forgotten to save and cover". That's it. He'd forgotten. He is not happy anymore. At least he'd survived.
Last closed file - opens a last closed file. This sentence is a greater paradox of XXI century CE.
Open at cursor, or F2 as a shortcut - this feature transforms a user into the so-called "F2 addict". Strange mind and body transformations can happen, so you warned!
Put the cursor at the file name in the href-link. Press F2. See THAT miracle? TEA opens a file with the file name that was pointed. If this file is already opened, its tab will be focused. If the file is an image, TEA show it in the build-in image browser. But, what if you don't work with the [X]HTML code, but use a real file names in your text and want to open them? TEA can handle that - just select a file name (not just put a cursor on it) and press F2.
What is the difference? TEA can open a "file under cursor" when the file name is enclosed with quotes. As in HTML or most of the code sources. In other cases, you need to select file name manually with Shift-cursor keys or using a mouse.
And a bit more - using Open at cursor you can navigate through local href-links.
You can also use Open at cursor at the built-in file manager to open the image file with the preview window.
Also, you can open file at cursor with any external program. Read about the "Run" menu for details.
Crapbook - opens a special file where you can put some notes, pieces of a text, etc. The crapbook file will be saved automatically when you close it. If the Crapbook file is opened and you exiting TEA, the content of a Crapbook is saved too.
Notes - a kind of crapbook, but connected to the current file. Useful to put the notes releated to the current file's content. The .notes file is autosaved on exit.
Save as different > Save .bak - saves a content of the current document with name, where the "bak" extension added.
Save as different > Save timestamped version - saves a content of the current document with name, where the timestamp is added. So you shall know the date and time related to the saved version. Note about timestamp format. Is is yyyy-MM-dd-hh-mm-ss. So the first comes a year, then a month, then days, hours, minutes and seconds.
Recent files. From this submenu you can open one of the last dozen opened files. TEA remembers the name, the encoding and the current position of the file when you close the document, so at the next time TEA already know the charset and the position, where to start an editing.
Templates - to create a new file from the template, select a template from this menu. To create a new template, save a text file into the TEA templates directory. It is available from templates bookmark at the TEA's file manager (or at the left sidebar at File save dialog). And vice versa, to open the template use the file manager's templates bookmark again. The character set of templates is always UTF-8. TEA sets it automatically even if you choose another encoding.
To delete or rename the template, use the file manager or File save/open dialogs.
Sessions - at this menu sessions are available. The session is a simple list of opened files. To load them all, just choose a session name from this menu. To save a session, put the name of the session into the Famous input field, then use File > Save different > Save session. At the preferences Common page you can check the Restore the last session on start-up option. If this option is turned on, TEA will save the session on exit (under the name def-session-777), and then load this session when starting.
Bookmarks - this menu is similar to Recent files, but the files list is updating by you, not by TEA. To add a current file to this list, use Edit bookmarks > Add to bookmarks function. If the bookmarks list already contains the adding file, its record will be updated with new position and charset values. To delete the bookmark, open the bookmarks list from the File > Configs menu, delete the needed line and save the list in a usual way. The wrong bookmark can be temporary disabling with the "#" prefix. To search wrong paths and disable such bookmarks automatically, use Edit bookmarks > Find obsolete paths function.
File actions submenu. From this menu you can do some magical things. Set UNIX end of line, Set Windows end of line, Set traditional Mac end of line - those functions allow you to override the file's end of line (EOL). When you save the file, the choosed EOL will be applied. To check the file's EOL, select a file at the built-in file manager and use Fm > File information > Full info.
Exit - closes TEA. To reduce the annoyance, TEA doesn't ask to confirm it. And another thing related to confirmations - TEA automatically proposes to save the modified existing files only. I.e. if you close (with TEA or by Ctrl-W) the modified new, nonamed file, TEA silently will close it.
This menu is available only when the todo panel is active.
Moon mode on/off - switch calendar widget to the moon/normal modes. In the first one the moon phases are shown. Also you'll see the moon day number after the slash (before the gregorian day number). I.e. the format is: normal day number / moon day number.
Some words about the calculation of moon day. First of all, you need to select the right Earth hemispehere at Tune - Common - Nortern hemisphere (on/off). The other important thing is the algorithm (Tune - Common - Moon phase algorithm). The speed and precision are vary, try for yourself. There are several algorithms were been used. Some of them are based on Ben Danglish's arcticle at http://www.ben-daglish.net/moon.shtml, another one on the Alexander Leushkanov's arcticle - http://www.astrogalaxy.ru/275.html.
Due to some technical source, the image of moon phase for days 12 and 13 are the same.
Add or subtract years/months/days - allows one to navigate through the calendar back and forward on N years, or months, or days. For example, you need to see the day +6 after the current one. Put "6" into the Famous Input Field, and then use Add or subtract > days. If you want to move backward, put the negative value into the FIF, i.e. "-6" instead of "6".
Number of days between two dates - calculates the number of days between two dates. Select the first date at the Calendar and use Mark first date menu item. Select the last date at the Calendar and use Mark last date. Use Number of days between two dates functions to measure the difference between the first and second dates.
Calculate moon days between dates - creates a list with a moon days between two dates (Mark first/last date).
Some notes about Indent/Un-indent functions. There are two hardcoded keyboard shortcuts are assigned to this functions - Tab and Shift-Tab. If no text selected, Indent (Tab) inserts a tab character or a space (spaces). Such behavior is depended from Tune > Interface > Use spaces instead of tabs and Tab width in spaces options.
If Use spaces instead of tabs is checked on, the editor will insert (by Tab key) the number of spaces that defined at Tab width in spaces. Otherwise, TEA inserts a single tab.
TEA also has the Automatic indent option, disabled by default.
Indent by first line - this function indents all selected lines with the same indent as the first line's of selection indent.
Variants - this function shows a user-defined menu for the selected word. Menu has items (words) to replace the selected word. For example, we want to see the list of variants for the word "animal". Create the file with name "animal" at TEA's variants directory (see $HOME/.config/tea/variants (or, under Window, at drive:\Documents and Settings\username\tea\variants)). Put to this file the list of items:
cow
dog
cat
wolf
Save the file, then open some text and select there "animal". Use Edit - Variants function to open the list of variants for the selected word.
Storage files - you can use some file as a "storage" file to copy text directly to it from different sources. Set as storage file chooses the current opened file as the storage file. Then, if ypu want copy and paste some text into that file, just use Copy to storage file. Also you can capture the system's clipboard for the text and put it to the storage using Start/stop capture clipboard to storage file. You may has just one storage file per session. When you close the storage file, all further pasting to it will be disabled until you not set a storage file again.
The functions from this menu are mainly working depending of the selected markup Mode. There are several modes available - HTML, XHTML, LaTeX, Wikitext, Lout and DocBook. When you select some mode from the Mode menu, you set the markup mode for the current document. So different documents have different, separated modes. It allows one to edit one file as HTML and another one as DocBook XML with the same menu item. So, menu items acts differently according to the document's markup mode. To use Wikitext mode, set this mode manually from the menu Mode, or use .wiki as the filename extension.
You can select a text and use some function, for example the "Paragraph". If you don't select any text, TEA just insert tags at the cursor position.
Beside the tag-related functions, Markup menu has a set of [X]HTML tools.
[X]HTML tools - Rename selected file - renames the file and changes the selection text. For example, you have (in your HTML document) a h-ref link to some file. You want to rename that file. Select its file name at the text, then put into the FIF a new file name (without the full path, just the name.ext), and use this function. Voila!
[X]HTML tools > Document weight - calculates a total document weight including all SRC-staff (images, flashes etc). Look for the result at the Logmemo.
[X]HTML tools > Convert tags to entities - if you want to show some HTML-tagged code in your [X]HTML-document, select your code and use this function. You'll get, for example:
<b>demo</b>
[X]HTML tools > Text to HTML - this function converts a plain text into the nice HTML/XHTML-formatted code using CSS.
[X]HTML tools > Preview selected color - previews the selected (within the text) color at the Famous input field. The color can be in the form of the hex value or the named color (darkBlue, red, white, etc).
Antispam e-mail - makes a selected mailto-link possibly invisible to those damned spammer e-mail harvesters, by converting an address into integer-coded entities. For example, if you will look at the source of that document, mailto:tea@list.ru will look like the heap of a garbage. I hope that spam harvesters do not understands it.
TEA has no dialog windows for find/replace functions. TEA uses the Famous input field and menu-driven interface.
To find a substring within the text, put your substring into the Famous input field (Use Ctrl-F to focus it) and press Enter. Then you can use Find next or Find previous functions. There are also three buttons near the Famous input field. They are: Find, Find previous and Find next. On search, TEA starts from the cursor position. You can set Whole words and Case sensitive options by checking the according menu items.
To replace the selected (i.e. text that been found) text with a new one, put the new value to the Famous input field and use the Replace with function. Thus, you can walk through the text using Find next and apply Replace with when you need.
To replace all occurrences of a substring in the text, put a special command into the Famous input field:
old value~new value
So, the "~" is the delimiter. For example, you want to replace all occurrences of the word "cat" to the "mouse". The command will be:
cat~mouse
So put such command to the Famous input field and apply the Replace all function.
If you want to delete some substring from the text, use the substring~ formulae. For example, to remove all occurencies of the word "weapon" from the text you can use "weapon~".
While search or replace you can use regular expressions. To do so, turn on the Regexp mode option (below the Whole words). For example, to convert HTML italic tag into the TeX tag you can use the following formulae:
<i>([^<]*)</i>~\emph{\1}
Please note that \1 acts like a content of the captured (with "parentheses") part of the source string. To have the access to the second such part, use \2, \3 for the third, etc.
Another example - how to find all numbers at the text? Use the (\d+) regexp at the FIF.
Don't forget to disable the Regexp mode when you need to do a usual searching. Also the Regexp mode overrides the the Case insensitive mode, i.e. with Regexp mode the Case sensitive is ON by default.
Fuzzy mode - enables very basic "fuzzy search" support. For example, you need to find some word, but don't remember how exactly it written. So in fuzzy mode, TEA can find similar word (if they have the same length, i.e "fender", "lender", etc). The factor of similarity can be defined at Tune - Functions - Miscellaneous - Fuzzy search factor.
In the file manager mode, "Replace all" works with all selected files and the charset from the charset selector of the file manager panel.
At the last, Replace all in opened files works as the Replace all, but in the scope of all opened files.
Search in files - searches the text given at FIF within all text files, starting from the current directory at the built-in file manager (the Manage tab), and deeper into the subdirectories. For a text encoding, TEA uses the charset that is selected at the charset list on the Manage tab.
Actually, TEA searches not in the ALL files. For the central processing unit, there is no difference between text files or mp3, or images. Programs must know the difference, but how? And why it is so important to identify the text file? If the program cannot do that, it will search the text in all files - images, sounds, videos, etc.. Too much time! Thus, TEA must know the difference. So TEA presumes that text files is the files with extensions those TEA recognizes for syntax highlighting. Also, TEA know that text files are txt, odt, kwd, docx and other formats those TEA support. Finally, TEA know about some definitely text files those have names such as README, ChangeLog, etc.
So, TEA cannot search in all other files and currently there is no way to define custom file-name mask or something like that.
To use text-processing functions, you need to select some text first. Some functions (such as Text statistics) can work with a whole text if no fragment is selected. Also there are some special cases when TEA can treat the current word as a selection when there is no text is actually selected. For example, it is a behavior of UPCASE and lowcase functions. But such behavior is a rare exception from the rule.
Some functions takes the parameter that you must place into the Famous input field. For example, the function Remove lines < N size gets N value from the Famous input field, so first you type the value, then call a function. There are no default values.
Cells submenu is used for all table-like data processing. It can be LaTeX tables, CSV-data, etc. In all cases you need to define (at FIF) the column separator to tell TEA how to parse the strings.
Functions > Cells > Sort table by column ABC - sorts the text table by the column with the ABC order.
Format string for FIF: separator~column number
Columns range starts from 0, i.e. the first colums is 0, the second is 1, etc.
For example, we have LaTeX table with 4 rows, 2 columns:
dog&cat
lamb&cow
snake&wombat
wolf&tiger
Now we want to sort it by the second (1) column (where the "cat", "cow", etc.). Select the text, put "&~1" into the FIF, and call this function. The table will be sorted by the second column.
It is good to process the table without line-breaks (such as "\\" in LaTeX), and then add line-breaks to the result using the "Apply to each line" function with FIF value "%s\\".
Functions > Cells > Swap cells - swaps the cells of the table by columns.
FIF format string: separator~column1~column2
For example (with the previous sample table) we want to swap column 0 with 1 - the column with "cat" must be before "dog" column. Select the text, put into the FIF "&~0~1", and call Swap cells.
Functions > Cells > Delete by column - delete column by the given number (0..n).
FIF format: separator~column number
0 - first column, 1 - second, etc.
Functions > Cells > Copy by column[s] - copy columns to the clipboard.
FIF format: separator~column 1[~column 2]
If the column2 is not given, the column1 will be copied, else - from column1 to column 2.
Functions > Analysis > Text statistics - outputs text statistics for the whole text or the selection into the Logmemo.
Functions > Analysis > Words lengths - how much words with length from 1 to 32.
Functions > Analysis > UNITAZ - the UNIversal Text AnalyZer that compute frequencies of words and give some other related information.
Functions > Analysis > Count the substring - number of occurrences of the substring (put it to the Famous Input Field) in the document. See the result at the logmemo. The "Search - Case sensitive" is used as an option.
Functions > Analysis > Extract words - extracts all word from the document and place them into the newly created one.
In TEA, the tables is a something like a set of rules for the text replacing. At the first, you need to create the file with a table (key=value format). Here is an example:
cat=dog mew=bow-wow
Then save this file as a replacement table file at the special TEA directory called tables. It is available at the file manager's bookmarks panel or file save dialog favourities. After you save the table under some name, it shows at the Functions > Tables menu.
Now try to apply this table. Create a new file and write some text like this: The cat say: "mew". Select this text, then select your table from the menu and see what will happen. As a result we have a new sentence: The dog say: "bow-wow". So the tables is a way to do a multiply replacement.
If the Regexp mode at the Search options is turned on, the table will use the keys as the regexps.
In the file manager mode, tables works with all selected files and the charset from the charset selector of the file manager panel.
The snippet is the piece of code, which you can insert into the text. TEA keeps an each snippet as the single file in the $HOME/.tea/snippets directory. The file name of a snippet is the menu item in Snippets-menu, i.e. the content of Snippets menu is the list of files from $HOME/.tea/snippets. To create a new snippet, you need:
1. Write some text.
2. File > Save As. Click the "snippets" bookmark to open a snippets directory, then save your file as a usual one. Note: Do not save a snippet under the name of any other TEA menu item! Menu item names should not duplicates, otherwise TEA cannot set keyboard shortcuts properly. It is important when you give a name for the snippet, or the script, template, session name, etc.
3. Enjoy :)
You can create a snippet that use a text selection in a some way. For example, you want to make a snippet which encloses the selected text into some HTML-tags. The %s macro represents a text selection. Here is the example of such snippet:
<a href="%s">%s</a>
When this snippet will be applied, %s will be replaced with the selected text. If there no text is selected, snippet content will be inserted into the text (but without the "%s" macro).
To open a snippet for the editing, use snippets directory boomark at the TEA file manager or File save/open dialog. From there you can also rename or delete snippets (use the context menu - the right click - in File save/open dialogs).
With TEA you can use scripts to process a selected text, just as you use a built-in TEA functions. If the script can handle some parameters, put them into the Famous input field.
TEA can work with scripts those written in Python, Perl, Ruby and Bash (Sh). To install a script, just copy it to $HOME/.config/tea/scripts (you can use "scripts" shortcut at the Save As dialog to save your file as a TEA script). If a script is packed, please unpack it first. TEA will "see" the newly installed scripts after restart or when you save the script from TEA. The scripts management stuff is similar to snippets.
How to write a script for TEA? It's a quite simple. But the first thing that you must to know it is how TEA gives a text to the script and how TEA takes a processed text back to replace the selection with it.
TEA runs each script with one or two parameters. Both of them are file names. The first file contains the text (UTF-8). This text is a selected text that TEA gets at the current document. And the second file (if exists) contains a text (UTF-8) from the Famous input field. So your script can read the first file to obtain the text data, and read the second file to get some optional parameters for your script.
Be careful with the text handling - TEA internally operates with UTF-8 encoding, so all text processing at the script must be UTF-8-safe. OK, now let's see how a script can return a processed text. Just write that processed text to the first file again, i.e. to the file, which file name you take from the first parameter of your script.
Below this lines you shall see an example of UTF8-safe Python-script that takes a text, swaps the case, and returns the processed text back to the TEA.
import sys import string import codecs f = codecs.open(sys.argv[1], "r", "utf-8" ) u = f.read() f.close u = u.swapcase() f = codecs.open(sys.argv[1], "w+", "utf-8" ) f.write (u) f.close
sys.argv[1] contains a name of file with the text from TEA. We read the whole content of that file, then we process this content, and then we write it back to the sys.argv[1]-file. Voila! Please note how to use the codecs.
And another example - the "inline" calculator. Here we don't use any codecs because we work with a numerical data:
import sys f = file (sys.argv[1], 'r') s = f.read() f.close t = eval (s) f = file (sys.argv[1], 'w+') f.write (str (t)) f.close
But what if we need to get some additional user's parameters to the script? They are available as a string, and you can read it from the file that named at sys.argv[2] (in Python). At Bash-script, use $1 to get the first parameter, and $2 for the second. Summing this all, the second parameter is a file which contains a text from the Famous input field. Note that Ruby scripts takes the first parameter in ARGV[0], and the second in ARGV[1].
Some notes about the BASH-scripts and sed/ed/etc stuff. The trick is to use a temporal file. First copy the $1 into some temp. file, then process this temporal file and put the result back into the $1. Here is an example (replacing all "dog" with "cat") of such script:
cp $1 /tmp/xyz.xyz sed 's/dog/cat/g' /tmp/xyz.xyz > $1
If you wish to contribute some scripts to the TEA site scripts repository, please consider to contribute your script with a public domain status. Or at least with the Free license. There is also will be useful to put the credits and the description somewhere in the comments within your script.
Sort > Sort case sensitively - sorts selected lines alphabetically and case sensitively.
Sort > Flip a list - reverses lines order. Was:
Dog
Cat
Cow
Will be:
Cow
Cat
Dog
Filter > Remove duplicates - useful when the string list has duplicated elements. Any duplicated item AFTER the original one will be removed. Can be slow on slow machines.
Filter > Remove empty lines - no empty lines will surrender! Empty lines are useless.
Filter > Remove lines < N size - remove lines with the length less than N. N is the number of characters. Write the number into the Famous input field.
Filter > Remove lines > N size - acts like the previous function, but removes all strings those larger than N characters.
Filter > Filter with regexp - filter a list using the regular expression. For more info, see www.regular-expressions.info. However, here is a a brief example. Let's presume you have a list:
hello.doc
example.txt
nature.jpeg
mytext.txt
And you want to filter all items with "txt"-extension. So the regexp (regular expression) for this will be:
.*\.txt$
Put it into the Famous input field, select the text and apply a function. Voila!
Filter > Remove after delimiter at each line. Removes the substring after the delimiter at each selected line. You need to put the delimiter into the FIF. For example, the delimiter is ")", and the selected text is:
1.) Nirvana 2.) Grajdanskaya Oborona 3.) The Cranberries
Apply the filter, and you'll get this:
1. 2. 3.
Filter > Remove before delimiter at each line. Removes the substring BEFORE the delimiter at each selected line. You need to put the delimiter into the FIF. For example, the delimiter is ")", and the selected text is:
1.) Nirvana 2.) Grajdanskaya Oborona 3.) The Cranberries
Apply the filter, and you'll get this:
Nirvana Grajdanskaya Oborona The Cranberries
Math > Sum by last column - sums values of each last column at the selection. For example, we can calculate the simply text list:
Carrots 14
Apples 45.8
Oranges 11
Math > Evaluate - calculates the expression that selected at the text. For example you can write 2+2, then select it and apply Evaluate. After such action you shall see the result at the logmemo. In your expression can may use the following operators: +, -, *, /, ^ (power), % (get percent value). The bracers are not supported. Here are some examples:
2/3*123 5+5+5 1-200*89 2^8 250%4 //what is 4 per cent of 250?
Math > Decimal to binary - converts the decimal integer into its binary representation. Example: was 255, will be 0000 0000 0000 0000 0000 0000 1111 1111.
Math > Binary to decimal - works with unsigned int binary numbers only.
Math > Flip bits (bitwise complement) -use this function to flip a bit at the binary value. Example: was 0000 0010, will be 1111 1101.
Math > Enumerate - Enumerates lines from the selected text. Place the parameter string of this function into the Famous input field. Syntax: step~zero_padding~prefix.
Step is the step of an increment. For example, the step 1 gives a numbers 1, 2, 3 etc. Step = 10 will give us 10, 20, 30.
Zero padding defines how many digits are in each number. For example, if zero padding = 3, and step = 1, we shall have 001, 002, 003 etc.
Prefix is a prefix after the number and before the string. Prefix can have a significant trailing spaces.
Here are some examples and results:
example 1, parameters are "1~3~) " (without quotes). Result is:
001) dog 002) cat 003) mouse
example 2, parameters are "10~1 " (without quotes). Result is:
10 dog 20 cat 30 mouse
example 3, the parameter is "1" (without quotes). Result is:
1dog 2cat 3mouse
You can use this function even without the parameters - in such case, padding = 0, step = 1, and the prefix is an empty string. You can use the single step parameter or the pair step and padding, or all three parameters.
Math > Arabic to Roman - converts "usual" numbers into the Roman form (i.e 20 to XX).
From Morse To English. I am not a guru in Morse codes, but I hope that my effort to implement such function is right. With this menu item you can translate the English text into the Morse code. For example, was:
tea and coffee
Will be:
- . .- .- -. -.. -.-. --- ..-. ..-. . .
Note that TEA puts a single space between two Morse codes.
From Morse To English. The inverse action for the previous function. You can decode any English Morse-coded message. You must to know that TEA; supposes that there are single spaces between Morse-codes, as in the example written before.
Text > Remove formatting at each line - removes the formatting (tabs, new lines, double spaces etc.) at each selected line.
Text > Remove formatting - removes the formatting from the whole selected text, so the text will be converted to the one big string without new lines, double spaces, etc.
Text > Apply to each line is a powerful tool to add some text into the each line of the selection. And again we use the Famous input field. For example, I want to add br-tag at the end of each line. So I type into the entry:
%s<br>
And then I apply this function to get br-tag added at the end of each line. The %s macro points to the each line of the selection. So consider that the %s represents a text of the each line. In another example, I want to enclose an each line into a pair of li-tags. The formula for the Famous input field will be:
<li>%s</li>
And another example:
<a href="%s">%s</a>
You can also apply the snippets (from the TEA's snippets directory). To do such thing, use the @@snippetname at the FIF. For exampe, if you have the snipped named "myitalic", use @@myitalic. As you remember, snippets can contain the %s macro to substitude the seletected text. In the case of "Apply to each line" function, %s will mean the the text of each selected line.
Text > Escape regexp useful to escape regexp special characters such as $, *, +, [, ], etc .
TEA can use two spell checking engines: Aspell and Hunspell. To switch between them use the list Spell checker engine at Tune - Functions page.
Aspell engine uses system-wide installed dictionaries (use the your Linux distro package manager to install them). At the Windows, you need some extra things to do. First, download and install Aspell full installer from the http://aspell.net/win32/. Then, from the same page, download and install some dictionaries. You need to put them into the directory, where Aspell is installed. By default, it is C:\Program Files\Aspell. Finally, at TEA, you need to set the path to the Aspell - go to the Tune - Functions, change the Aspell directory option to the correct onem and restart TEA.
For Hunspell, you also need to set the path to the dictionaries by youself, manually. It is possible that the dictionaries are already installed because Hunspell is the spell checking engine for Firefox, OpenOffice.org and Opera. For example, Firefox (in a case of the user local home directory installation) holds the dictionaries at firefox/dictionaries directory. Also you can download dictionaries from LibreOffice and OpenOffice.org extension repositories. There are files with OXT extension. Internally they are common ZIP-files. So download and rename filename.oxt to filenname.zip. Create some directory for dictionaries and unpack the .aff and .dic files from ZIP. Then select this directory using Select button at the Tune - Functions - Hunspell dictionaries path option.
When the dictionary stuff is configured, you need to go to the menu Functions - Spell checker languages and select the language what you need. Without this last step the spell checking will fail. Also select the language in this way after you change the engine from Aspell to Hunspell or vice versa.
It's a good idea to restart TEA after adding the dictionary.
Spell-checker languages - At this menu you can find the list of dictionaries which installed for aspell (from the distro or so). To spell check, use one of those menu items. It works with the whole text, not with the selection only.
The menu item with the language name is used also to set the default spell-checker language. Default value is a language of your locale. To do a simple check with the default language, use Spell check menu item.
Suggest - shows the list with suggestions for the current misspelled word (actually, the word under the cursor). To use this function, use Spell check first. Possibly incorrect words will be underlined.
You can fix them with the Suggest functions or by the hand. When you fix the error you can see that the fixed word is colored as before. That is because the nature of the TEA spellchecker - it updates manually, so to update error marks select the same spell checking menu item again. To turn error marks off, use View > Hide error marks.
Add to dictionary - add the underlined as incorrect word to the user's local dictionary. Actually, this function adds to the dictionary any word at the cursor.
Beware that some correct words TEA can mark as incorrect. It's due to the current word parsing, it will be fixed soon as possible.
Remove from dictionary- this function is Hunspell-only. An updated dictionary will be loaded after the next session.
Functions > Plugins. TEA (Qt5-builds) can run the plugins written in QML (see the source code tarball/manuals/plugins for the details how to write TEA plugins). The plugins are snipped as archived directories (TEA itself can unpack ZIPped plugin to plugins folder if you try open such achive in TEA). To install the plugin. just unpack it WITH its directory to $HOME/.config/tea/plugins (UNIX-way) or drive:\Documents and Settings\username\tea\plugins (Windows-way). Then restart TEA to rescan the plugins list. Delete plugin's directory to uninstall it. I am not responsible on how plugin work - it can do everything just like the normal stand-alone program, so trust your plugin developer or don't use it.
This menu is designed for running the current file with external programs, browsers for example. To add some items to menu, go to File > Configs > Programs list config, edit that file and then save it. The configuration file has the simple ini-like format. Each line has the following format:
meni item caption=command line
An example of the command line for a browser starting:
konqueror=konqueror %s
%s is a needful macro for a current filename, so use it in the properly place. For Win32 you need to use the full path for the executable file, with the double quotes (macro %s needs its quotes too!). For example:
opera="C:\Program Files\Opera\opera.exe" "%s"
Some more precise macros are available: %fbasename, %ffilename, %fext, %fdir. This allows to use the parts of the path. Thus, if we have the full path "/mnt/foo/bar.txt", %fdir = "/mnt/foo", %fbasename = "bar", %ffilename = "bar.txt", %fext = "txt". So the full path at the command line can be presented in the following way: %fdir/%fbasename.%fext
To open the current selected file or file at cursor at the text (as by F2, but with external program) use %i macro.
For example, if you want to open the image file with gimp, put the following command line to the config file:
gimp=gimp %i
Then, at HTML or LaTeX file, move the cursor to the image file name. Then call "gimp" menu item from the "Run" menu. Enjoy.
Labels, Update labels. You can put some specially formatted labels into the text and then switch between them from the Labels menu (or drop-down list on the toolbar). How it works? The label is just a text embraced with the opening and the ending sequences ("[?" and "?]" by default, this values can be redefined at Tune - Functions - Labels).
For example, put into your text some lines such as "[? dogs ?]", "[? cats ?]". Then make TEA know this labeles using Update labels menu item or press the button on the toolbar. The Labels menu and
drop-down list will be filled with labels "dogs" and "cats". You can select them from the menu or the list and navigate to the text near the selected label. Please note that labels are updating manually only.
Go to line - moves the cursor position to the line number that you provide in the Famous input field.
Save position/Go to saved position - these functions are good to make a quick jump through a large text, when you need to look something at the one place, then return to the currently editing place, etc.
Fm is meaning the File manager. This menu contain functions those related to TEA file manager. For example, you can rename files or directories or get the MD5 checksum. Explore and use!
For some function such as MD5 checksum, select the file first, and then apply the function.
Fm > Select by regexp/Deselect by regexp - use this functions to select or deselect files by regexp pattern. For example, to select all txt-files at the current dir, put the following regexps into the FIF:".*\.txt$" (without quotes!) then, use Select by regexp. Then you can press Open button to open all selected files.
Fm > File information > Full info - gives you a full information about the file (creation/modification time, etc). For the 16 bit PCM WAV files it calculates the RMS (for the both channels). For other WAV's shows just the properties such as bit depth, etc.
Fm > File information > Count lines in selected files - please note that empty lines will be also counted.
Fm > Images > Scale by percentages/Scale by side - among other non-text related functions TEA has the ability of batch conversion of images. It is useful when you want to scale them or convert to another format.
For example, we want to scale selected images by 50 per cents, put the the processed images into the new directory and zip that directory:
1. Select files at the File manager. To select them multiply, use Ctrl-Click (or Ctrl-A to select all).
2. Put the desired perecentage into the Famous Input Field. The value must be a simple integer number without the % sign.
3. At the Tune > Images check the Zip directory with processed images option.
4. Apply the Scale by percentages function.
After that, TEA creates a new directory as a subdirectory of a current one. This new directory has the random name that starts with "images-out-". Into this directory TEA put all converted images, leaving the originals unmodified.
You can want to scale images in a more precise way and define the size manually. To do that, put the image side size into the Famous Input Field and apply Scale by side. As you know, each photo has dimensions. For example, 640x480. If the width is larger than height, the image has a horizontal orientation (TEA does not support EXIF data), and vise versa. So we can use the side - the larger side of an image. Usually all photos has a standard dimensions with some aspect ratio in a mind, so the larger side for all of photos is the same.
For example, we want to scale all images (photos wit a right aspect ratio/dimension) to width 640 and, if the image has a vertical orientation, to the height 640. Put that 640 into the Famous Input Field and apply Scale by side.
Image convestion options are places at the Tune > Images page. With the Image conversion output format list you can set the output format. The Output images quality (from 0 to 100) is used mainly for JPEG. A default value is -1 that means the internaly defined value. The Scale images with bilinear filtering checkbox affects images when you scale them, to smooth the image and make it less "rough".
Fm > Images > Create web gallery - yes, TEA can create a simple table-based web gallary. Dp the following steps:
1. Put your images in some directory. Save the html-file there. Open that file with TEA.
2. Go to the TEA's file manager, select image files those you want to put into the weg gallery.
3. Use the Create web gallery function.
4. The thumbnails and the HTML-table shall be created.
You can customize the gallery using the Tune > Images > Web gallery options. There is a thumbnail size, cells per row, et cetera.
TEA as a ZIP packer/unpacker
TEA provides simple functions to pack files (not directories) to the archive. To do such thing, set the archive name first (do that at the directory where you want to create the archive):
Fm > ZIP > Create new ZIP
The input dialog box will be provided. Then, walk through your directories. Select any files and use Add to ZIP to add them into the archive. Please note - all that happens virtually until you do not use a Save ZIP function. To pack the files physically, apply Save ZIP.
All files will be packed into the archive that has a one subdirectory names as the achive name, but without .zip-extension.
You can also unpack the selected ZIP-file into the current directory. Use the Unpack ZIP to current directory function. Please note that the file names charset (inside of the ZIP-archive) are controlled via Tune - Common - ZIP unpacking: file names charset/ZIP packing: file names charset options. So, if you see weird characters after you unpacked ZIP-file, try to tune the charset. To do this less painful, select some charset at ZIP unpacking: file names charset and try how is looking file name - use List ZIP content menu item. It simple lists the archive content (file names) into the Logmemo using selected charset.
And another note - TEA does not support password-protected ZIPs.
Highlighting mode - from this submenu you can set the highlighting mode manually. It is useful for a new unsaved files or for file without extensions.
Hide error marks - hides the underlined marks those were set by the spell-checker.
Toggle word wrap - turn word wrapping on/off for the current document.
Palettes - from this submenu you can select the color scheme that affects a text editing area. To define your own colors you can create your own palette based on some build-in palettes (see the source directory, palettes subdir). Then save your palette into the $HOME/.config/tea/palettes directory and choose one from the Palettes menu.
TEA partially supports Eclipse IDE themes (eclipsecolorthemes.org) - just put XML file of theme to TEA palettes directory and select from menu as the native TEA palette. Please note that TEA palette format supports more highlighting elements than Eclipse Color Theme plugin, so Eclipse themes will be not so colorful as TEA native palettes.
Profiles - this menu allows you to switch between view profiles (they includes parameters such as window position, size, word wrap and line numbering settings, etc.). So you can save your current settings via Save profile function, and named profile will appear at the Profiles menu. In any time you can select it to recall saved settings.
On Keyboard tab you can assign the shortcuts with the menu items. To set a new hotkey, select a menu item from the list, then press some hotkey combination at the entry to the right from the list, and press the Assign button. To remove a hotkey, select the menu item from the list and press Remove button. To re-assing the hotkey that already in use, do Remove for this shortcut first.
Add user font button - you can add fonts to TEA locally, instead of system fonts database. Just select font file (TTF or OTF) and this font will be available in TEA. To remove such font, you need to edit TEA configuration file "userfonts.txt" (at $HOME/.config/tea), delete the line with font's file path, save "userfonts.txt" and restart TEA.
Word wrap - use word wrapping globally for all documents, including new ones.
Use wrap setting from highlighting module on the Interface page means that the word wrap settings will be taken from the syntax highlighting modules, not from the global Word wrap option. Some modules has word wrapping turned on, and some turned off. For example, for C++ the word wrap setting is on. For the plain text or for the HTML - is off.
The legacy "--charset=codepage" command line option is supported. This command sets the codepage for the following files. For example:
tea --charset=window-1251 file1.txt file2.txt --charset=utf-8 file3.txt
By default (if no charset defined manually) TEA uses UTF-8.
This manual and all TEA media stuff (palettes, images, etc) is the public domain. TEA source code is licensed under GPL v3.
User's syntax hl files can be added to the $HOME/.config/tea/hls directory. See the working hl files at the TEA source directory, the hls subdirectory. Feel free to contribute your hl files. Please use color references from the palette files (look at palettes directory at the source). I.e. use "preproc" or "types" color instead of the hexodecimal value.
My home site with the prose, programs, music and other things.
Drymba studio - the indie film studio that make ultra-low-budget movies and clay/3D cartoons. I'm one of the creators. Public domain.
Atomnaya Smena - my one-person music project. Rock/Indietronica/Symphonic/Psytrance. All music is in the public domain.
Nesmeyana - the band where I am one of the members. All music is in the public domain.
Kostny Mozg - the indie/hip-hop/techno band, where I am one of the members. Public domain and Artistic License.