• Skip to content
  • Skip to link menu
KDE 3.5 API Reference
  • KDE API Reference
  • API Reference
  • Sitemap
  • Contact Us
 

Kate

KateVarIndent Class Reference

This indenter uses document variables to determine when to add/remove indents. More...

#include <kateautoindent.h>

Inheritance diagram for KateVarIndent:

Inheritance graph
[legend]

List of all members.


Public Types

enum  pairs { Parens = 1, Braces = 2, Brackets = 4, AngleBrackets = 8 }

Public Member Functions

virtual bool canProcessLine () const
 KateVarIndent (KateDocument *doc)
virtual uint modeNumber () const
virtual void processChar (QChar c)
virtual void processLine (KateDocCursor &line)
virtual void processNewline (KateDocCursor &cur, bool needContinue)
virtual void processSection (const KateDocCursor &begin, const KateDocCursor &end)
virtual ~KateVarIndent ()

Detailed Description

This indenter uses document variables to determine when to add/remove indents.

It attempts to get the following variables from the document:

  • var-indent-indent-after: A rerular expression which will cause a line to be indented by one unit, if the first non-whitespace-only line above matches.
  • var-indent-indent: A regular expression, which will cause a matching line to be indented by one unit.
  • var-indent-unindent: A regular expression which will cause the line to be unindented by one unit if matching.
  • var-indent-triggerchars: a list of characters that should cause the indentiou to be recalculated immediately when typed.
  • var-indent-handle-couples: a list of paren sets to handle. Any combination of 'parens' 'braces' and 'brackets'. Each set type is handled the following way: If there are unmatched opening instances on the above line, one indent unit is added, if there are unmatched closing instances on the current line, one indent unit is removed.
  • var-indent-couple-attribute: When looking for unmatched couple openings/closings, only characters with this attribute is considered. The value must be the attribute name from the syntax xml file, for example "Symbol". If it's not specified, attribute 0 is used (usually 'Normal Text').

The idea is to provide a somewhat intelligent indentation for perl, php, bash, scheme and in general formats with humble indentation needs.

Definition at line 492 of file kateautoindent.h.


Member Enumeration Documentation

enum KateVarIndent::pairs

Purely for readability, couples we know and love.

Enumerator:
Parens 
Braces 
Brackets 
AngleBrackets 

Definition at line 500 of file kateautoindent.h.


Constructor & Destructor Documentation

KateVarIndent::KateVarIndent ( KateDocument *  doc  ) 

Definition at line 2163 of file kateautoindent.cpp.

KateVarIndent::~KateVarIndent (  )  [virtual]

Definition at line 2181 of file kateautoindent.cpp.


Member Function Documentation

virtual bool KateVarIndent::canProcessLine (  )  const [inline, virtual]

Set to true if an actual implementation of 'processLine' is present.

This is used to prevent a needless Undo action from being created.

Reimplemented from KateNormalIndent.

Definition at line 516 of file kateautoindent.h.

virtual uint KateVarIndent::modeNumber (  )  const [inline, virtual]

Mode index of this mode.

Returns:
modeNumber

Reimplemented from KateNormalIndent.

Definition at line 518 of file kateautoindent.h.

void KateVarIndent::processChar ( QChar  c  )  [virtual]

Called every time a character is inserted into the document.

Parameters:
c character inserted

Reimplemented from KateNormalIndent.

Definition at line 2194 of file kateautoindent.cpp.

void KateVarIndent::processLine ( KateDocCursor &   )  [virtual]

Aligns/indents the given line to the proper indent position.

Reimplemented from KateNormalIndent.

Definition at line 2210 of file kateautoindent.cpp.

void KateVarIndent::processNewline ( KateDocCursor &  cur,
bool  needContinue 
) [virtual]

Called every time a newline character is inserted in the document.

Parameters:
cur The position to start processing. Contains the new cursor position after the indention.
needContinue Used to determine whether to calculate a continue indent or not.

Reimplemented from KateNormalIndent.

Definition at line 2186 of file kateautoindent.cpp.

void KateVarIndent::processSection ( const KateDocCursor &  ,
const KateDocCursor &   
) [virtual]

Processes a section of text, indenting each line in between.

Reimplemented from KateNormalIndent.

Definition at line 2347 of file kateautoindent.cpp.


The documentation for this class was generated from the following files:
  • kateautoindent.h
  • kateautoindent.cpp

Kate

Skip menu "Kate"
  • Main Page
  • Namespace List
  • Class Hierarchy
  • Alphabetical List
  • Class List
  • File List
  • Namespace Members
  • Class Members
  • Related Pages

API Reference

Skip menu "API Reference"
  • dcop
  • DNSSD
  • interfaces
  • Kate
  • kconf_update
  • KDECore
  • KDED
  • kdefx
  • KDEsu
  • kdeui
  • KDocTools
  • KHTML
  • KImgIO
  • KInit
  • kio
  • kioslave
  • KJS
  • KNewStuff
  • KParts
  • KUtils
Generated for API Reference by doxygen 1.5.9
This website is maintained by Adriaan de Groot and Allen Winter.
KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal