A class for storing and manipulating a source code file. More...
#include <juce_CodeDocument.h>
Classes | |
class | Iterator |
Iterates the text in a CodeDocument. More... | |
class | Listener |
An object that receives callbacks from the CodeDocument when its text changes. More... | |
class | Position |
A position in a code document. More... | |
Public Member Functions | |
CodeDocument () | |
Creates a new, empty document. More... | |
~CodeDocument () | |
Destructor. More... | |
void | addListener (Listener *listener) noexcept |
Registers a listener object to receive callbacks when the document changes. More... | |
void | applyChanges (const String &newContent) |
Analyses the changes between the current content and some new text, and applies those changes. More... | |
void | clearUndoHistory () |
Clears the undo history. More... | |
void | deleteSection (const Position &startPosition, const Position &endPosition) |
Deletes a section of the text. More... | |
void | deleteSection (int startIndex, int endIndex) |
Deletes a section of the text. More... | |
void | findLineContaining (const Position &pos, Position &start, Position &end) const noexcept |
Finds the line that contains the given position. More... | |
void | findTokenContaining (const Position &pos, Position &start, Position &end) const noexcept |
Finds the token that contains the given position. More... | |
Position | findWordBreakAfter (const Position &position) const noexcept |
Searches for a word-break. More... | |
Position | findWordBreakBefore (const Position &position) const noexcept |
Searches for a word-break. More... | |
String | getAllContent () const |
Returns the full text of the document. More... | |
String | getLine (int lineIndex) const noexcept |
Returns a line from the document. More... | |
int | getMaximumLineLength () noexcept |
Returns the number of characters in the longest line of the document. More... | |
String | getNewLineCharacters () const noexcept |
Returns the preferred new-line characters for the document. More... | |
int | getNumCharacters () const noexcept |
Returns the number of characters in the document. More... | |
int | getNumLines () const noexcept |
Returns the number of lines in the document. More... | |
String | getTextBetween (const Position &start, const Position &end) const |
Returns a section of the document's text. More... | |
UndoManager & | getUndoManager () noexcept |
Returns the document's UndoManager. More... | |
bool | hasChangedSinceSavePoint () const noexcept |
Returns true if the state of the document differs from the state it was in when setSavePoint() was last called. More... | |
void | insertText (const Position &position, const String &text) |
Inserts some text into the document at a given position. More... | |
void | insertText (int insertIndex, const String &text) |
Inserts some text into the document at a given position. More... | |
bool | loadFromStream (InputStream &stream) |
Replaces the editor's contents with the contents of a stream. More... | |
void | newTransaction () |
Begins a new undo transaction. More... | |
void | redo () |
Redo the last operation. More... | |
void | removeListener (Listener *listener) noexcept |
Deregisters a listener. More... | |
void | replaceAllContent (const String &newContent) |
Clears the document and replaces it with some new text. More... | |
void | replaceSection (int startIndex, int endIndex, const String &newText) |
Replaces a section of the text with a new string. More... | |
void | setNewLineCharacters (const String &newLineCharacters) noexcept |
Sets the new-line characters that the document should use. More... | |
void | setSavePoint () noexcept |
Makes a note that the document's current state matches the one that is saved. More... | |
void | undo () |
Undo the last operation. More... | |
bool | writeToStream (OutputStream &stream) |
Writes the editor's current contents to a stream. More... | |
Private Member Functions | |
void | checkLastLineStatus () |
void | insert (const String &text, int insertPos, bool undoable) |
void | remove (int startPos, int endPos, bool undoable) |
Private Attributes | |
int | currentActionIndex |
int | indexOfSavedState |
OwnedArray< CodeDocumentLine > | lines |
ListenerList< Listener > | listeners |
int | maximumLineLength |
String | newLineChars |
Array< Position * > | positionsToMaintain |
UndoManager | undoManager |
Friends | |
class | CodeDocumentDeleteAction |
class | CodeDocumentInsertAction |
class | Iterator |
class | Position |
A class for storing and manipulating a source code file.
When using a CodeEditorComponent, it takes one of these as its source object.
The CodeDocument stores its content as an array of lines, which makes it quick to insert and delete.
CodeDocument::CodeDocument | ( | ) |
Creates a new, empty document.
CodeDocument::~CodeDocument | ( | ) |
Destructor.
|
noexcept |
Registers a listener object to receive callbacks when the document changes.
If the listener is already registered, this method has no effect.
void CodeDocument::applyChanges | ( | const String & | newContent | ) |
Analyses the changes between the current content and some new text, and applies those changes.
|
private |
void CodeDocument::clearUndoHistory | ( | ) |
Clears the undo history.
Deletes a section of the text.
This operation is undoable.
Deletes a section of the text.
This operation is undoable.
|
noexcept |
Finds the line that contains the given position.
|
noexcept |
Finds the token that contains the given position.
Searches for a word-break.
Searches for a word-break.
String CodeDocument::getAllContent | ( | ) | const |
Returns the full text of the document.
|
noexcept |
Returns the number of characters in the longest line of the document.
|
inlinenoexcept |
Returns the preferred new-line characters for the document.
This will be either "\n", "\r\n", or (rarely) "\r".
References StandardApplicationCommandIDs::redo, and StandardApplicationCommandIDs::undo.
|
noexcept |
Returns the number of characters in the document.
|
inlinenoexcept |
Returns the number of lines in the document.
Returns a section of the document's text.
|
inlinenoexcept |
Returns the document's UndoManager.
|
noexcept |
Returns true if the state of the document differs from the state it was in when setSavePoint() was last called.
Inserts some text into the document at a given position.
This operation is undoable.
Inserts some text into the document at a given position.
This operation is undoable.
bool CodeDocument::loadFromStream | ( | InputStream & | stream | ) |
Replaces the editor's contents with the contents of a stream.
This will also reset the undo history and save point marker.
void CodeDocument::newTransaction | ( | ) |
Begins a new undo transaction.
The document itself will not call this internally, so relies on whatever is using the document to periodically call this to break up the undo sequence into sensible chunks.
void CodeDocument::redo | ( | ) |
Redo the last operation.
|
noexcept |
Deregisters a listener.
void CodeDocument::replaceAllContent | ( | const String & | newContent | ) |
Clears the document and replaces it with some new text.
This operation is undoable - if you're trying to completely reset the document, you might want to also call clearUndoHistory() and setSavePoint() after using this method.
Replaces a section of the text with a new string.
This operation is undoable.
|
noexcept |
Sets the new-line characters that the document should use.
The string must be either "\n", "\r\n", or (rarely) "\r".
|
noexcept |
Makes a note that the document's current state matches the one that is saved.
After this has been called, hasChangedSinceSavePoint() will return false until the document has been altered, and then it'll start returning true. If the document is altered, but then undone until it gets back to this state, hasChangedSinceSavePoint() will again return false.
void CodeDocument::undo | ( | ) |
Undo the last operation.
bool CodeDocument::writeToStream | ( | OutputStream & | stream | ) |
Writes the editor's current contents to a stream.
|
friend |
|
friend |
|
friend |
|
friend |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |