Editor
These options define the appearance of the Perl Editor , the coloring
of the Perl source code and how annotations are displayed.
Source Formatter
EPIC uses PerlTidy to format source code. The Source Formatter
Preference allows to specify PerlTidy command line parameters. To get a
description of available parameters, press the Help key and select 
PerlTidy
options from the popup menu.
NOTE: In order for PerlTidy to work correctly the Perl
Interpreter Preferences have to be setup correctly (see above). 
Templates
Templates are a powerful tool to insert pre defined code snippets while
working with the  Perl Editor.
 
How Templates are use is covered in 
Working with
the Perl Editor. The Templates Preference page allows the creation,
import and export of Templates.
On export Templates are stored in XML format.
Associating Files
with the Perl
editor
Eclipse file extension are associated with an editor. If another
plug-in is installed the EPIC Perl Editor might not be used as standard
editor when opening *.pl, *.pm or *.cgi files.
To associate these file extensions with the Perl Editor choose 
Window
> Preferences from the Eclipse menu and select 
Workbench
> File Associations.
If the Perl extensions are missing they can be created by pressing the 
Add...
button.
Select the Perl Editor from the list and press the 
Default
button.
CVS Setup
On default Eclipse stores Perl files as binary when they are added to
the CVS repository.
To store Perl files as text (ASCII) select 
Window >
Preferences... from the Eclipse menu and modify the 
Team >
File Content settings.
Add your Perl extensions (pl, pm etc.) by pressing the 
Add...
button and specify 
ASCII in the 
Contents column.
Setting up the Debugger
Setting up the debugger requires two steps:
  - Define the Perl interpreter to use
  
- Install the PadWalker Perl module
 NOTE: It is possible to use the debugger without installing PadWalker.
But in this case local variables won't be shown.
 Download the PadWalker module from CPAN 
(PadWalker
0.10) and install as described in the installation notes or use the
installation manager provided with your Perl installation (e.g. PPM for
ActiveState installations).
 If you are using ActiveState 5.8.x on Windows system you can download a
pre-compiled PadWalker module from the EPIC homepage as the
version provided by ActiveState doesn't seem to work for Perl 5.8.x
(but it does for 5.6.x).
 
Perl Projects
Creating a Project
Perl projects are created (like any other Project) by selecting 
File
> New > Project... from the Eclipse menu.
 
After following the instructions of the wizard the
Perl Project will be created. In the Navigator the Perl folder icon 

is assigned to Perl Projects.
Perl Include Path
To expand the Perl Include Path (@INC) right click on the project icon
and select 
Properties...
Converting an existing
Project
To add the Perl Nature to an existing Project, select the Project in
the Navigator and select 
Add Perl Nature from the dropdown menu.
 
To remove a Perl Nature form a project, select a Perl
project and select 
Remove Perl Nature form the popup menu.
Eclipse Basics
Perspectives
Each Workbench window contains one or more
perspectives. A perspective defines the initial set and layout of views
in the Workbench window. Within the window, each perspective shares the
same set of editors. Each perspective provides a set of capabilities
aimed at accomplishing a specific type of task or works with specific
types of resources. For example, the Java perspective combines
views that you would commonly use while editing Java source files,
while the Debug perspective contains the views that you would use while
debugging Java programs. As you work in the Workbench, you will
probably switch perspectives frequently.
Perspectives control what appears in
certain menus and toolbars. They define visible action sets,
which you can change to customize a perspective. You can save a
perspective that you build in this manner, making your own custom
perspective that you can open again later.  
You can set your Workbench preferences to
open perspectives in the same window or in a new window.
The main perspectives perspectives for developing Perl applications are

 : This is the main view for
coding  Perl
scripts

 : Provides the main
functionally for
debugging
and executing Perl scripts. For details see 
Debug
Perspective .
Views
Views support editors and provide
alternative presentations as well as ways to navigate the information
in your Workbench.  For example, the Navigator view displays
projects and other resources that you are working with.
Views also have their own menus. To open
the menu for a view, click the icon at the left end of the view's title
bar. Some views also have their own toolbars. The actions represented
by buttons on view toolbars only affect the items within that
view. 
A view might appear by itself, or stacked
with other views in a tabbed notebook. You can change the layout
of a perspective by opening and closing views and by docking them in
different positions in the Workbench window. 
Using Perspectives
 
New perspectives
There are several ways to open a new perspective within
this Workbench window:
  -  Using the Open Perspective button  on the shortcut bar. on the shortcut bar.
-  Choosing a perspective from the Window > Open Perspective
menu. 
To open one by using the shortcut bar button:
  - 
    Click on the Open Perspective button  . .
 
- 
    A menu appears showing the same choices as shown on
the Window > Open Perspective menu. Choose Other
from the menu. 
        
 
 
- 
    In the Select Perspective dialog choose Debug
and click OK.   
        
 
 The Debug perspective is displayed.   
- 
    There are several other interesting things to take
note of.   
      - 
        The title of the window now indicates that the
Debug perspective is in use.   
- 
        The shortcut bar contains several perspectives,
the original Resource perspective, the new Debug perspective and a few
others. The Debug perspective button is pressed in, indicating
that it is the current perspective.  
- 
        To disply the full name of the perspective
right click the perspective bar and check Show Text.
   
 
 
- 
    In the shortcut bar, click on the Resource
perspective button. The Resource perspective is once again the current
perspective. Notice that the set of views is different for each of the
perspectives. 
 
 
Configuring perspectives
In addition to configuring the layout of a perspective you can also
control several other key aspects of a perspective. These include:
  -  The New menu.
-  The Window > Open Perspective menu.
-  The Window > Show View menu.
-  Action sets that show up on the toolbar.
Try customizing one of these items. 
  - 
    In the shortcut bar click on the Resource
perspective.  
- 
    Select Window > Customize Perspective...
     
- 
    Select the Commands tab.  
- Check Launch and click OK.
    
        
 
 
- Observe that the toolbar now includes buttons for debug/run
launching.
    
        
 
 
- 
    After experimenting with the other options on the
Customize Perspective dialog, choose Window > Reset Perspective
to return the perspective to its original state.   
Saving a user defined perspective
If you have modified a perspective by adding, deleting, or moving
(docking) views, you can save your changes for future use. 
  - Switch to the perspective that you want to save. 
- Click Window > Save Perspective As. 
- Type a new name for the perspective into the Name field. 
- Click OK. 
 
Resetting perspectives
To restore a perspective to its original layout:
  - Click Window > Preferences. 
- Expand Workbench and choose Perspectives. 
- From the Available perspectives list, select the
perspective you want to restore. 
- Click Reset. 
- Click OK.
Using views
Opening views
Perspectives offer pre-defined combinations of views and editors. To
open a view that is not included in the current perspective, select Window
> Show View from the main menu bar. 
You can create fast views to provide a shortcut to views
that you use often. 
After adding a view to the current perspective, you may wish to save
your new layout by clicking Window > Save Perspective As. 
Moving and docking views
To change the location of a view in the current perspective: 
  - Drag the view by its title bar. Do not release the left mouse
button yet. 
- As you move the view around the Workbench, the mouse pointer
changes to one of the drop cursors shown in the table below.
The drop cursor indicates where the view will be docked if you release
the left mouse button. To see the drop cursor change, drag the view
over the left, right, top, or bottom border of another view or editor. 
- When the view is in the location that you want, relative to the
view or editor area underneath the drop cursor, release the left mouse
button. 
- (Optional) If you want to save your changes, select Window
> Save Perspective As from the main menu bar. 
- Note that a group of stacked views can be dragged using the empty
space to the right of the view tabs.
Working with the Perl Editor
Syntax Check
EPIC performs on the fly syntax check of Perl source
files. In order for the Syntax Check to work the Perl Interpreter has
to be set up correctly (see 
Setting up Preferences). 
The Syntax Check is performed after a defined idle period, after the
user has stopped typing. This idle period can be configured in the
preferences.
When an error/warning has been found the editor
displays the appropriate icon in the annotation ruler (the gray bar on
the left side of the editor), underlines the error in the source and
inserts a marker into the Problems View window.
 
Explain Errors and Warnings
In addition to displaying warnings and errors the editor is capable of
explaining Errors and Warnings.
To get an Error/Warning explanation right-click the Error/Warning icon
and select Explain 
Errors/Warnings from the dropdown menu.
The explanation(s) will be displayed in the 
Explain Errors/Warnings
View.
Perldoc
To retrieve perldoc information select a keyword or text and choose one
of the perldoc options from the context menu.
If nothing is selected an input box will pop up.
If a perldoc entry is found it is displayed inside the 
Perldoc View.
NOTE: Perldoc has to be installed available in the system PATH,
otherwise this feature will not work.
 
Quick Reference
Apart from Perldoc support a quick reference feature is available. This
feature has the advantage that no perldoc has to be installed on the
system but does not provide as many information as perldoc.
To view the Quick Reference select a keyword and move the mouse pointer
over the selection.
A tooltip with a short description of the keyword should appear.
Code Assist
Code Assist features try to assist the user during source code editing.
NOTE: The features currently implemented in EPIC may not be
fully functional but will be improved in the future.
Variable Inspection
When pressing one of the auto completion characters 
$ @ % the
editor displays all defined variables in a list. From the list the user
can select the variable that should be inserted in the source code.
Module Inspection
The editor tries to display methods available in modules when the auto
completion characters 
> or
 : are pressed.
NOTE:
Currently the
Indirect  Object Invocation is not recognized by code assist.
This code block will not work:
$smtp = new Net::SMTP;
$smtp->[no content assist]
 
This one will
work:
 
$smtp =
Net::SMTP->new(.....);
$smtp->[content assist]
TODO Markers
TODO Markers are a very convenient way to add  todos to the
Eclipse task list.
A TODO marker is generated when a 
#TODO any text
is found in the Perl source code.
On deletion of the 
#TODO comment, the 
TODO Marker
is also deleted.
Templates
Templates allow for easy insertion of predefined text segments. In
addition to normal text these segments can also include pre-defined
variables that are included at runtime as well as variables that are
specified by the user when the template is inserted.
Defining Templates
Templates are defined in the EPIC Preferences (
Window >
Preferences...).
To define a new template press the 
New... button.
To insert pre-defined variables press the 
Insert Variable...
button.
 
In addition to pre-defined variables the user can
specify additional variables ( using the syntax ${varname} )
which can be edited
when the template is inserted. When the first variable is inserted
variables with the same name will automatically be changed.
Using Templates
Templates are invoked by typing some characters and pressing 
Ctrl+Space.
Templates matching the typed characters will be displayed in a list. A
preview is also available.
If the template contains user defined variables the user can press the 
TAB
key to jump to the next variable after the template has been inserted.
Source Formatter
EPIC uses PerlTidy for source code formatting (PerlTidy is included in
the EPIC package).
To format the source code select S
ource > Format from the
Eclipse menu or use 
Ctrl+shift+f.
PerlTidy settings can be changed in the
 Source Formatter
preference page.
NOTE: Source formatting might take a while if the source code
has a lot of lines.
HTML Export
To export select Source > Export > HTML from the Eclipse menu and
specify an output file.
HTML export settings can be changed in the
 Source Formatter
preference page.
NOTE: For HTML export to work a working 
Source Formatter
is needed.
Outline View
The Outline View displays modules and subroutines. By clicking on the
module/subroutine name the editor will jump to the appropriate position
in the source code.
Subroutines named 
new will get a different icon.
Using the Perl Debugger
Launching Perl Programs
You may launch your Perl programs from the workbench.  Programs
may be launched in either run or debug mode.
  - In run mode, the program executes, but may not be
suspended or examined. 
- In debug mode, execution may be suspended and resumed, variables
may be inspected, and expressions may be evaluated. 
The environment a Perl program is to be executed in is defined via
"Launch Configurations". A launch configuration defines 
  - if the program is to be executed in a CGI or normal Perl
environment
- the host the program is to be executed on
 
- the program to execute
- execution parameters to pass
- environment variables (for CGI environment)
- configuration data  for the WEB server used to provide the
CGI framework
Launching Perl programs in run mode
 
  - Select Menu->Run
- Within the dialog appearing 
 select the configuration type:
 Perl(local): Run a Perl script on the local machine
 Perl-CGI(local): Run Perl programs in a CGI environment
 Perl(remote): Run Perl script on a remote machine
 and press the new button to create a new launch configuration.
 
- Adjust  launch configuration attributes. For details see Configuring
Launch Configurations   . 
 
- Press the "Run" Button
This executes the program. The programs console output will  be
shown in the console window. The console window also accepts keyboard
input to be passed to the program.
If you switch to the debug view you have additional control over the
execution of the program. For details see 
Debug
View .
Launching Perl Programs in debug mode
 
Before debugging a program you may want to set break points to stop
program execution at certain source code locations. For details see 
Debug
View .
  - Select Menu->Debug
- Within the dialog appearing 
 select the configuration type:
 Perl(local): Run a Perl script on the local machine
 Perl-CGI(local): Run Perl programs in a CGI environment
 Perl(remote): Run Perl script on a remote machine
 and press the new button to create a new launch configuration.
 
- Adjust  launch configuration attributes. For details see
  
. 
 
- Press the "Debug" Button
If you switch to the debug view you have additional control over the
execution of the program. For details see 
Debug
View .
Re-launching a Perl Program 
The workbench keeps a history of each launched and debugged program.
To relaunch a program, do one of the following: 
  - Select a previous launch from Run or Debug
button pull-down menus. 
- From the menu bar, select Run > Run
History or Run > Debug History
and select a previous launch from these sub-menus. 
- In the Debug view, select a process that you want to relaunch,
and select Relaunch from the process's pop-up menu. 
To relaunch the most recent launch, do one of the following: 
  - Click the Run or Debug
buttons (without using the button pull-down menu). 
- Select Run > Run Last Launched
(Ctrl+F11), or Run > Debug
Last Launched (F11) from the workbench menu bar.
 
Configuring Launch
Configurations
Perl(local): Running a Perl script on the local machine
 
  - Enter the name for the launch configuration in they "Name" field.
- In the "Configuration" tab
 "Project" field: select the project to debug.
 Note: Only Perl projects (projects associated with a Perl nature) will
be shown. If the project you require isn't shown see Converting an existing
Project  for adding a Perl nature to your project.
 "File to execute" field: select the Perl file to execute.
 Note: Only files associated with the Perl editor will be shown. See Associating Files with
the Perl
editor for details.
 "Commadline Parameters" field: Enter command line parameters
to
pass to the selected perl script
- Press the "Apply" button
Perl-CGI(local): Run Perl programms in a CGI environment
 
  - Enter the name for the launch configuration in they "Name" field.
  
- In the "Web Server" tab
 "HTML Root Directory" Field: Enter the base directory that
contains all HTML files or use the "Browse" button to select the
appropriate directory.
 "HTML Startup File" Field: Enter the file name to be shown
in
the browser after startup or use  the "Browse" button to select
this file.
 "CGI Root Directory" Field: Enter the base directory that
contains all CGI files or use the "Browse" button to select the
appropriate directory.
 "Extension for CGI files" Field: this is
a comma separated list of
file extensions (each starting with a  "." ) used  for
CGI  files in the project.
- In the "CGI Environment" tab
 CGI-Script Environment Variables Field: Sorted  list of environemt
vailables to be set  for CGI scripts to be excuted. Use the
following syntax to specify environment variables: name=value.
- In the "Browser" tab
 There are two possible settings:
 Select "Custom Browser":
 specify the path to the browser executable and add the required
command line parameters. Use "%1" as a place holder for the HTML file
to be opened.
 Select "Default System Browser":
 to use the browser defined as default browser by your OS
preferences.
- Press the "Apply" button
Perl(remote): Run Perl script on a remote machine
----Not yet implemented----
 Break Points
The Perl debugger supports 
line break points and 
regular
expression breakpoints. Both types of  breakpoints are set on
an executable line of a program. If enabled they suspend thread
execution before
the corresponding line of code is executed. Regular expression
breakpoints
additionally extract the regular expression contained in the line of
code they are associated with and enable you to debug the regular
expression within the 
RegEx-Plugin. 
The following symbols are used to indicate breakpoints :
  
    
      | Status 
 | Line Break Point
 
 | Regular
Expression Break Point
 
 | 
    
      | Enabled 
 |  
 |  
 | 
    
      | Disabled 
 |  
 |  
 | 
    
      | Registered with debugger 
 |  
 |  
 | 
  
Note: 
Regular Expressions Break Points are still in an experimental state and
will at the
moment only work for expressions of the type:
Expr1 =~ <delim>regexp<delim>modifier;
Modifiers are ignored.
Setting Break Points
  - In the editor area, open the file where you want to add the
breakpoint with the Perl editor.  
-  Directly to the left of the line where you want to add the
breakpoint, open the marker bar (vertical ruler) pop-up menu and select
    Add Breakpoint or Add RegExp Breakpoint. 
While the breakpoint is enabled, thread execution suspends before
that line of code is executed.
Enabling or  Disabling  Break Points
Open the debug view, open the 
breakpoint
view 
and use the check box in
front of the break point to enable or disable the break point.
Removing Break Points
There are two possible ways for removing a  breakpoint:
  - Right click on the breakpoint symbol in marker the bar (vertical
ruler) of the editor pop-up menu and select Remove Breakpoint.
- Open the debug view, open the breakpoint window (if this window
is not visible see Adding
and
Removing views ), right-click the breakpoint you want to remove and
select Remove.
 
Views in the Debug Perspective
Debug View

This view allows you to manage the debugging or running of 
programs in
the workbench. It displays the stack frame for the suspended threads
for each target you are debugging. Each thread in your program appears
as a node in the tree. It also displays the process for each target you
are
running.
If the thread is suspended, its stack frames are shown as child
elements.
Variable View
 
When a stack frame is selected, you can see the visible variables in
that
stack frame in the Variables view.
The Variables view shows the value of primitive types. 
Complex variables can be examined by expanding them to show their
members.
Global variables (including Perl internal variables) are marked with
an  icon,  local variables with an
icon,  local variables with an  icon.
icon.
If the value of a variable has changed since the last execution step
it is
displayed in red.
If changes in inner levels of complex  variables have occurred the
path to the changed variables is indicated via  delta symbols:

This makes it possible to see these kind of changes even if variables
are collapsed.
Customizing the Variables View
You can customize the presentation with the configuration menu.
 Show detail pane
To show the detail pane select  "Vertical View Orientation" or
"Horizontal View Orientation" .  Select "Variables View Only" to
disable it.
The details pane shows the value of 
primitive variables (especially useful for string variables).
Select Variables to display
The variables view allows to select the following types of
variables for displaying by checking the corresponding menu entry:
  - Perl internal Variables
 these are variables provided by the Perl interpreter like $_, %INC
etc. .
 
- Global Variables
 Variables visible from every where in your program.
- Local variables
 more correctly called "lexical" variables in Perl. Variables declared
with my .
 To show lexical variables you need to install
the Perl PadWalker module. The PadWalkers module has some problems
which influence
viewing of local variables.
 
Breakpoint View
 
The breakpoint views shows all breakpoints, their state (see 
Break
Points) and location. 
By selecting one ore more break points and invoking the context menu
you can enable, disable or remove these break points.
Perl Expression View
 
The Perl Expression View allows you to execute any valid Perl code
within the current context of the program executed in debug mode.
  - Open the Perl Debug View  (Window->Open
View->Other->Epic->Perl Expression View)
- Enter the code to execute
- Press the  symbol symbol
 
Stepping through the execution of a Perl program 
When a thread is suspended, the step controls can be used to step
through the execution of the program line-by-line. If a breakpoint is
encountered while performing a step operation,  the execution will
suspend at the breakpoint and the step operation is ended. 
Step over 
  - Select a stack frame in the Debug view. The current line of
execution in that stack frame is highlighted in the editor in the Debug
perspective. 
- Click the Step Over button ( )
in the
Debug view
toolbar, or press the F6 key. The currently-selected line
is executed and suspends on the next executable line. )
in the
Debug view
toolbar, or press the F6 key. The currently-selected line
is executed and suspends on the next executable line.
Step into 
  - Select a stack frame in the Debug view. The current line of
execution in the selected frame is highlighted in the editor in the
Debug perspective. 
- Click the Step Into ( ) button in
the Debug view
toolbar, or press the F5 key. The next expression on the
currently-selected line to be executed is invoked, and execution
suspends at the next executable line in the method that is invoked. ) button in
the Debug view
toolbar, or press the F5 key. The next expression on the
currently-selected line to be executed is invoked, and execution
suspends at the next executable line in the method that is invoked.
Run to return 
  - Select a stack frame in the Debug view. The current line of
execution in the selected frame is highlighted in the editor in the
Debug perspective. 
- Click the Run to Return button ( )
in the Debug
view toolbar or press the F7 key. Execution resumes until
the next return statement in the current method is executed, and
execution suspends on the next executable line. )
in the Debug
view toolbar or press the F7 key. Execution resumes until
the next return statement in the current method is executed, and
execution suspends on the next executable line.
RegExp Plugin
Enabling the RegExp View
To display the R
egExp View select 
Window > Show View..
> Other... from the Eclipse menu and select the 
RegExp View
from the list.
Using the RegExp Plugin
The RegExp plugin is a small tool to debug Regular Expressions.
To check if a Regular Expression is valid, press the run 

 icon. If the
Regular Expression matches the text i t will be signaled by a green
icon.
If the Regular Expression contain brackets the resulting string will be
colored.
Debugging Regular Expressions
The Single Step
feature allows for a step by step inspection of the regular expression.
If no sub expressions (...) are defined by the user the RegExp
Plug-in
tries to use logical blocks for matching, otherwise the already
existing
subexpressions are used. 
The following
buttons are provided:
  Reset
(clears all color markers)
 Reset
(clears all color markers)
   Step
forward
 Step
forward
   Step
backward
 Step
backward
Known Bugs & Problems
Debugger
Problems showing
Local Variables
The EPIC debugger uses the PadWalker module to show local (or lexical)
variables. PadWalker  0.10 does not display the values for lexical
variables declared on  top-level (outside of functions and blocks)
correctly if used in debugger mode . To get around this problem put
your code within a function:
dummy();
sub dummy
{
    <YOUR CODE>
}
References
Part of this document is taken from the official Eclipse documentation
provided by the Eclipse project and IBM.