First Edition, ClipTool Version 38.1
Torsten Poulin
(torsten@diku.dk)
Copyright © 1994 Torsten Poulin
Published by Torsten Poulin.
Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice are preserved on all copies.
Permission is granted to copy and distribute modified versions of this manual under the conditions for verbatim copying, provided also that the sections entitled “Distribution” and “GNU General Public License” are included exactly as in the original, and provided that the entire resulting derived work is distributed under the terms of a permission notice identical to this one.
Permission is granted to copy and distribute translations of this manual into another language, under the above conditions for modified versions, except that the sections entitled “Distribution” and “GNU General Public License” may be included in a translation approved by the author instead of in the original English.
Legal Stuff | ||
---|---|---|
Distribution | How to get the latest ClipTool distribution. | |
GNU General Public License | The GNU General Public License gives you permission to redistribute ClipTool on certain terms; and also explains that there is no warranty. | |
The Manual | ||
1 Introduction | A brief introduction to ClipTool. | |
2 Options | An explanation of the shell and Workbench options. | |
3 ARexx Interface | How to control ClipTool with ARexx. |
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
ClipTool is free; this means that everyone is free to use it and free to redistribute it on a free basis. ClipTool is not in the public domain; it is copyrighted and there are restrictions on its distribution, but these restrictions are designed to permit everything that a good cooperating citizen would want to do. What is not allowed is to try to prevent others from further sharing any version of ClipTool that they might get from you. The precise conditions are found in the GNU General Public License that comes with ClipTool and also appears following this section.
The easiest way to get a copy of ClipTool is from someone else who has it. You need not ask for permission to do so, or tell any one else; just copy it.
If you have access to the Internet, you can get the latest distribution version of ClipTool from Aminet:
ftp.luth.se
litamiga.epfl.ch
ftp.uni-kl.de
ftp.uni-erlangen.de
ftp.cs.tu-berlin.de
ftp.uni-paderborn.de
ftp.etsu.edu
wuarchive.wustl.edu
src.doc.ic.ac.uk
splat.aarnet.edu.au
Most of these sites delete old files, however wuarchive.wustl.edu
and ftp.luth.se
keep all files.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Version 2, June 1991
Copyright © 1989, 1991 Free Software Foundation, Inc. 675 Mass Ave, Cambridge, MA 02139, USA Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public License is intended to guarantee your freedom to share and change free software–to make sure the software is free for all its users. This General Public License applies to most of the Free Software Foundation’s software and to any other program whose authors commit to using it. (Some other Free Software Foundation software is covered by the GNU Library General Public License instead.) You can apply it to your programs, too.
When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for this service if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs; and that you know you can do these things.
To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the software, or if you modify it.
For example, if you distribute copies of such a program, whether gratis or for a fee, you must give the recipients all the rights that you have. You must make sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights.
We protect your rights with two steps: (1) copyright the software, and (2) offer you this license which gives you legal permission to copy, distribute and/or modify the software.
Also, for each author’s protection and ours, we want to make certain that everyone understands that there is no warranty for this free software. If the software is modified by someone else and passed on, we want its recipients to know that what they have is not the original, so that any problems introduced by others will not reflect on the original authors’ reputations.
Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that redistributors of a free program will individually obtain patent licenses, in effect making the program proprietary. To prevent this, we have made it clear that any patent must be licensed for everyone’s free use or not licensed at all.
The precise terms and conditions for copying, distribution and modification follow.
Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running the Program is not restricted, and the output from the Program is covered only if its contents constitute a work based on the Program (independent of having been made by running the Program). Whether that is true depends on what the Program does.
You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee.
These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Program, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Program, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it.
Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Program.
In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the Program) on a volume of a storage or distribution medium does not bring the other work under the scope of this License.
The source code for a work means the preferred form of the work for making modifications to it. For an executable work, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the executable. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable.
If distribution of executable or object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place counts as distribution of the source code, even though third parties are not compelled to copy the source along with the object code.
If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply and the section as a whole is intended to apply in other circumstances.
It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system, which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice.
This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
If you develop a new program, and you want it to be of the greatest possible use to the public, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms.
To do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively convey the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found.
one line to give the program's name and a brief idea of what it does. Copyright (C) 19yy name of author This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
Also add information on how to contact you by electronic and paper mail.
If the program is interactive, make it output a short notice like this when it starts in an interactive mode:
Gnomovision version 69, Copyright (C) 19yy name of author Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. This is free software, and you are welcome to redistribute it under certain conditions; type `show c' for details.
The hypothetical commands ‘show w’ and ‘show c’ should show the appropriate parts of the General Public License. Of course, the commands you use may be called something other than ‘show w’ and ‘show c’; they could even be mouse-clicks or menu items—whatever suits your program.
You should also get your employer (if you work as a programmer) or your school, if any, to sign a “copyright disclaimer” for the program, if necessary. Here a sample; alter the names:
Yoyodyne, Inc., hereby disclaims all copyright interest in the program `Gnomovision' (which makes passes at compilers) written by James Hacker. signature of Ty Coon, 1 April 1989 Ty Coon, President of Vice
This General Public License does not permit incorporating your program into proprietary programs. If your program is a subroutine library, you may consider it more useful to permit linking proprietary applications with the library. If this is what you want to do, use the GNU Library General Public License instead of this License.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
ClipTool is basically a storehouse for text you may want to paste into other programs, perhaps multiple times.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
ClipTool understands the following icon tooltypes:
CX_PRIORITY=priority
lets you change the priority of ClipTool relative to other Commodities Exchange programs. The default priority is 0. The valid range is -128 to 127; the higher the number, the higher the priority. This only changes the order in which the Commodities gets to look at input events.
CX_POPKEY=hotkey string
specifies the key or keys that must be pressed to pop up ClipTool’s window. The default is ‘control lalt c’. Please refer to your Workbench manual for a list of valid key combinations.
CX_POPUP=yes|no
determines whether the GUI window is opened when ClipTool is launched. The default is ‘yes’. You will probably want to change this if you put the program in the ‘WBStartup’ drawer.
EMBOSSED=yes|no
Normally ClipTool will use embossed imagery to give its buttonbar a 3-D look, unless it is run on a two colour screen. Setting EMBOSSED=no forces ClipTool to always use its simpler 2-D imagery. This may be useful if your colour preferences make the 3-D buttons look strange.
CREATEICONS=yes|no
can be used to enable or suppress the creation of icons when data is saved to a file. The default is to create icons. This can be turned on and off at will.
UNIT=0-255
is the clipboard unit to use when ClipTool is launched. It can be changed while the program is running. The default is 0.
APPICON=yes|no
determines whether ClipTool shall put an AppIcon, a dropbox, on the Workbench. The default is ‘yes’.
PORTNAME=Arexx port name
is used to override the default port name, which is ‘CLIPTOOL’.
When started from the shell, ClipTool accepts arguments corresponding to the icon tooltypes according to this AmigaDOS template:
CX_PRIORITY/K/N,CX_POPKEY/K,CX_POPUP/K,EMBOSSED/K,CREATEICONS/K,UNIT/K/N,APPICON/K,PORTNAME/K
The case and order of the keywords doesn’t matter. The defaults are the same as when used as tooltypes.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
3.1 ARexx Commands | Descriptions of the supported commands. | |
3.2 Examples | Some ARexx scripts to get you started. |
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
In this section, each ARexx command is explained following a standard outline:
The format listing shows all the arguments and keywords accepted by the command. Square brackets enclose arguments and keywords that are optional. They are accepted by the command but are not required. A vertical bar is used to separate options of which you may only choose one.
In the command template, each argument is specified by a keyword (a
preset argument that the command understands) followed by a modifier
/X
where X
is one of the characters A
, K
,
N
, or S
. Each keyword can have several of the modifiers.
Neither the keywords nor the modifiers are case-dependent.
This is followed by a description of the command.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: OPEN FILENAME file [DIR directory]
Template: NAME=FILENAME/K/A,DIR/K
This command tries to open the file specified by the file argument, load it, and make it the current buffer. It recognizes IFF FTXT files automatically.
If you specify a relative pathname, ClipTool may not be able to locate the file, because its current directory may differ from the current directory of the process that sent the OPEN command. To overcome this problem, you can use the DIR keyword to tell ClipTool to temporarily change its current directory to directory:
'open filename' foo 'dir' pragma('D')
The built-in ARexx function pragma()
, with the option D
,
returns the full path of the current directory.
The keyword NAME is provided as an alternative to the AUISG compliant FILENAME.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: SAVEAS NAME file [FTXT] [DIR directory]
Template: NAME/K/A,FTXT/S,DIR/K
This command saves the contents of the current buffer to the file specified by the file argument. If the FTXT switch is used, it will be saved as an IFF FTXT file.
If you specify a relative pathname, the result may not be what you expect, because ClipTool’s current directory may differ from the current directory of the process that sent the SAVEAS command. To overcome this problem, you can use the DIR keyword to tell ClipTool to temporarily change its current directory to directory (for a full example, see section SaveClip.rexx):
'saveas name' foo 'dir' pragma('D')
The built-in ARexx function pragma()
, with the option D
,
returns the full path of the current directory.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: SHOW
Template: (none)
This command opens ClipTool’s main window on the default public screen. If it is already open, it is moved in front of the other windows on the screen and made active.
SHOW is a synonym for the AUISG compliant command ACTIVATE.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: HIDE
Template: (none)
This command closes ClipTool’s main window. It is not an error, if the window is already closed.
HIDE is a synonym for the AUISG compliant command DEACTIVATE.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: ACTIVATE
Template: (none)
This command opens ClipTool’s main window on the default public screen. If it is already open, it is moved in front of the other windows on the screen and made active.
ACTIVATE is an AUISG compliant synonym for the SHOW command.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: DEACTIVATE
Template: (none)
This command closes ClipTool’s main window. It is not an error, if the window is already closed.
DEACTIVATE is an AUISG compliant synonym for the HIDE command.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: QUIT
Template: (none)
This command stops ClipTool.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: CUT
Template: (none)
This command removes the current buffer and places it in the current clipboard unit.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: COPY
Template: (none)
This command places a duplicate of the current buffer into the current clipboard unit.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: PASTE
Template: (none)
This command puts the contents of the current clipboard unit into a new buffer. This buffer is made the current buffer.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: ERASE
Template: (none)
This command removes the current buffer.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: PREVIOUS
Template: (none)
This command makes the previous buffer the current buffer.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: NEXT
Template: (none)
This command makes the next buffer the current buffer.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: GETNUMBER VAR name
Template: VAR/K/A
Returns the number of clip buffers in the ARexx variable name.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: GETCURRENT VAR name
Template: VAR/K/A
Returns the number of the current buffer in the ARexx variable name.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: CREATEICONS ON|OFF
Template: ON/S,OFF/S
This command controls the creation of icons when saving files. One of the switches must be given.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: GETCREATEICONS VAR name
Template: VAR/K/A
Returns the current state of the ‘Create icons?’ menu item in the ARexx variable name. The state is one of two possible strings: ‘ON’ or ‘OFF’. Thus, the contents of name can be used as an argument to CREATEICONS (see section CREATEICONS).
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: APPICON ON|OFF
Template: ON/S,OFF/S
This command turns the AppIcon on and off.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: GETUNIT VAR name
Template: VAR/K/A
Returns the clipboard unit number in the ARexx variable name.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Format: SETUNIT number
Template: /N/A
This command sets the clipboard unit to number.
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This section contains a few example scripts, showing how you may control ClipTool from ARexx.
3.2.1 LoadClip.rexx | How to load a file into the clipboard. | |
3.2.2 SaveClip.rexx | How to save the contents of the clipboard to a file. | |
3.2.3 EDCopy.ed | How to add clipboard support to the Ed editor. |
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
/* * loadclip - Load a file into the clipboard. */ parse arg fname address cliptool 'open filename' fname 'dir' pragma(d) 'cut'
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
/* * saveclip - Save the contents of the clipboard to a file. */ parse arg fname address cliptool 'getnumber var before' 'paste' 'getnumber var after' if before < after then do 'getcreateicons var state' 'createicons off' /* we don't want an icon */ 'saveas name' fname 'dir' pragma('Directory') 'erase' 'createicons' state /* restore the previous state */ end else say 'Clipboard is empty'
[ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
/* * EDCopy - Copy the marked block to the current clipboard unit. * Assumes ClipTool is running. * You can add it to Ed's EDIT menu if you put * the following command in S:Ed-startup: * * SI n 2 "Copy to Clipboard" "rx!EDCopy.ed!" * * where n is the menu item number. * * You can also add it to a key with something like * * SF n "rx!EDCopy.ed!" * * where n range from 1 to 57. Please refer to the Ed docs for details. */ tempfile = 'T:EDCLIP-'pragma('ID') options failat 21 'WB!'tempfile'!' /* Tell Ed to write the block */ if rc = 0 then do address cliptool 'open filename' tempfile address cliptool 'cut' address command 'delete quiet force' tempfile 'SM!Copied!' end else 'SM!No block selected!' exit
[Top] | [Contents] | [Index] | [ ? ] |
[Top] | [Contents] | [Index] | [ ? ] |
This document was generated on August 3, 2022 using texi2html 5.0.
The buttons in the navigation panels have the following meaning:
Button | Name | Go to | From 1.2.3 go to |
---|---|---|---|
[ << ] | FastBack | Beginning of this chapter or previous chapter | 1 |
[ < ] | Back | Previous section in reading order | 1.2.2 |
[ Up ] | Up | Up section | 1.2 |
[ > ] | Forward | Next section in reading order | 1.2.4 |
[ >> ] | FastForward | Next chapter | 2 |
[Top] | Top | Cover (top) of document | |
[Contents] | Contents | Table of contents | |
[Index] | Index | Index | |
[ ? ] | About | About (help) |
where the Example assumes that the current position is at Subsubsection One-Two-Three of a document of the following structure:
This document was generated on August 3, 2022 using texi2html 5.0.