This version is still in development and is not considered stable yet. For the latest stable version, please use Spring Shell 3.4.0!

Alias

It is possible to define an alias for a command. This is convenient for cases where you want to create a shorter version of a command or going through a complete command rename while keeping old one temporarily in place.

Format for alias is slighly different than a command. When command is defined as an array it’s concatenated together into a single command. When alias is defined as an array it’s used to create a separate aliases.

Aliases with a plain CommandRegistration is simple and clear as you get exactly what you define as there’s no "magic" in it.

CommandRegistration commandRegistration() {
	return CommandRegistration.builder()
		.command("mycommand")
		// define alias as myalias
		.withAlias()
			.command("myalias")
			.and()
		// define alias as myalias1 and myalias2
		.withAlias()
			.command("myalias1", "myalias2")
			.and()
		.build();
}

Defining alias with @Command annotation is a bit more involved as it can exist on a both class and method levels. Here are examples how it works.

Alias just on a method gives you myalias.

@Command
class MyCommands {

	@Command(command = "mycommand", alias = "myalias")
	void myCommand() {
	}
}

Or myalias1 and myalias2 if defined as an array.

@Command
class MyCommands {

	@Command(command = "mycommand", alias = { "myalias1", "myalias2" })
	void myCommand() {
	}
}

Alias only on a class level does nothing as it’s simply an instruction for annotation on a method level if defined.

@Command(alias = "myalias")
class MyCommands {

	@Command(command = "mycommand")
	void myCommand() {
	}
}

Alias on both class and method level combines those two together where class level works as an prefix and method level as combination of aliases. Alias on a class level is usually used together with a command prefix to keep aliases on a same command level.

Here you’d get alias myalias1 myalias2.

@Command(alias = "myalias1")
class MyCommands {

	@Command(command = "mycommand", alias = "myalias2")
	void myCommand() {
	}
}

On a method level there’s a special format, that being an empty string which allows you to create an alias but it only uses prefix from a class level.

Here you’d get alias myalias1.

@Command(command = "mycommand", alias = "myalias")
class MyCommands {

	@Command(command = "", alias = "")
	void myMainCommand() {
	}

	@Command(command = "mysubcommand", alias = "mysubalias")
	void mySubCommand() {
	}
}