@ExperimentalApi public class Expansion extends Object
node
and any sub properties
will get collected in the subExpansions
If its the root node it will only have children e.g. "a.b,c.d" will become an Expansion with a root node ("ROOT"), with two sub nodes "a" and "c"
If its a sub node, it will have the name of the sub node, and its children. e.g. "a.c,a.b" will have "a" as the node and subExpansion of "c" and "b"
Modifier and Type | Field and Description |
---|---|
static String |
ROOT_NODE |
static Expansion |
SELF |
Modifier and Type | Method and Description |
---|---|
void |
addSubExpansion(@Nullable Expansion expansion)
Adds a single sub expansion to this expansion.
|
void |
addSubExpansions(@Nullable Collection<Expansion> expansions)
Adds sub expansions to this expansion.
|
boolean |
canExpand()
Check if the current property can be expanded
|
boolean |
canExpand(@NotNull String name)
Check if the given property is a sub node of the current property
|
boolean |
equals(Object o) |
@NotNull Expansion |
getExpansion(@NotNull String name)
Get expansion at a specific sub node.
|
@NotNull String |
getName() |
@NotNull Expansion |
getSubExpansion(@NotNull String name)
Get expansion at a specific sub node.
|
@NotNull Collection<Expansion> |
getSubExpansions() |
int |
hashCode() |
boolean |
isRoot() |
static @NotNull Expansion |
parse(@Nullable String string)
Takes in expansion arguments and parses/splits/merges them into an expansion tree.
|
protected static @NotNull Pair<String,String> |
toParts(@NotNull String expansionString)
Split an expansion string into its first node and rest.
|
String |
toString()
Flattens the tree into a string format
|
public static final String ROOT_NODE
public static final Expansion SELF
@NotNull public static @NotNull Expansion parse(@Nullable @Nullable String string)
string
- to parse@NotNull public @NotNull String getName()
public boolean isRoot()
@NotNull public @NotNull Collection<Expansion> getSubExpansions()
public void addSubExpansions(@Nullable @Nullable Collection<Expansion> expansions)
expansions
- to addpublic void addSubExpansion(@Nullable @Nullable Expansion expansion)
expansion
- to addpublic boolean canExpand(@NotNull @NotNull String name)
name
- to checkpublic boolean canExpand()
@NotNull public @NotNull Expansion getExpansion(@NotNull @NotNull String name)
NONE
will be returned.name
- of the sub expansion to get@NotNull public @NotNull Expansion getSubExpansion(@NotNull @NotNull String name)
canExpand(String)
firstname
- of the sub expansion to get@NotNull protected static @NotNull Pair<String,String> toParts(@NotNull @NotNull String expansionString)
expansionString
- string to splitpublic String toString()
Copyright © 2022 Atlassian Software Systems Pty Ltd. All rights reserved.