NAME

Padre::Wx::Editor - Padre document editor object

DESCRIPTION

Padre::Wx::Editor implements the Scintilla-based document editor for Padre. It implements the majority of functionality relating to visualisation and navigation of documents.

METHODS

get_brace_info

Look at a given position in the editor if there is a brace (according to the setting editor_braces) before or after, and return the information about the context It always look first at the character after the position.

Params:
	pos - the cursor position in the editor [defaults to cursor position) : int

Return:
	undef if no brace, otherwise [brace, actual_pos, is_after, is_opening]
	where:
		brace - the brace char at actual_pos
		actual_pos - the actual position where the brace has been found
		is_after - true iff the brace is after the cursor : boolean
		is_opening - true iff only the brace is an opening one

Examples:

	|{} => should find the { : [0,{,1,1]
	{|} => should find the } : [1,},1,0]
	{| } => should find the { : [0,{,0,1]

get_brace_type

Tell if a character is a brace, and if it is an opening or a closing one

Params:
	char - a character : string

Return:
	int : 0 if this is not a brace, an odd value if it is an opening brace and an even
	one for a closing brace

find_matching_brace

Find the position of to the matching brace if any. If the cursor is inside the braces the destination will be inside too, same it is outside.

Params:
	pos - the cursor position in the editor [defaults to cursor position) : int

Return:
	matching_pos - the matching position, or undef if none

goto_matching_brace

Move the cursor to the matching brace if any. If the cursor is inside the braces the destination will be inside too, same it is outside.

Params:
	pos - the cursor position in the editor [defaults to cursor position) : int

select_to_matching_brace

Select to the matching opening or closing brace. If the cursor is inside the braces the destination will be inside too, same it is outside.

Params:
	pos - the cursor position in the editor [defaults to cursor position) : int

find_line

my $line_number = $editor->find_line( 123, "sub foo {" );

The find_line method locates a line in a document using a line number and the content of the line.

It is intended for use in situations where a search function has determined that a particular line is of interest, but the document may have changed in the time since the original search was made.

Starting at the suggested line, it will locate the line containing the text which is the closest to line provided. If no text is provided the method acts as a simple pass-through.

Returns an integer line number guaranteed to exist in the document, or undef if the hint text could not be found anywhere in the document.

position

my $position = $editor->position($untrusted);

The position method is used to clean parameters that are supposed to refer to a position within the editor. It takes what should be an numeric document position, constrains the value to the actual position range of the document, and removes any fractional characters.

This method should generally be used when doing something to a document somewhere in it preferable aborting that functionality completely.

Returns an integer character position guaranteed to exist in the document.

line

my $line = $editor->line($untrusted);

The line method is used to clean parameters that are supposed to refer to a line within the editor. It takes what should be an numeric document line, constrains the value to the actual line range of the document, and removes any fractional characters.

This method should generally be used when doing something to a document somewhere in it preferable aborting that functionality completely.

Returns an integer line number guaranteed to exist in the document.

clipboard_length

my $chars = Padre::Wx::Editor->clipboard_length;

The clipboard_length method returns the number of characters of text currently in the clipboard, if any.

Returns an integer number of characters, or zero if the clipboard is empty or contains non-text data.

COPYRIGHT & LICENSE

Copyright 2008-2012 The Padre development team as listed in Padre.pm.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

The full text of the license can be found in the LICENSE file included with this module.