API¶
Dependency¶
Declaring the dependency:
<dependency>
<groupId>net.kyori</groupId>
<artifactId>adventure-text-minimessage</artifactId>
<version>4.18.0</version>
</dependency>
repositories {
mavenCentral()
}
dependencies {
implementation "net.kyori:adventure-text-minimessage:4.18.0"
}
repositories {
mavenCentral()
}
dependencies {
implementation("net.kyori:adventure-text-minimessage:4.18.0")
}
Need development/snapshot builds? Using Snapshot Builds
Note
Some platforms already provide MiniMessage natively. In this case you will not need to add MiniMessage as a dependency.
Getting Started¶
MiniMessage exposes a simple API via the MiniMessage
class.
Note
Previously, a Markdown mode was available. This has been temporarily removed due to some issues with the new 4.10.0 parser backend, but there are plans to re-add it once time permits.
A standard instance of the serializer is available through the miniMessage()
method. This uses the default set of tags and is not in strict mode.
Additional customization of MiniMessage is possible via the Builder.
MiniMessage allows you to both serialize components into MiniMessage strings and to parse/deserialize MiniMessage strings into components.
Here’s a short example to try things out:
Audience player = ...;
var mm = MiniMessage.miniMessage();
Component parsed = mm.deserialize("Hello <rainbow>world</rainbow>, isn't <underlined>MiniMessage</underlined> fun?");
player.sendMessage(parsed);
For more advanced uses, additional tag resolvers can be registered, which when given a tag name and arguments will produce a Tag
instance. These are described in more detail below.
Builder¶
To make customizing MiniMessage easier, we provide a Builder. The specific methods on the builder are explained in the javadoc.
MiniMessage minimessage = MiniMessage.builder()
.tags(TagResolver.builder()
.resolver(StandardTags.color())
.resolver(StandardTags.decorations())
.resolver(this.someResolvers)
.build()
)
.build();
Tip
It’s a good idea to initialize such a MiniMessage instance once, in a central location, and then use it for all your messages. Exception being if you want to customize MiniMessage based on permissions of a user (for example, admins should be allowed to use color and decoration in the message, normal users not)
Error handling¶
By default, MiniMessage will never throw an exception caused by user input. Instead, it will treat any invalid tags as normal text. MiniMessage.Builder#strict(true)
mode will enable strict mode,
which throws exceptions on unclosed tags, but still will allow any improperly specified tags through.
To capture information on why a parse may have failed, MiniMessage.Builder#debug(Consumer<String>)
can be provided, which will accept debug logging for an input string.
Tag Resolvers¶
All tag resolution goes through tag resolvers. There is one global tag resolver, which describes the tags available through a MiniMessage instance, plus parse-specific resolvers which can provide additional input-specific tags.
Tag resolvers are the binding between a name and arguments, and the logic to produce a Component
contained in a Tag
instance. They are composable so a TagResolver
can produce any number of actual Tag
instances. The tag name passed to resolvers will always be lower-cased, to ensure case-insensitive searches.
Tag names are only allowed to contain the characters a-z, 0-9, _
, and -
. They can also optionally start with any of the following characters: !?#
.
You can create your own TagResolver
by using the static factory methods in TagResolver
. To replace tags dynamically with text MiniMessage has built-in Placeholder
and Formatter
.
Where possible, these built-in resolvers should be used, as MiniMessage can flatten combinations of these resolvers into a more efficient format.
For built-in dynamic replacements take a look here.
To combine multiple resolvers, take a look at the tag resolver builder, TagResolver.builder()
.
The builder for MiniMessage
allows providing a custom tag resolver rather than the default (StandardTags.all()
), allowing
MiniMessage also provides convenience methods to do that:
MiniMessage serializer = MiniMessage.builder()
.tags(TagResolver.builder()
.resolver(StandardTags.color())
.build()
)
.build();
var parsed = serializer.deserialize("<green><bold>Hai");
// Assertion passes
assertEquals(Component.text("<bold>Hai", NamedTextColor.GREEN), parsed);
Because the
tag is not enabled on this builder, the bold tag is interpreted as literal text.Handling Arguments¶
Tag resolvers have an ArgumentQueue
parameter, which provides any tag arguments that are present in the input. Helper methods on Tag.Argument
can assist with conversions of the tag.
Exceptions thrown by the popOr()
methods will interrupt execution, but are not currently exposed to users outside of debug output. We plan to add an auto-completion function that can
reveal some of this information to the user, so please do try to write useful error messages in custom tag resolvers.