public final class FoldHierarchy extends Object
FoldHierarchy.get(javax.swing.text.JTextComponent)
.
FoldHierarchy.getRootFold()
and allows to expand/collapse the folds
and listen for fold events describing folds structure changes
and state changes of any of the folds in the hierarchy.
Hierarchy is logically bound to view
i.e. JTextComponent
instead of the document model because
if there would be two views over the same document
then a particular fold can be collapsed in one view
but uncollapsed in another.
It's up to the concrete fold implementations to possibly share
some common information even on document model level
e.g. java-related folds in multiple views over
a single java source document can share
the document-level parsing information.
On the other hand user-defined folds (e.g. by collapsing caret selection)
will only be held for the component in which they were created.
Only one thread at the time can access the code folding hierarchy.
Prior working with the hierarchy a document-level lock
must be obtained first followed by call to FoldHierarchy.render(Runnable)
(or FoldHierarchy.lock()
for advanced uses) which ensure that the hierarchy
gets locked exclusively.
The document lock can be either readlock
e.g. by using Document.render(Runnable)
or writelock
e.g. when in DocumentListener
)
and must be obtained on component's document
i.e. JTextComponent.getDocument()
should be used.
The whole fold hierarchy related code expects that the document
instances of the text component will subclass
javax.swing.text.AbstractDocument
.
Modifier and Type | Field and Description |
---|---|
static FoldType |
ROOT_FOLD_TYPE
Fold type for the root fold.
|
Modifier and Type | Method and Description |
---|---|
void |
addFoldHierarchyListener(FoldHierarchyListener l)
Add listener for changes done in the hierarchy.
|
void |
collapse(Collection c)
Collapse all the folds contained in the given collection.
|
void |
collapse(Fold f)
Collapse the given fold.
|
void |
expand(Collection c)
Expand all the folds contained in the given collection.
|
void |
expand(Fold f)
Expand the given fold.
|
static FoldHierarchy |
get(JTextComponent component)
Get the fold hierarchy for the given component.
|
JTextComponent |
getComponent()
Get the text component for which this fold hierarchy was created.
|
Fold |
getRootFold()
Get the root fold of this hierarchy.
|
boolean |
isActive()
Determines whether the hierarchy can have some folds.
|
void |
lock()
Lock the hierarchy for exclusive use.
|
void |
removeFoldHierarchyListener(FoldHierarchyListener l)
Remove previously added listener for changes done in the hierarchy.
|
void |
render(Runnable r)
Execute the given runnable over the exclusively locked hierarchy.
|
void |
toggle(Fold f)
Collapse the given fold if it's expanded and expand it if it's
collapsed.
|
String |
toString()
Get a string description of the hierarchy for debugging purposes.
|
void |
unlock()
Unlock the hierarchy from exclusive use.
|
public static final FoldType ROOT_FOLD_TYPE
public static FoldHierarchy get(JTextComponent component)
public void render(Runnable r)
Document.render(Runnable)
or writelock
e.g. when in DocumentListener
)
and must be obtained on component's document
i.e. JTextComponent.getDocument()
should be used.r
- the runnable to be executed.public void lock()
FoldHierarchy.unlock()
in try..finally
block.
Document.render(Runnable)
or writelock
e.g. when in DocumentListener
)
and must be obtained on component's document
i.e. JTextComponent.getDocument()
should be used.
Note: The clients using this method must ensure that they always use this method in the following pattern:
lock(); try { ... } finally { unlock(); }
FoldHierarchy.render(Runnable)
public void unlock()
FoldHierarchy.lock()
in try..finally
block.public void collapse(Fold f)
Note: The hierarchy must be locked prior using of this method.
f
- fold to be collapsed.public void collapse(Collection c)
Note: The hierarchy must be locked prior using of this method.
c
- collection of the Fold
s to be collapsed. The folds
must be present in this hierarchy.public void expand(Fold f)
Note: The hierarchy must be locked prior using of this method.
f
- fold to be expanded.public void expand(Collection c)
Note: The hierarchy must be locked prior using of this method.
c
- collection of the Fold
s to be collapsed. The folds
must be present in this hierarchy.public void toggle(Fold f)
Note: The hierarchy must be locked prior using of this method.
f
- fold which state should be toggled.public JTextComponent getComponent()
public Fold getRootFold()
public void addFoldHierarchyListener(FoldHierarchyListener l)
l
- non-null listener to be added.public void removeFoldHierarchyListener(FoldHierarchyListener l)
l
- non-null listener to be removed.public String toString()
public boolean isActive()
false
, there is no provider currently
that could define folds. If true
is returned, then there are
'just' no folds at the moment, but they could appear.
Note that provider may (dis)appear, so clients should subscribe their
FoldHierarchyListener
, and react if a Fold appears.
false
, if there is no FoldManager providing folds.