From: Carsten Dominik Date: Mon, 20 Dec 1999 11:18:31 +0000 (+0000) Subject: TeXInfo documentation of the IDLWAVE mode and shell X-Git-Tag: emacs-pretest-21.0.90~5657 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=797c8ebcdd861ad6798acad8554ed6dbb37927bb;p=emacs.git TeXInfo documentation of the IDLWAVE mode and shell --- diff --git a/man/idlwave.texi b/man/idlwave.texi new file mode 100644 index 00000000000..6082e8dfdf4 --- /dev/null +++ b/man/idlwave.texi @@ -0,0 +1,1784 @@ +\input texinfo @c -*-texinfo-*- +@c %**start of header +@setfilename ../info/idlwave +@settitle IDLWAVE User Manual +@dircategory Editors +@direntry +* IDLWAVE: (idlwave). Major mode and shell for IDL and WAVE/CL files. +@end direntry +@synindex ky cp +@syncodeindex vr cp +@syncodeindex fn cp +@set VERSION 3.11 +@set EDITION 1.7 +@set IDLVERSION 5.3 +@set NSYSROUTINES 1226 +@set NSYSKEYWORDS 5230 +@set DATE December 1999 +@set AUTHOR Carsten Dominik +@set AUTHOR-EMAIL dominik@@astro.uva.nl +@set MAINTAINER Carsten Dominik +@set MAINTAINER-EMAIL dominik@@astro.uva.nl +@c %**end of header +@finalout + +@ifinfo +This file documents IDLWAVE, a major mode for editing IDL and +WAVE/CL files with Emacs. It also implements a shell for running IDL as +a subprocess.@refill + +This is edition @value{EDITION} of the IDLWAVE User Manual for +IDLWAVE @value{VERSION}@refill + +Copyright (c) 1999 Free Software Foundation, Inc. + +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. + +@ignore +Permission is granted to process this file through TeX +and print the results, provided the printed document +carries a copying permission notice identical to this +one except for the removal of this paragraph (this +paragraph not being relevant to the printed manual). + +@end ignore +Permission is granted to copy and distribute modified +versions of this manual under the conditions for +verbatim copying, 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 this permission notice may be stated in a +translation approved by the Free Software Foundation. +@end ifinfo + +@titlepage +@title IDLWAVE User Manual +@subtitle Major Emacs mode and shell for IDL and WAVE/CL files +@subtitle Edition @value{EDITION}, @value{DATE} + +@author by Carsten Dominik +@page +Copyright @copyright{} 1999 Free Software Foundation, Inc. + +@sp 2 +This is edition @value{EDITION} of the @cite{IDLWAVE User Manual} for +IDLWAVE version @value{VERSION}, @value{DATE}.@refill + +@sp 2 + +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 that the entire resulting +derive 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 this permission notice may be stated in a +translation approved by the Free Software Foundation. + +@end titlepage +@page + +@ifinfo +@node Top, Introduction, (dir), (dir) + +IDLWAVE is a package to support editing command files for the +Interactive Data Language (IDL), and for running IDL as an inferior +shell. @refill + +@end ifinfo + +@menu +* Introduction:: What IDLWAVE is and what not +* IDLWAVE in a Nutshell:: One page quick-start guide +* The IDLWAVE Major Mode:: The mode to edit IDL programs +* The IDLWAVE Shell:: The mode to run IDL as inferior program +* Installation:: How to Install or Upgrade +* Acknowledgement:: Who helped +* Sources of Routine Info:: How does IDLWAVE know about routine XYZ +* Configuration Examples:: The user is king... +* Index:: Fast access + +@detailmenu + + --- The Detailed Node Listing --- + +The IDLWAVE Major Mode + +* Code Formatting:: Making code look nice +* Routine Info:: Calling Sequences and Keywords +* Completion:: Completing routine names and Keywords +* Code Templates:: Abbreviations for frequent constructs +* Actions:: Changing case, Padding, End checking +* Doc Header:: Inserting a standard header +* Motion Commands:: Moving through the structure of a program +* Misc Options:: Things that fit nowhere else + +Code Formatting + +* Code Indentation:: Reflecting the logical structure +* Comment Indentation:: Special indentation for comment lines +* Continuation Lines:: Splitting statements over lines +* Syntax Highlighting:: Font-lock support + +Actions + +* Block Boundary Check:: Is the END correct +* Padding Operators:: Enforcing space around `=' etc +* Case Changes:: Enforcing upper case keywords + +The IDLWAVE Shell + +* Starting the Shell:: How to launch IDL as a subprocess +* Using the Shell:: Interactively working with the Shell +* Debugging IDL Programs:: Compilation/Debugging + +Debugging IDL Programs + +* Compiling Programs:: Compiling buffers under the shell +* Breakpoints and Stepping:: Deciding where to stop and look +* Examining Variables:: What is the value now? + +Installation + +* Installing IDLWAVE:: How to install the distribution +* Upgrading from idl.el:: Necessary configuration changes + +Sources of Routine Info + +* Routine Definitions:: Where IDL Routines are defined. +* Routine Information Sources:: So how does IDLWAVE know about... +* Library Scan:: Scanning the Libraries for Routine Info +* Updating idlwave-rinfo.el:: Scanning the Reference Manual +@end detailmenu +@end menu + +@node Introduction, IDLWAVE in a Nutshell, Top, Top +@chapter Introduction +@cindex Introduction +@cindex CORBA (Common Object Request Broker Architecture) +@cindex cc-mode.el +@cindex Feature overview + +IDLWAVE is a package to support editing command files for the +Interactive Data Language (IDL), and for running IDL as an inferior +shell. It also can be used for WAVE/CL command files, but the support +for these is limited. Note that this package has nothing to do with the +Interface Definition Language as part of the Common Object Request +Broker Architecture (CORBA). + +IDLWAVE is the successor to the @file{idl.el} and @file{idl-shell.el} +files written by Chris Chase. The modes and files had to be renamed +because of a name space conflict with CORBAs @code{idl-mode}, defined in +Emacs in the file @file{cc-mode.el}. If you have been using the old +files, check @ref{Upgrading from idl.el} for information on how to +switch. + +IDLWAVE consists of two parts: A major mode for editing command files +(@code{idlwave-mode}) and a mode to allow running the IDL program as an +inferior shell (@code{idlwave-shell-mode}). Both modes work closely +together and form a complete development environment.@refill + +Here is a brief summary of what IDLWAVE does. + +@itemize @bullet +@item +Code indentation and formatting. +@item +Font-lock support on three levels. +@item +Display of calling sequence and keywords of more than 1000 IDL +routines. +@item +Context sensitive completion of routine names and keywords. +@item +Insertion of code templates. +@item +Actions to enforce coding standards during typing. +@item +Block structure check. +@item +Documentation support. +@item +Running IDL as inferior process. +@item +Shell with history search, command line editing and completion. +@item +Compilation, execution and debugging of programs directly from the source +buffer. +@item +Examining expressions with a mouse click. +@end itemize + +@ifnottex +@cindex Screenshots +Here are a number of screenshots showing IDLWAVE in action. +@itemize @bullet +@item +@uref{http://www.strw.leidenuniv.nl/~dominik/Tools/idlwave/font-lock.gif, +XEmacs 21.1 with formatted and fontified code} +@item +@uref{http://www.strw.leidenuniv.nl/~dominik/Tools/idlwave/rinfo.gif, +XEmacs 21.1 displaying routine info} +@item +@uref{http://www.strw.leidenuniv.nl/~dominik/Tools/idlwave/complete.gif, +XEmacs 21.1 completing a keyword} +@item +@uref{http://www.strw.leidenuniv.nl/~dominik/Tools/idlwave/shell.gif, +XEmacs 21.1 with debugging toolbar; execution stopped at a breakpoint} +@end itemize +@end ifnottex + +In this manual, each section contains a list of user options related to +the subject. Don't be confused by the shear number of options available +-- in most cases the default settings are just fine. The variables are +listed here to make sure you know where to look if you want to change +things. For a full description of what a particular variable does and +how to configure it, see the documentation string of that variable. +Some configuration examples are also given in the appendix. + +@node IDLWAVE in a Nutshell, The IDLWAVE Major Mode, Introduction, Top +@chapter IDLWAVE in a Nutshell +@cindex Quick-Start +@cindex Getting Started +@cindex IDLWAVE in a Nutshell +@cindex Nutshell, IDLWAVE in a + +If you are in a hurry, here is some quick-start information. + +@subheading Editing IDL Programs + +@multitable @columnfractions .15 .85 +@item @key{TAB} +@tab Indent the current line relative to context. +@item @kbd{M-C-\} +@tab Re-indent all lines in the current region. +@item @kbd{M-@key{RET}} +@tab Start a continuation line. Or split the current line at point. +@item @kbd{M-q} +@tab Fill the current comment paragraph. +@item @kbd{C-c ?} +@tab Display calling sequence, keywords of the procedure/function call +at point. +@item @kbd{M-@key{TAB}} +@tab Complete a procedure name, function name or keyword in the buffer. +@item @kbd{C-c C-i} +@tab Update IDLWAVE's knowledge about functions and procedures. +@item @kbd{C-c C-v} +@tab Find the source code of a procedure/function. +@item @kbd{C-c C-h} +@tab Insert a standard documentation header. +@item @kbd{C-c C-m} +@tab Insert a new timestamp and history item in the documentation header. +@end multitable + +@subheading Running the IDLWAVE Shell, Debugging Programs + +@multitable @columnfractions .15 .85 +@item @kbd{C-c C-s} +@tab Start IDL as a subprocess and/or switch to the interaction buffer. +@item @kbd{C-u C-c C-s} +@tab Start the shell in a separate frame. +@item @kbd{M-p} +@tab Cycle back through IDL command history matching command line input. +@item @kbd{M-n} +@tab Cycle forward. +@item @kbd{M-@key{TAB}} +@tab Complete a procedure name, function name or keyword in the shell buffer. +@item @kbd{C-c C-d C-c} +@tab Save and compile the source file in the current buffer. +@item @kbd{C-c C-d C-x} +@tab Goto next syntax error. +@item @kbd{C-c C-d C-b} +@tab Set a breakpoint at the current source line. +@item @kbd{C-c C-d C-d} +@tab Clear the current breakpoint. +@item @kbd{C-c C-d C-p} +@tab Ask IDL to print the value of the expression near point. +@end multitable + +@subheading Commonly used Settings in @file{.emacs} +@lisp +;; Change the indentation preferences +(setq idlwave-main-block-indent 2 ; default 0 + idlwave-block-indent 2 ; default 4 + idlwave-end-offset -2) ; default -4 + +;; Syntax Highlighting +(add-hook 'idlwave-mode-hook 'turn-on-font-lock) +;; Automatically expand END to ENDIF, ENDELSE, ... +(setq idlwave-expand-generic-end t) + +;; Automatically start the shell when needed +(setq idlwave-shell-automatic-start t) +;; Always use a separate frame for the shell buffer +(setq idlwave-shell-use-dedicated-frame t) + +;; Specify a file where library info can be stored. +(setq idlwave-libinfo-file "~/idlinfo.el") +@end lisp + +@node The IDLWAVE Major Mode, The IDLWAVE Shell, IDLWAVE in a Nutshell, Top +@chapter The IDLWAVE Major Mode +@cindex IDLWAVE major mode +@cindex Major mode, @code{idlwave-mode} + +The IDLWAVE major mode supports editing IDL and WAVE/CL command files. +In this chapter we describe the main features of the mode and how to +customize them. + +@menu +* Code Formatting:: Making code look nice +* Routine Info:: Calling Sequences and Keywords +* Completion:: Completing routine names and Keywords +* Code Templates:: Abbreviations for frequent constructs +* Actions:: Changing case, Padding, End checking +* Doc Header:: Inserting a standard header +* Motion Commands:: Moving through the structure of a program +* Misc Options:: Things that fit nowhere else +@end menu + +@node Code Formatting, Routine Info, The IDLWAVE Major Mode, The IDLWAVE Major Mode +@section Code Formatting +@cindex Code formatting +@cindex Formatting, of code + +@menu +* Code Indentation:: Reflecting the logical structure +* Comment Indentation:: Special indentation for comment lines +* Continuation Lines:: Splitting statements over lines +* Syntax Highlighting:: Font-lock support +@end menu + +@node Code Indentation, Comment Indentation, Code Formatting, Code Formatting +@subsection Code Indentation +@cindex Code indentation +@cindex Indentation + +Like all Emacs programming modes, IDLWAVE performs code indentation. +The @key{TAB} key indents the current line relative to context. +@key{LFD} insert a newline and indents the new line. The indentation is +governed by a number of variables. + +@cindex Foreign code, adapting +@cindex Indentation, of foreign code +To re-indent a larger portion of code (e.g. when working with foreign code +written with different conventions), use @kbd{M-C-\} +(@code{indent-region}) after marking the relevant code. Useful marking +commands are @kbd{C-x h} (the entire file) or @kbd{M-C-h} (the +current subprogram). @xref{Actions}, for information how to impose +additional formatting conventions on foreign code. + +@defopt idlwave-main-block-indent (@code{0}) +Extra indentation for the main block of code. That is the block between +the FUNCTION/PRO statement and the END statement for that program +unit.@refill +@end defopt + +@defopt idlwave-block-indent (@code{4}) +Extra indentation applied to block lines. If you change this, you +probably also want to change @code{idlwave-end-offset}.@refill +@end defopt + +@defopt idlwave-end-offset (@code{-4}) +Extra indentation applied to block END lines. A value equal to negative +@code{idlwave-block-indent} will make END lines line up with the block +BEGIN lines.@refill +@end defopt + +@defopt idlwave-continuation-indent (@code{2}) +Extra indentation applied to continuation lines and insided unbalanced +parenthesis.@refill +@end defopt + +@node Comment Indentation, Continuation Lines, Code Indentation, Code Formatting +@subsection Comment Indentation +@cindex Comment indentation +@cindex Hanging paragraphs +@cindex Paragraphs, filling +@cindex Paragraphs, hanging + +In IDL, lines starting with a @samp{;} are called @emph{comment lines}. +Comment lines are indented as follows: + +@multitable @columnfractions .1 .90 +@item @code{;;;} +@tab The indentation of lines starting with three semicolons remains +unchanged. +@item @code{;;} +@tab Lines starting with two semicolons are indented like the surrounding code. +@item @code{;} +@tab Lines starting with a single semicolon are indent to a minimum column. +@end multitable + +The indentation of comments starting in column 0 is never changed. + +@defopt idlwave-no-change-comment +The indentation of a comment that starts with this regular +expression will not be changed. +@end defopt + +@defopt idlwave-begin-line-comment +A comment anchored at the beginning of line. A comment matched by this +regular expression will not have its indentation changed.@refill +@end defopt + +@defopt idlwave-code-comment +A comment that starts with this regular expression on a line by itself +is indented as if it is a part of IDL code.@refill +@end defopt + +@node Continuation Lines, Syntax Highlighting, Comment Indentation, Code Formatting +@subsection Continuation Lines and Filling +@cindex Continuation lines +@cindex Line splitting +@cindex Splitting, of lines +@cindex Filling +@cindex @code{auto-fill-mode} +@cindex Hanging paragraphs + +In IDL, a newline character terminates a statement unless preceded by a +@samp{$}. If you would like to start a continuation line, use +@kbd{M-@key{RET}} which calls the command @code{idlwave-split-line}. It +inserts a @samp{$} to indicate that the following line is a continuation +of the current line, terminates the line with a newline and indents the +new line. The command @kbd{M-@key{RET}} can also be used in the middle +of a line to split the line at that point. When used inside a long +string constant, the string is split with the @samp{+} concatenation +operator. You could even use @code{auto-fill-mode} to automatically +break code lines into several lines while you type. For this, set the +variable @code{idlwave-fill-comment-line-only} to @code{nil} and turn on +@code{auto-fill-mode}. @code{auto-fill-mode} can be toggled with +@kbd{C-c C-a}. + +When filling comment paragraphs, IDLWAVE overloads the normal filling +functions and uses a function which creates hanging paragraphs as they +are customary in the IDL routine headers. When @code{auto-fill-mode} is +turned on, comments will be auto-filled. If the first line of a +paragraph is matched by @code{idlwave-hang-indent-regexp}, subsequent +lines are indented to after the position of this match, as in the +following example. + +@example +; INPUTS +; x - an array containing +; lots of interesting numbers. +; +; y - another variable where +; a hanging paragraph is used +; to describe it. +@end example + +You also refill a comment paragraph with @kbd{M-q}. + +@defopt idlwave-fill-comment-line-only (@code{t}) +Non-@code{nil} means auto fill will only operate on comment lines. +@end defopt + +@defopt idlwave-auto-fill-split-string (@code{t}) +Non-@code{nil} means auto fill will split strings with the IDL @samp{+} +operator. +@end defopt + +@defopt idlwave-split-line-string (@code{t}) +Non-@code{nil} means @code{idlwave-split-line} will split strings with +@samp{+}. +@end defopt + +@defopt idlwave-hanging-indent +Non-@code{nil} means comment paragraphs are indented under the hanging +indent given by @code{idlwave-hang-indent-regexp} match in the first +line of the paragraph.@refill +@end defopt + +@defopt idlwave-hang-indent-regexp +Regular expression matching the position of the hanging indent +in the first line of a comment paragraph.@refill +@end defopt + +@defopt idlwave-use-last-hang-indent (@code{nil}) +Non-@code{nil} means use last match on line for +@code{idlwave-indent-regexp}.@refill +@end defopt + +@node Syntax Highlighting, , Continuation Lines, Code Formatting +@subsection Syntax Highlighting +@cindex Syntax highlighting +@cindex Font lock + +Highlighting of keywords, comments, strings etc. can be accomplished +with @code{font-lock}. To enable @code{font-lock} for IDL files, place +the following line into your @file{.emacs} (see +@ref{Configuration Examples})@refill + +@lisp +(add-hook 'idlwave-mode-hook 'turn-on-font-lock) +@end lisp + +IDLWAVE supports 3 levels of syntax highlighting. The variable +@code{font-lock-maximum-decoration} determines which level is selected. + +@defopt idlwave-default-font-lock-items +Items which should be fontified on the default fontification level +2.@refill +@end defopt + +@node Routine Info, Completion, Code Formatting, The IDLWAVE Major Mode +@section Routine Info +@cindex Routine info + +IDL defines more than one thousand procedures, functions and object +methods. This large command set makes it difficult to remember the +calling sequence and keywords of a command. IDLWAVE contains a list of +all builtin routines with calling sequences and keywords@footnote{This +list was created by scanning the IDL manual and might contain (very few) +errors. Please report any detected errors to the maintainer, so that +they can be fixed.}. It also scans Emacs buffers and library files for +routine definitions and queries the IDLWAVE-Shell for the properties of +modules currently compiled under the shell. When you have edited a +buffer or compiled additional routines under the shell, use @kbd{C-c +C-i} (@code{idlwave-update-routine-info}) to update IDLWAVE's idea about +these routines.@refill + +To display the information about a routine, press @kbd{C-c ?} which +calls the command @code{idlwave-routine-info}. When the current cursor +position is on the name or in the argument list of a procedure or +function, information will be displayed about the routine. For example, +consider the cursor positions in the following line + +@example +plot,x,alog(x+5*sin(x) + 2), + 1 2 3 4 5 6 7 8 +@end example + +@cindex Object methods +On positions 1,2 and 8, information about the @samp{plot} procedure will +be shown. On positions 3,4, and 7, the @samp{alog} function will be +described, while positions 5 and 6 will select the @samp{sin} function. +When you ask for routine information about an object method, and the +method exists in several classes, IDLWAVE queries for the class of the +object. + +@cindex Calling sequences +@cindex Keywords of a routine +The description displayed contains the calling sequence, the list of +keywords and the origin of this information (@emph{system routine}, +@emph{library routine}, @emph{Emacs buffer}, or @emph{compiled +module}). It looks like this: + +@example +Usage: MAP_PROJ_INFO, iproj +Keywords: CIRCLE CURRENT CYLINDRICAL NAME UV_LIMITS WIDTH +Origin: buffer visiting /soft1/idl/lib/map_set.pro +@end example + +Some of the text in the @file{*Help*} buffer will be active (it +highlights when you move the mouse over it). Clicking with the middle +mouse button on any of the active fields will try to find the source file of +the routine and display it in another window. Another click on the same +line will switch back to the buffer from which @kbd{C-c ?} was +called. Clicking with the right mouse button on an active field will +search the IDL online help for this item.@refill + +@cindex Routine source file +@cindex Module source file +Another way to find the source file of a routine is the command @kbd{C-c +C-v} (@code{idlwave-find-module}). It asks for a module name, offering +the same default as @code{idlwave-routine-info} would have used. In the +minibuffer, specify a complete routine name (including the class part). +IDLWAVE will display the source file in another window.@refill + +@cindex @code{RESOLVE_ROUTINE} +@cindex Compiling library modules +@cindex Routines, resolving +@cindex Online help, for IDL routines +The two other commands that work with the routine at point need a +running IDLWAVE shell. The key sequence @kbd{M-?} calls the command +@code{idlwave-routine-info-from-idlhelp}. This sends the command line +@samp{ONLINE_HELP, '@var{routine_name}'} to IDL in order to display the +documentation of the routine in the IDL online documentation. The key +sequence @kbd{C-c =} calls the command @code{idlwave-resolve} and sends +the line @samp{RESOLVE_ROUTINE, '@var{routine_name}'} to IDL in order to +resolve (compile) it. + +@code{idlwave-resolve} is one way to get a library module within reach +of IDLWAVE's routine info collecting functions. A better way is to +prescan (parts of) the library (@pxref{Library Scan}). Routine info on +library modules will then be available without the need to compile the +modules first, and even without a running shell. + +@xref{Sources of Routine Info}, for in-depth information where IDLWAVE +collects data about routines, and how to update this information. + +@defopt idlwave-scan-all-buffers-for-routine-info (@code{t}) +Non-@code{nil} means, scan all buffers for IDL programs when updating +info. When this variable is @code{nil}, it only parses the current +buffer.@refill +@end defopt + +@defopt idlwave-query-shell-for-routine-info (@code{t}) +Non-@code{nil} means query the shell for info about compiled routines. +@end defopt + +@defopt idlwave-resize-routine-help-window (@code{t}) +Non-@code{nil} means, resize the Routine-info @file{*Help*} window to +fit the content.@refill +@end defopt + + +@node Completion, Code Templates, Routine Info, The IDLWAVE Major Mode +@section Completion +@cindex Completion + +IDLWAVE offers completion for routine names and keywords. As in many +programming modes, completion is bound to @kbd{M-@key{TAB}}. +Completion uses the same internal information as routine info, +so in order to update IDLWAVE's idea about your own routines after you +have edited or compiled them, press @kbd{C-c C-i} +(@code{idlwave-update-routine-info}).@refill + +The completion function is context sensitive and figures out what to +complete at point. Here are example lines and what @kbd{M-@key{TAB}} +would try to complete when the cursor is on the position marked with a +@samp{*}. + +@example +plo* @r{Procedure} +x = a* @r{Function} +plot,xra* @r{Keyword of @code{plot} procedure} +plot,x,y,/x* @r{Keyword of @code{plot} procedure} +plot,min(* @r{Keyword of @code{min} function} +obj -> a* @r{Object method (procedure)} +a(2,3) = obj -> a* @r{Object method (function)} +x = obj_new('IDL* @r{Class name} +x = obj_new('MyCl',a* @r{Keyword to @code{Init} method in class @code{MyCl}} +@end example + +@cindex Scrolling the @file{*Completions*} window +@cindex Completion, scrolling +If the list of completions is too long to fit in the +@file{*Completions*} window, the window can be scrolled by pressing +@kbd{M-@key{TAB}} repeatedly.@refill + +@cindex Case of completed words +The case of the completed words is determined by what is already in the +buffer. When the partial word being completed is all lower case, the +completion will be lower case as well. If at least one character is +upper case, the string will be completed in upper case or mixed case. +The default is to use upper case for procedures, functions and keywords, +and mixed case for object class names and methods, similar to the +conventions in the IDL manuals. These defaults can be changed with the +variable @code{idlwave-completion-case}.@refill + +@defopt idlwave-completion-case +Association list setting the case (UPPER/lower/Capitalized/...) of completed +words.@refill +@end defopt + +@defopt idlwave-completion-force-default-case (@code{nil}) +Non-@code{nil} means, completion will always honor the settings in +@code{idlwave-completion-case}. When nil (the default), lower case +strings will be completed to lower case. +@end defopt + +@defopt idlwave-complete-empty-string-as-lower-case (@code{nil}) +Non-@code{nil} means, the empty string is considered lower case for +completion.@refill +@end defopt + +@defopt idlwave-keyword-completion-adds-equal (@code{t}) +Non-@code{nil} means, completion automatically adds @samp{=} after +completed keywords.@refill +@end defopt + +@defopt idlwave-function-completion-adds-paren (@code{t}) +Non-@code{nil} means, completion automatically adds @samp{(} after +completed function. A value of `2' means, also add the closing +parenthesis and position cursor between the two.@refill +@end defopt + +@defopt idlwave-completion-restore-window-configuration (@code{t}) +Non-@code{nil} means, restore window configuration after successful +completion.@refill +@end defopt + +@subsubheading Object Method Completion and Class Ambiguity +@cindex Object methods +@cindex Class ambiguity +An object method is not uniquely determined without the object's class. +Since the class part is usually omitted in the source code, IDLWAVE +considers all available methods in all classes as possible completions +of an object method name. For keywords, the combined keywords of the +current method in all available classes will be considered. In the +@file{*Completions*} buffer, the classes allowed for each completion +will be shown next to the item (see option +@code{idlwave-completion-show-classes}).@refill + +You can also call @code{idlwave-complete} with a prefix arg: @kbd{C-u +M-@key{TAB}}. IDLWAVE will then prompt you for the class in order to +narrow down the number of possible completions. The variable +@code{idlwave-query-class} can be configured to make this behavior the +default (not really recommended). After you have specified the class +for a particular statement (e.g. when completing the method), IDLWAVE +can remember it for the rest of the editing session. Subsequent +completions in the same statement (e.g. keywords) can then reuse this +class information. Remembering the class works by placing a text +property in the object operator @samp{->}. This is not enabled by +default - the variable @code{idlwave-store-inquired-class} can be used +to turn it on.@refill + +@defopt idlwave-completion-show-classes (@code{t}) +Non-@code{nil} means, show classes in @file{*Completions*} buffer when +completing object methods and keywords.@refill +@end defopt + +@defopt idlwave-completion-fontify-classes (@code{t}) +Non-@code{nil} means, fontify the classes in completions buffer. +@end defopt + +@defopt idlwave-query-class (@code{nil}) +Association list governing query for object classes during completion.@refill +@end defopt + +@defopt idlwave-store-inquired-class (@code{nil}) +Non-@code{nil} means, store class of a method call as text property on +@samp{->}.@refill +@end defopt + +@defopt idlwave-class-arrow-face +Face to highlight object operator arrows @samp{->} which carry a class +property.@refill +@end defopt + +@node Code Templates, Actions, Completion, The IDLWAVE Major Mode +@section Code Templates +@cindex Code templates +@cindex Abbreviations +@cindex Templates + +IDLWAVE can insert IDL code templates into the buffer. For a few +templates, this is done with direct keybindings: + +@multitable @columnfractions .15 .85 +@item @kbd{C-c C-c} +@tab @code{CASE} statement template +@item @kbd{C-c C-f} +@tab @code{FOR} loop template +@item @kbd{C-c C-r} +@tab @code{REPEAT} loop template +@item @kbd{C-c C-w} +@tab @code{WHILE} loop template +@end multitable + +Otherwise, special abbreviations are used. Emacs abbreviations are +expanded by typing text into the buffer and pressing @key{SPC} or +@key{RET}. The special abbreviations used to insert code templates all +start with a @samp{\} (the backslash). Here are a few examples of +predefined abbreviations. For a full list, use @kbd{M-x +idlwave-list-abbrevs}. + +@multitable @columnfractions .15 .85 +@item @code{\pr} +@tab @code{PROCEDURE} template +@item @code{\fu} +@tab @code{FUNCTION} template +@item @code{\c} +@tab @code{CASE} statement template +@item @code{\f} +@tab @code{FOR} loop template +@item @code{\r} +@tab @code{REPEAT} loop template +@item @code{\w} +@tab @code{WHILE} loop template +@item @code{\i} +@tab @code{IF} statement template +@item @code{\elif} +@tab @code{IF-ELSE} statement template +@item @code{\b} +@tab @code{BEGIN} +@end multitable + +@defopt idlwave-abbrev-start-char +A single character string used to start abbreviations in abbrev +mode.@refill +@end defopt + +@defopt idlwave-abbrev-move (@code{t}) +Non-@code{nil} means the abbrev hook can move point, e.g. to end up +between the parenthesis of a function call. +@end defopt + +@node Actions, Doc Header, Code Templates, The IDLWAVE Major Mode +@section Actions +@cindex Actions +@cindex Coding standards, enforcing + +@emph{Actions} are special commands which are executed automatically +while you write code in order to check the structure of the program or +to enforce coding standards. Most actions which have been implemented +in IDLWAVE are turned off by default, assuming that the average user +wants her code the way she writes it. But if you are a lazy typist and +want your code to adhere to certain standards, they can be +helpful.@refill + +Action can be applied in three ways: +@itemize @bullet +@item +Some actions are applied directly while typing. For example, pressing +@samp{=} can run a check to make sure that this operator is surrounded +by spaces and insert these spaces if necessary. Pressing @key{SPC} +after a reserved word can call a command to change the word to upper +case.@refill +@item +When a line is re-indented with @key{TAB}, actions can be applied to the +entire line. To enable this, the variable @code{idlwave-do-actions} +must be non-@code{nil}.@refill +@item +@cindex Foreign code, adapting +@cindex Actions, applied to foreign code +Action can also be applied to a larger piece of code, e.g. in order to +convert foreign code to your own style. To do this, mark the relevant +part of the code and execute @kbd{M-x expand-region-abbrevs}. Useful +marking commands are @kbd{C-x h} (the entire file) or @kbd{M-C-h} (the +current subprogram). @xref{Code Indentation}, for information how to +ajust the indentation of the code.@refill +@end itemize + +@defopt idlwave-do-actions (@code{nil}) +Non-@code{nil} means performs actions when indenting. +@end defopt + +@menu +* Block Boundary Check:: Is the END correct +* Padding Operators:: Enforcing space around `=' etc +* Case Changes:: Enforcing upper case keywords +@end menu + +@node Block Boundary Check, Padding Operators, Actions, Actions +@subsection Block Boundary Check +@cindex Block boundary check +@cindex @code{END} type checking +@cindex @code{END}, automatic insertion +@cindex Block, closing +@cindex Closing a block + +Whenever you type an @code{END} statement, IDLWAVE finds the +corresponding start of the block and the cursor blinks back to that +location for a second. If you have typed a specific @code{END}, like +@code{ENDIF} or @code{ENDCASE}, you get a warning if that kind of END +does not match the type of block it terminates.@refill + +Set the variable @code{idlwave-expand-generic-end} in order to have all +generic @code{END} statements automatically expanded to a specific type. +You can also type @kbd{C-c ]} to close the current block by inserting +the appropriate @code{END} statement.@refill + +@defopt idlwave-show-block (@code{t}) +Non-@code{nil} means point blinks to block beginning for +@code{idlwave-show-begin}.@refill +@end defopt + +@defopt idlwave-expand-generic-end (@code{nil}) +Non-@code{nil} means expand generic END to ENDIF/ENDELSE/ENDWHILE etc. +@end defopt + +@node Padding Operators, Case Changes, Block Boundary Check, Actions +@subsection Padding Operators +@cindex Padding operators with spaces +@cindex Operators, padding with spaces + +Some operators can be automatically surrounded by spaces. This can +happen when the operator is typed, or also later when the line is +indented. IDLWAVE contains this setting for the operators @samp{&}, +@samp{<}, @samp{>}, @samp{,}, @samp{=}, but the feature is turned off by +default. If you want to turn it on, customize the variable +@code{idlwave-surround-by-blank}. You can also define similar actions +for other operators by using the function +@code{idlwave-action-and-binding} in the mode hook. For example, to +enforce space padding of the @samp{+} and @samp{*} operators, try this +in @file{.emacs} + +@lisp +(add-hook 'idlwave-mode-hook + (lambda () + (setq idlwave-surround-by-blank t) ; Turn this type of actions on + (idlwave-action-and-binding "*" '(idlwave-surround 1 1)) + (idlwave-action-and-binding "+" '(idlwave-surround 1 1)))) +@end lisp + +@defopt idlwave-surround-by-blank (@code{nil}) +Non-@code{nil} means, enable @code{idlwave-surround}. If non-nil, +@samp{=}, @samp{<}, @samp{>}, @samp{&}, @samp{,} are surrounded with +spaces by @code{idlwave-surround}. +@end defopt + +@defopt idlwave-pad-keyword (@code{t}) +Non-@code{nil} means pad @samp{=} for keywords like assignments.@refill +@end defopt + +@node Case Changes, , Padding Operators, Actions +@subsection Case Changes +@cindex Case changes + +Actions can be used to change the case of reserved words or expanded +abbreviations by customizing the variables +@code{idlwave-abbrev-change-case} and +@code{idlwave-reserved-word-upcase}. If you want to change the case of +additional words automatically, put something like the following into +your @file{.emacs} file:@refill + +@lisp +(add-hook 'idlwave-mode-hook + (lambda () + ;; Capitalize system vars + (idlwave-action-and-binding idlwave-sysvar '(capitalize-word 1) t) + ;; Capitalize procedure name + (idlwave-action-and-binding "\\<\\(pro\\|function\\)\\>[ \t]*\\<" + '(capitalize-word 1) t) + ;; Capitalize common block name + (idlwave-action-and-binding "\\[ \t]+\\<" + '(capitalize-word 1) t))) +@end lisp + +For more information, see the documentation string for the function +@code{idlwave-action-and-binding}. + +@defopt idlwave-abbrev-change-case (@code{nil}) +Non-@code{nil} means all abbrevs will be forced to either upper or lower +case. Legal values are @code{nil}, @code{t}, and @code{down}. +@end defopt + +@defopt idlwave-reserved-word-upcase (@code{nil}) +Non-@code{nil} means, reserved words will be made upper case via abbrev +expansion. +@end defopt + + +@node Doc Header, Motion Commands, Actions, The IDLWAVE Major Mode +@section Documentation Header +@cindex Documentation header +@cindex Modification timestamp +@cindex Header, for file documentation +@cindex Timestamp, in doc header. +@cindex Changelog, in doc header. + +The command @kbd{C-c C-h} inserts a standard routine header into the +buffer, with the usual fields for documentation. One of the keywords is +@samp{MODIFICATION HISTORY} under which the changes to a routine can be +recorded. The command @kbd{C-c C-m} jumps to the @samp{MODIFICATION +HISTORY} of the current routine or file and inserts the user +name with a timestamp. + +@defopt idlwave-file-header +The doc-header template or a path to a file containing it. +@end defopt + +@defopt idlwave-timestamp-hook +The hook function used to update the timestamp of a function. +@end defopt + +@defopt idlwave-doc-modifications-keyword +The modifications keyword to use with the log documentation commands. +@end defopt + +@defopt idlwave-doclib-start +Regexp matching the start of a document library header. +@end defopt + +@defopt idlwave-doclib-end +Regexp matching the start of a document library header. +@end defopt + +@node Motion Commands, Misc Options, Doc Header, The IDLWAVE Major Mode +@section Motion Commands +@cindex Motion commands +@cindex Program structure, moving through +@cindex Code structure, moving through + +Several commands allow to move quickly through the structure of an IDL +program. These are + +@multitable @columnfractions .15 .85 +@item @kbd{C-M-a} +@tab Beginning of subprogram +@item @kbd{C-M-e} +@tab End of subprogram +@item @kbd{C-c @{} +@tab Beginning of block (stay inside the block) +@item @kbd{C-c @}} +@tab End of block (stay inside the block) +@item @kbd{M-C-n} +@tab Forward block (on same level) +@item @kbd{M-C-p} +@tab Backward block (on same level) +@item @kbd{M-C-d} +@tab Down block (enters a block) +@item @kbd{M-C-u} +@tab Backward up block (leaves a block) +@item @kbd{C-c C-n} +@tab Next Statement +@end multitable + + +@node Misc Options, , Motion Commands, The IDLWAVE Major Mode +@section Miscellaneous Options + +@defopt idlwave-help-application +The external application providing reference help for programming. +@end defopt + +@defopt idlwave-startup-message (@code{t}) +Non-@code{nil} means display a startup message when @code{idlwave-mode}' +is first called. +@end defopt + +@defopt idlwave-mode-hook +Normal hook. Executed when a buffer is put into @code{idlwave-mode}. +@end defopt + +@defopt idlwave-load-hook +Normal hook. Executed when @file{idlwave.el} is loaded. +@end defopt + + + + + + + + + + + + + + + + +@node The IDLWAVE Shell, Installation, The IDLWAVE Major Mode, Top +@chapter The IDLWAVE Shell +@cindex IDLWAVE shell +@cindex Major mode, @code{idlwave-shell-mode} + +The IDLWAVE shell is an Emacs major mode which allows to run the IDL +program as an inferior process of Emacs. It can be used to work with +IDL interactively, to compile and run IDL programs in Emacs buffers and +to debug these programs. The IDLWAVE shell uses @file{comint}, an Emacs +packages which handles the communication with the IDL program. +Unfortunately IDL for Windows and MacOS does not allow the interaction +with Emacs@footnote{Please inform the maintainer if you come up with a way +to make the IDLWAVE shell work on these systems.} - so the IDLWAVE shell +only works under Unix.@refill + +@menu +* Starting the Shell:: How to launch IDL as a subprocess +* Using the Shell:: Interactively working with the Shell +* Debugging IDL Programs:: Compilation/Debugging +@end menu + +@node Starting the Shell, Using the Shell, The IDLWAVE Shell, The IDLWAVE Shell +@section Starting the Shell +@cindex Starting the shell +@cindex Shell, starting +@cindex Dedicated frame, for shell buffer +@cindex Frame, for shell buffer + +The IDLWAVE shell can be started with the command @kbd{M-x +idlwave-shell}. In @code{idlwave-mode} the function is bound to +@kbd{C-c C-s}. It creates a buffer @file{*idl*} which is used to +interact with the shell. If the shell is already running, @kbd{C-c C-s} +will simple switch to the shell buffer. The command @kbd{C-c C-l} +(@code{idlwave-shell-recenter-shell-window}) displays the +shell window without selecting it.@refill + +In order to create a separate frame for the IDLWAVE shell buffer, call +@code{idlwave-shell} with a prefix argument: @kbd{C-u C-c C-s} or +@kbd{C-u C-c C-l}. If you always want a dedicated frame for the shell +window, configure the variable +@code{idlwave-shell-use-dedicated-frame}.@refill + +The shell can also be started automatically when another command tries +to send a command to it. To enable auto start, set the variable +@code{idlwave-shell-automatic-start} to @code{t}.@refill + +@defopt idlwave-shell-explicit-file-name +This is the command to run IDL. +@end defopt + +@defopt idlwave-shell-command-line-options +A list of command line options for calling the IDL program. +@end defopt + +@defopt idlwave-shell-prompt-pattern +Regexp to match IDL prompt at beginning of a line. +@end defopt + +@defopt idlwave-shell-process-name +Name to be associated with the IDL process. +@end defopt + +@defopt idlwave-shell-automatic-start +Non-@code{nil} means attempt to invoke idlwave-shell if not already +running. +@end defopt + +@defopt idlwave-shell-initial-commands +Initial commands, separated by newlines, to send to IDL. +@end defopt + +@defopt idlwave-shell-use-dedicated-frame (@code{nil}) +Non-@code{nil} means, IDLWAVE should use a special frame to display +shell buffer. +@end defopt + +@defopt idlwave-shell-frame-parameters +The frame parameters for a dedicated idlwave-shell frame. +@end defopt + +@defopt idlwave-shell-temp-pro-prefix +The prefix for temporary IDL files used when compiling regions.@refill +@end defopt + +@defopt idlwave-shell-mode-hook +Hook for customizing @code{idlwave-shell-mode}. +@end defopt + +@node Using the Shell, Debugging IDL Programs, Starting the Shell, The IDLWAVE Shell +@section Using the Shell +@cindex comint +@cindex Shell, basic commands + +The IDLWAVE shell works in the same fashion as other shell modes in +Emacs. It provides command history, command line editing and job +control. Here is a list of commonly used commands, see the Emacs +documentation on @file{comint} for additional information.@refill + +@multitable @columnfractions .12 .88 +@item @kbd{M-p} +@tab Cycle backwards in input history matching input +@item @kbd{M-n} +@tab Cycle forwards +@item @kbd{M-r} +@tab Previous input matching a regexp +@item @kbd{M-s} +@tab Next input that matches a regexp +@item @kbd{return} +@tab Send input or copy line to current prompt +@item @kbd{C-c C-a} +@tab Beginning of line; skip prompt +@item @kbd{C-c C-u} +@tab Kill input to beginning of line +@item @kbd{C-c C-w} +@tab Kill word before cursor +@item @kbd{C-c C-c} +@tab Send ^C +@item @kbd{C-c C-z} +@tab Send ^Z +@item @kbd{C-c C-\} +@tab Send ^\ +@item @kbd{C-c C-o} +@tab Delete last batch of process output +@item @kbd{C-c C-r} +@tab Show last batch of process output +@item @kbd{C-c C-l} +@tab List input history +@end multitable + +In addition to these standard @file{comint} commands, +@code{idlwave-shell-mode} has some bindings which correspond to similar +commands in @code{idlwave-mode}. See @ref{Routine Info} and +@ref{Completion} for more information on these commands.@refill + +@cindex Completion in the shell +@cindex Routine info in the shell +@multitable @columnfractions .12 .88 +@item @kbd{@key{TAB}} +@tab Completion of file names, routine names and keywords +(@code{idlwave-shell-complete})@refill +@item @kbd{M-@key{TAB}} +@tab Same as @key{TAB} +@item @kbd{C-c ?} +@tab Routine Info display (@code{idlwave-routine-info}) +@item @kbd{M-?} +@tab IDL online help on routine (@code{idlwave-routine-info-from-idlhelp}) +@item @kbd{C-c C-i} +@tab Update routine info from buffers and shell +(@code{idlwave-update-routine-info}) +@item @kbd{C-c C-v} +@tab Find the source file of a routine (@code{idlwave-find-module}) +@item @kbd{C-c =} +@tab Compile a library routine (@code{idlwave-resolve}) +@end multitable + +@defopt idlwave-shell-file-name-chars +The characters allowed in file names, as a string. Used for file name +completion.@refill +@end defopt + +@node Debugging IDL Programs, , Using the Shell, The IDLWAVE Shell +@section Debugging IDL Programs +@cindex Debugging +@cindex Keybindings for debugging +@cindex Toolbar + +Programs can be compiled, run, and debugged directly from the source +buffer in Emacs. The IDLWAVE shell installs keybindings both in the +shell buffer and in all IDL code buffers of the current Emacs session. +On Emacs versions which support this, it also installs a debugging +toolbar. The display of the toolbar can be toggled with @kbd{C-c C-d +C-t} (@code{idlwave-shell-toggle-toolbar}).@refill + +The debugging keybindings are by default on the prefix key @kbd{C-c +C-d}, so for example setting a breakpoint is done with @kbd{C-c C-d +C-b}. If you find this too much work and your ALT key is still +available, turn on the variable +@code{idlwave-shell-activate-alt-keybindings} in order to get breakpoint +setting on @kbd{A-b}. In the remainder of this chapter we will assume +that the @kbd{C-c C-d} bindings are active. + +@defopt idlwave-shell-prefix-key +The prefix key for the debugging map +@code{idlwave-shell-mode-prefix-map}.@refill +@end defopt + +@defopt idlwave-shell-activate-prefix-keybindings (@code{t}) +Non-@code{nil} means, debug commands will be bound to the prefix +key, like @kbd{C-c C-d C-b}. +@end defopt + +@defopt idlwave-shell-activate-alt-keybindings (@code{nil}) +Non-@code{nil} means, debug commands will be bound to alternate +keys, like @kbd{A-b}. +@end defopt + +@defopt idlwave-shell-use-toolbar (@code{t}) +Non-@code{nil} means, use the debugging toolbar in all IDL related +buffers.@refill +@end defopt + + +@menu +* Compiling Programs:: Compiling buffers under the shell +* Breakpoints and Stepping:: Deciding where to stop and look +* Examining Variables:: What is the value now? +@end menu + +@node Compiling Programs, Breakpoints and Stepping, Debugging IDL Programs, Debugging IDL Programs +@subsection Compiling Programs +@cindex Compiling programs +@cindex Programs, compiling +@cindex Default command line, executing +@cindex Executing a default command line + +In order to compile the current buffer under the IDLWAVE shell, press +@kbd{C-c C-d C-c} (@code{idlwave-save-and-run}). This first saves the +current buffer and then send the command @samp{.run path/to/file} to the +shell. You can laso execute @kbd{C-c C-d C-c} from the shell buffer, in +which case the most recently compiled buffer will be saved and +re-compiled. + +When developing or debugging a program, it is often necessary to execute +the same command line many times. A convenient way to do this is +@kbd{C-c C-d C-y} (@code{idlwave-shell-execute-default-command-line}). +This command first resets IDL from a state of interrupted execution by +closing all files and returning to the main interpreter level. Then a +default command line is send to the shell. To edit the default command +line, call @code{idlwave-shell-execute-default-command-line} with a +prefix argument: @kbd{C-u C-c C-d C-y}.@refill + +@defopt idlwave-shell-mark-stop-line (@code{t}) +Non-@code{nil} means, mark the source code line where IDL is currently +stopped. The value decides about the preferred method. Legal values +are @code{nil}, @code{t}, @code{arrow}, and @code{face}.@refill +@end defopt + +@defopt idlwave-shell-overlay-arrow +The overlay arrow to display at source lines where execution +halts.@refill +@end defopt + +@defopt idlwave-shell-stop-line-face +The face which highlights the source line where IDL is +stopped.@refill +@end defopt + +@node Breakpoints and Stepping, Examining Variables, Compiling Programs, Debugging IDL Programs +@subsection Breakpoints and Stepping +@cindex Breakpoints +@cindex Stepping + +You can set breakpoints and step through a program with IDLWAVE. +Setting a breakpoint in the current line of the source buffer is done +with @kbd{C-c C-d C-b} (@code{idlwave-shell-break-here}). With a prefix +arg of 1, the breakpoint gets a @code{/ONCE} keyword, meaning that it +will be deleted after first use. With a numeric prefix greater than +one, the breakpoint will only be active the @code{nth} time it is hit. +To clear the breakpoint in the current line, use @kbd{C-c C-d C-d} +(@code{idlwave-clear-current-bp}). To clear all breakpoints, use +@kbd{C-c C-d C-a} (@code{idlwave-clear-all-bp}). Breakpoint lines are +highlighted in the source code.@refill + +Once the program has stopped somewhere, you can step through it. Here +is a summary of the breakpoint and stepping commands: + +@multitable @columnfractions .2 .8 +@item @kbd{C-c C-d C-b} +@tab Set breakpoint (@code{idlwave-shell-break-here}) +@item @kbd{C-c C-d C-i} +@tab Set breakpoint in function named here (@code{idlwave-shell-break-in}) +@item @kbd{C-c C-d C-d} +@tab Clear current breakpoint (@code{idlwave-shell-clear-current-bp}) +@item @kbd{C-c C-d C-a} +@tab Clear all breakpoints (@code{idlwave-shell-clear-all-bp}) +@item @kbd{C-c C-d C-s} +@tab Step, into function calls (@code{idlwave-shell-step}) +@item @kbd{C-c C-d C-n} +@tab Step, over function calls (@code{idlwave-shell-stepover}) +@item @kbd{C-c C-d C-k} +@tab Skip one statement (@code{idlwave-shell-skip}) +@item @kbd{C-c C-d C-u} +@tab Continue to end of block (@code{idlwave-shell-up}) +@item @kbd{C-c C-d C-m} +@tab Continue to end of function (@code{idlwave-shell-return}) +@item @kbd{C-c C-d C-o} +@tab Continue past end of function (@code{idlwave-shell-out}) +@item @kbd{C-c C-d C-h} +@tab Continue to line at cursor position (@code{idlwave-shell-to-here}) +@item @kbd{C-c C-d C-r} +@tab Continue execution to next breakpoint (@code{idlwave-shell-cont}) +@item @kbd{C-c C-d C-up} +@tab Show higher level in calling stack (@code{idlwave-shell-stack-up}) +@item @kbd{C-c C-d C-down} +@tab Show lower level in calling stack (@code{idlwave-shell-stack-down}) +@end multitable + +@defopt idlwave-shell-mark-breakpoints (@code{t}) +Non-@code{nil} means, mark breakpoints in the source file buffers. The +value indicates the preferred method. Legal values are @code{nil}, +@code{t}, @code{face}, and @code{glyph}. +@end defopt + +@defopt idlwave-shell-breakpoint-face +The face for breakpoint lines in the source code if +@code{idlwave-shell-mark-breakpoints} has the value @code{face}.@refill +@end defopt + +@node Examining Variables, , Breakpoints and Stepping, Debugging IDL Programs +@subsection Examining Variables +@cindex @code{PRINT} expressions +@cindex @code{HELP}, on expressions +@cindex Expressions, printing +@cindex Expressions, help +@cindex Mouse binding to print expressions + +When execution is stopped you can examine the values of variables. The +command @kbd{C-c C-d C-p} prints the expression at point in the shell +buffer, while @kbd{C-c C-d ?} shows help on this expression. The +expression at point is an array expression or a function call, or the +contents of a pair of parenthesis. The selected expression becomes +highlighted in the source code for a short time. + +I find it very convenient to bind these functions to a mouse event, so +that simply clicking on an expression prints its value. Here is a way +to do this with XEmacs: + +@lisp +(add-hook 'idlwave-shell-mode-hook + (lambda() + (define-key idlwave-mode-map [(shift button1)] + 'idlwave-shell-mouse-print) + (define-key idlwave-mode-map [(shift button2)] + 'idlwave-shell-mouse-help))) +@end lisp + +@defopt idlwave-shell-expression-face +The face for @code{idlwave-shell-expression-overlay}. +Allows you to choose the font, color and other properties for +the expression printed by IDL. +@end defopt + + +@node Installation, Acknowledgement, The IDLWAVE Shell, Top +@chapter Installation +@cindex Installation +@cindex FTP site +@cindex URL, homepage for IDLWAVE +@cindex Homepage for IDLWAVE + +@menu +* Installing IDLWAVE:: How to install the distribution +* Upgrading from idl.el:: Necessary configuration changes +@end menu + +@node Installing IDLWAVE, Upgrading from idl.el, Installation, Installation +@section Installing IDLWAVE + +IDLWAVE is part of Emacs 21.1 and later. It is also@footnote{or will be +soon} an XEmacs packages and can be installed from +@uref{ftp://ftp.xemacs.org/pub/xemacs/packages/,the XEmacs ftp site} +with the normal package management system on XEmacs 21.@refill + +You can also download IDLWAVE and install it yourself from +@uref{http://www.strw.leidenuniv.nl/~dominik/Tools/idlwave, the maintainers +webpage}. Follow the instructions in the INSTALL file.@refill + +@node Upgrading from idl.el, , Installing IDLWAVE, Installation +@section Upgrading from the old @b{@file{idl.el}} file +@cindex Upgrading from old @b{@file{idl.el}} +@cindex Renaming old variables +@cindex Old variables, renaming + +If you have been using the old @file{idl.el} and @file{idl-shell.el} +files and would like to use IDLWAVE, you need to update your +customization in @file{.emacs}. + +@enumerate +@item +Change all variable and function prefixes from @samp{idl-} to @samp{idlwave-}. +@item +Remove the now invalid @code{autoload} and @code{auto-mode-alist} forms +pointing to the @file{idl.el} and @file{idl-shell.el} files. +@item +If you have been using the hook function recommended in earlier versions +to get a separate frame for the IDL shell, remove that command from your +@code{idlwave-shell-mode-hook}. Instead, set the variable +@code{idlwave-shell-use-dedicated-frame} with +@lisp +(setq idlwave-shell-use-dedicated-frame t) +@end lisp +@end enumerate + +@node Acknowledgement, Sources of Routine Info, Installation, Top +@chapter Acknowledgement +@cindex Acknowledgement +@cindex Thanks + +@file{idl.el} and @file{idl-shell.el} were written by +@uref{mailto:chase@@att.com, Chris Chase}. The package +was extended and renamed to IDLWAVE by the current maintainer +@uref{mailto:dominik@@strw.leidenuniv.nl, Carsten Dominik}. + +Thanks to the following people who have contributed to the development +of IDLWAVE with patches, ideas, bug reports and suggestions. + +@itemize @minus +@item +Ulrik Dickow +@item +Eric E. Dors +@item +Stein Vidar H. Haugan +@item +David Huenemoerder +@item +Kevin Ivory +@item +Xuyong Liu +@item +Simon Marshall +@item +Laurent Mugnier +@item +Lubos Pochman +@item +Patrick M. Ryan +@item +Marty Ryba +@item +Phil Williams +@item +J.D. Smith +@item +Phil Sterne +@end itemize + +@node Sources of Routine Info, Configuration Examples, Acknowledgement, Top +@appendix Sources of Routine Info + +In @ref{Routine Info} and @ref{Completion} it was shown how IDLWAVE +displays the calling sequence and keywords of routines, and how it +completes routine names and keywords. For these features to work, +IDLWAVE must know about the accessible routines. + +@menu +* Routine Definitions:: Where IDL Routines are defined. +* Routine Information Sources:: So how does IDLWAVE know about... +* Library Scan:: Scanning the Libraries for Routine Info +* Updating idlwave-rinfo.el:: Scanning the IDL Manuals +@end menu + +@node Routine Definitions, Routine Information Sources, Sources of Routine Info, Sources of Routine Info +@section Routine Definitions +@cindex Routine definitions + +Routines which can be used in an IDL program can be defined in several +places: + +@enumerate +@item +@emph{System routines} are defined inside IDL itself. The source +code of such routines is not accessible to the user.@refill +@item +Routines @emph{part of the current program} are defined in a file which +is explicitly compiled by the user. This file may be located on the IDL +search path, but this is not certain.@refill +@item +@emph{Library routines} are defined in special files which are located +somewhere on IDL's search path. When a library routine is called for +the first time, IDL will find the source file and compile it +dynamically.@refill +@item +External routines written in other languages (like Fortran or C) can be +called with @code{CALL_EXTERNAL}, linked into IDL via @code{LINKIMAGE}, +or included as dynamically loaded modules (DLMs). Currently IDLWAVE +cannot provide routine info and completion for external +routines.@refill +@end enumerate + +@node Routine Information Sources, Library Scan, Routine Definitions, Sources of Routine Info +@section Routine Information Sources +@cindex Routine info sources + +In oder to know about as many routines as possible, IDLWAVE will do the +following to collect information:@refill + +@enumerate + +@item +It has a @emph{builtin list} with the properties of the builtin IDL +routines. IDLWAVE @value{VERSION} is distributed with a list of +@value{NSYSROUTINES} routines and @value{NSYSKEYWORDS} keywords, +reflecting IDL version @value{IDLVERSION}. This list has been created +by scanning the IDL manuals and is stored in the file +@file{idlwave-rinfo.el}. @xref{Updating idlwave-rinfo.el}, for +information how to regenerate this file for new versions of IDL.@refill + +@item +It @emph{scans} all @emph{buffers} of the current Emacs session for +routine definitions. This is done automatically when routine +information or completion is first requested by the user. The command +@kbd{C-c C-i} (@code{idlwave-update-routine-info}) can be used at any +time to rescan all buffers.@refill + +@item +If you have an IDLWAVE-Shell running as inferior process of the current +Emacs session, IDLWAVE will @emph{query the shell} for compiled routines +and their arguments. This happens automatically when routine +information or completion is first requested by the user. The command +@kbd{C-c C-i} (@code{idlwave-update-routine-info}) can be used to ask +the shell again at any time.@refill + +@item +IDLWAVE can scan all or selected library files and store the result in a +file which will be automatically loaded just like +@file{idlwave-rinfo.el}. @xref{Library Scan}, for information how to +scan library files.@refill +@end enumerate + +@defopt idlwave-scan-all-buffers-for-routine-info (@code{t}) +Non-@code{nil} means, scan all buffers for IDL programs when updating +info. When this variable is @code{nil}, it only parses the current +buffer.@refill +@end defopt + +@defopt idlwave-query-shell-for-routine-info (@code{t}) +Non-@code{nil} means query the shell for info about compiled routines. +@end defopt + + +@node Library Scan, Updating idlwave-rinfo.el, Routine Information Sources, Sources of Routine Info +@section Library Scan +@cindex Library scan +@cindex IDL library routine info + +IDLWAVE can extract routine information from library modules and store +that information in a file. To do this, the variable +@code{idlwave-libinfo-file} needs to contain the path to a file in an +existing directory (e.g. @code{"~/idlwave_libinfo.el"}). Since the file +will contain lisp code, it should end in @file{.el}. Under Windows and +MacOS, you also need to specify the search path for IDL library files in +the variable @code{idlwave-library-path}. Under UNIX, this path will +be automatically inferred from an IDLWAVE shell.@refill + +The command @kbd{M-x idlwave-create-libinfo-file} can then be used to +scan library files. It brings up a widget in which you can select some +or all directories on the search path. Pressing the @w{@samp{[Scan & Save]}} +button in the widget will scan all files in the selected directories and +write the resulting routine information into the file +@code{idlwave-libinfo-file}. In order to update the library information +from the same directories, call the command +@code{idlwave-update-routine-info} with a double prefix argument: +@kbd{C-u C-u C-c C-i}. This will rescan files in the previously +selected directories, write an updated version of the libinfo file and +rebuild IDLWAVEs internal lists.@refill + +A note of caution: Depending on your local installation, the IDL +library can be very large. Parsing it for routine information will take +time and loading this information into Emacs can require a +significant amount of memory.@refill + +A routine which is both in the library listing and compiled under the +shell will show up twice in the @file{*Completions*} listing. This is +usually not a serious problem. However, if you have scanned the part of +the library relevant for you, and if you are not compiling files which +are not on the library search path, the information about compiled +routines is in fact unnecessary. In this case, you can turn of the +shell query for compiled routines with the variable +@code{idlwave-query-shell-for-routine-info}.@refill + +@defopt idlwave-libinfo-file +File for routine information of the IDL library. +@end defopt + +@defopt idlwave-library-path +IDL library path for Windows and MacOS. Not needed under Unix. +@end defopt + + +@node Updating idlwave-rinfo.el, , Library Scan, Sources of Routine Info +@section Updating @file{idlwave-rinfo.el} +@cindex @file{get_rinfo} +@cindex @file{idlwave.rinfo.el} +@cindex Perl program, to create @file{idlwave.rinfo.el} + +The file @file{idlwave-rinfo.el} contains the routine information for +the routines build into IDL. This constant depends upon the version of +IDL. If you are lucky, the maintainer of IDLWAVE will always have +access to the newest version of IDL and provide updates of +@file{idlwave-rinfo.el} reflecting the currently released version of +IDL. The IDLWAVE package also contains a Perl program @file{get_rinfo} +which constructs this file by scanning selected files from the IDL +documentation. The program needs @file{pdftotext} by Derek B. Noonburg. +Instructions on how to use @file{get_rinfo} are in the program +itself.@refill + +@node Configuration Examples, Index, Sources of Routine Info, Top +@appendix Configuration Examples +@cindex Configuration examples +@cindex Example configuration + +@noindent +@b{Question:} So now you have all these complicated configuration +options in your package, but which ones do @emph{you} as the maintainer +actually set in your own configuration? + +@noindent +@b{Answer:} Hardly any. As the maintainer, I set the default of all +options to what I think is best. However, I do not turn on features by +default which +@itemize @minus +@item +are not self-evident (i.e. too magic) when used by an unsuspecting user +@item +are too intrusive +@item +will not work properly on all Emacs installations out there +@item +break with what I think are widely used standards. +@end itemize + +@noindent To see what I mean, here is the entire configuration I have in +my @file{.emacs}: + +@lisp +(setq idlwave-shell-activate-alt-keybindings t + idlwave-expand-generic-end t + idlwave-store-inquired-class t + idlwave-shell-automatic-start t + idlwave-libinfo-file "~/lib/idl/libinfo.el" + idlwave-main-block-indent 2) +(add-hook 'idlwave-shell-mode-hook + (lambda() + (define-key idlwave-mode-map [(shift button1)] + 'idlwave-shell-mouse-print) + (define-key idlwave-mode-map [(shift button2)] + 'idlwave-shell-mouse-help))) +@end lisp + +However, if you are an Emacs power-user and want IDLWAVE to work +completely differently, the options allow you to change almost every +aspect of it. Here is an example of a much more extensive configuration +of IDLWAVE. To say it again - this is not what I recommend, but the +user is King!@refill + +@example +;;; Settings for IDLWAVE mode + +(setq idlwave-block-indent 3) ; Indentation settings +(setq idlwave-main-block-indent 3) +(setq idlwave-end-offset -3) +(setq idlwave-continuation-indent 1) +(setq idlwave-begin-line-comment "^;[^;]") ; Leave ";" but not ";;" + ; anchored at start of line. +(setq idlwave-surround-by-blank t) ; Turn on padding ops =,<,> +(setq idlwave-pad-keyword nil) ; Remove spaces for keyword '=' +(setq idlwave-expand-generic-end t) ; convert END to ENDIF etc... +(setq idlwave-reserved-word-upcase t) ; Make reserved words upper case + ; (with abbrevs only) +(setq idlwave-abbrev-change-case nil) ; Don't force case of expansions +(setq idlwave-hang-indent-regexp ": ") ; Change from "- " for auto-fill +(setq idlwave-show-block nil) ; Turn off blinking to begin +(setq idlwave-abbrev-move t) ; Allow abbrevs to move point + +;; Some setting can only be done from a mode hook. Here is an example: + +(add-hook 'idlwave-mode-hook + (lambda () + (setq abbrev-mode 1) ; Turn on abbrevs (-1 for off) + (setq case-fold-search nil) ; Make searches case sensitive + ;; Run other functions here + (font-lock-mode 1) ; Turn on font-lock mode + (idlwave-auto-fill-mode 0) ; Turn off auto filling + ;; + ;; Pad with with 1 space (if -n is used then make the + ;; padding a minimum of n spaces.) The defaults use -1 + ;; instead of 1. + (idlwave-action-and-binding "=" '(idlwave-expand-equal 1 1)) + (idlwave-action-and-binding "<" '(idlwave-surround 1 1)) + (idlwave-action-and-binding ">" '(idlwave-surround 1 1 '(?-))) + (idlwave-action-and-binding "&" '(idlwave-surround 1 1)) + ;; + ;; Only pad after comma and with exactly 1 space + (idlwave-action-and-binding "," '(idlwave-surround nil 1)) + ;; + ;; Set some personal bindings + ;; (In this case, makes `,' have the normal self-insert behavior.) + (local-set-key "," 'self-insert-command) + ;; Create a newline, indenting the original and new line. + ;; A similar function that does _not_ reindent the original + ;; line is on "\C-j" (The default for emacs programming modes). + (local-set-key "\n" 'idlwave-newline) + ;; (local-set-key "\C-j" 'idlwave-newline) ; My preference. + )) + +;;; Settings for IDLWAVE SHELL mode + +(setq idlwave-shell-overlay-arrow "=>") ; default is ">" +(setq idlwave-shell-use-dedicated-frame t) ; Make a dedicated frame +(setq idlwave-shell-prompt-pattern "^WAVE> ") ; default is "^IDL> " +(setq idlwave-shell-explicit-file-name "wave") +(setq idlwave-shell-process-name "wave") +(setq idlwave-shell-use-dedicated-frame t) ; Shell on separate frame +(setq idlwave-shell-use-toolbar nil) ; No toolbar +@end example + +@node Index, , Configuration Examples, Top +@unnumbered Index +@printindex cp + +@summarycontents +@contents +@bye +