mirror of
https://codeberg.org/PGPainless/sop-java.git
synced 2024-11-25 16:42:07 +01:00
Kotlin conversion: SOPGPException
This commit is contained in:
parent
94b428ef62
commit
7824ee92c5
4 changed files with 308 additions and 490 deletions
|
@ -1,473 +0,0 @@
|
|||
// SPDX-FileCopyrightText: 2021 Paul Schaub <vanitasvitae@fsfe.org>
|
||||
//
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
package sop.exception;
|
||||
|
||||
public abstract class SOPGPException extends RuntimeException {
|
||||
|
||||
public SOPGPException() {
|
||||
super();
|
||||
}
|
||||
|
||||
public SOPGPException(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
public SOPGPException(Throwable e) {
|
||||
super(e);
|
||||
}
|
||||
|
||||
public SOPGPException(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
}
|
||||
|
||||
public abstract int getExitCode();
|
||||
|
||||
/**
|
||||
* No acceptable signatures found (sop verify, inline-verify).
|
||||
*/
|
||||
public static class NoSignature extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 3;
|
||||
|
||||
public NoSignature() {
|
||||
this("No verifiable signature found.");
|
||||
}
|
||||
|
||||
public NoSignature(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
public NoSignature(String errorMsg, NoSignature e) {
|
||||
super(errorMsg, e);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Asymmetric algorithm unsupported (sop encrypt, sign, inline-sign).
|
||||
*/
|
||||
public static class UnsupportedAsymmetricAlgo extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 13;
|
||||
|
||||
public UnsupportedAsymmetricAlgo(String message, Throwable e) {
|
||||
super(message, e);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Certificate not encryption capable (e,g, expired, revoked, unacceptable usage).
|
||||
*/
|
||||
public static class CertCannotEncrypt extends SOPGPException {
|
||||
public static final int EXIT_CODE = 17;
|
||||
|
||||
public CertCannotEncrypt(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
}
|
||||
|
||||
public CertCannotEncrypt(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Missing required argument.
|
||||
*/
|
||||
public static class MissingArg extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 19;
|
||||
|
||||
public MissingArg() {
|
||||
|
||||
}
|
||||
|
||||
public MissingArg(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Incomplete verification instructions (sop decrypt).
|
||||
*/
|
||||
public static class IncompleteVerification extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 23;
|
||||
|
||||
public IncompleteVerification(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Unable to decrypt (sop decrypt).
|
||||
*/
|
||||
public static class CannotDecrypt extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 29;
|
||||
|
||||
public CannotDecrypt() {
|
||||
|
||||
}
|
||||
|
||||
public CannotDecrypt(String errorMsg, Throwable e) {
|
||||
super(errorMsg, e);
|
||||
}
|
||||
|
||||
public CannotDecrypt(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Non-UTF-8 or otherwise unreliable password (sop encrypt).
|
||||
*/
|
||||
public static class PasswordNotHumanReadable extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 31;
|
||||
|
||||
public PasswordNotHumanReadable() {
|
||||
super();
|
||||
}
|
||||
|
||||
public PasswordNotHumanReadable(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Unsupported option.
|
||||
*/
|
||||
public static class UnsupportedOption extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 37;
|
||||
|
||||
public UnsupportedOption(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
public UnsupportedOption(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Invalid data type (no secret key where KEYS expected, etc.).
|
||||
*/
|
||||
public static class BadData extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 41;
|
||||
|
||||
public BadData(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
public BadData(Throwable throwable) {
|
||||
super(throwable);
|
||||
}
|
||||
|
||||
public BadData(String message, Throwable throwable) {
|
||||
super(message, throwable);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Non-Text input where text expected.
|
||||
*/
|
||||
public static class ExpectedText extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 53;
|
||||
|
||||
public ExpectedText() {
|
||||
super();
|
||||
}
|
||||
|
||||
public ExpectedText(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Output file already exists.
|
||||
*/
|
||||
public static class OutputExists extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 59;
|
||||
|
||||
public OutputExists(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Input file does not exist.
|
||||
*/
|
||||
public static class MissingInput extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 61;
|
||||
|
||||
public MissingInput(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
}
|
||||
|
||||
public MissingInput(String errorMsg) {
|
||||
super(errorMsg);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* A KEYS input is protected (locked) with a password and sop failed to unlock it.
|
||||
*/
|
||||
public static class KeyIsProtected extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 67;
|
||||
|
||||
public KeyIsProtected() {
|
||||
super();
|
||||
}
|
||||
|
||||
public KeyIsProtected(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
public KeyIsProtected(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Unsupported subcommand.
|
||||
*/
|
||||
public static class UnsupportedSubcommand extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 69;
|
||||
|
||||
public UnsupportedSubcommand(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* An indirect parameter is a special designator (it starts with @), but sop does not know how to handle the prefix.
|
||||
*/
|
||||
public static class UnsupportedSpecialPrefix extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 71;
|
||||
|
||||
public UnsupportedSpecialPrefix(String errorMsg) {
|
||||
super(errorMsg);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Exception that gets thrown if a special designator (starting with @) is given, but the filesystem contains
|
||||
* a file matching the designator.
|
||||
* <p>
|
||||
* E.g. <pre>@ENV:FOO</pre> is given, but <pre>./@ENV:FOO</pre> exists on the filesystem.
|
||||
*/
|
||||
public static class AmbiguousInput extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 73;
|
||||
|
||||
public AmbiguousInput(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Key not signature-capable (e.g. expired, revoked, unacceptable usage flags).
|
||||
*/
|
||||
public static class KeyCannotSign extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 79;
|
||||
|
||||
public KeyCannotSign() {
|
||||
super();
|
||||
}
|
||||
|
||||
public KeyCannotSign(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
public KeyCannotSign(String s, Throwable throwable) {
|
||||
super(s, throwable);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* User provided incompatible options (e.g. "--as=clearsigned --no-armor").
|
||||
*/
|
||||
public static class IncompatibleOptions extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 83;
|
||||
|
||||
public IncompatibleOptions() {
|
||||
super();
|
||||
}
|
||||
|
||||
public IncompatibleOptions(String errorMsg) {
|
||||
super(errorMsg);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* The user provided a subcommand with an unsupported profile ("--profile=XYZ"),
|
||||
* or the user tried to list profiles of a subcommand that does not support profiles at all.
|
||||
*/
|
||||
public static class UnsupportedProfile extends SOPGPException {
|
||||
|
||||
public static final int EXIT_CODE = 89;
|
||||
|
||||
private final String subcommand;
|
||||
private final String profile;
|
||||
|
||||
/**
|
||||
* Create an exception signalling a subcommand that does not support any profiles.
|
||||
*
|
||||
* @param subcommand subcommand
|
||||
*/
|
||||
public UnsupportedProfile(String subcommand) {
|
||||
super("Subcommand '" + subcommand + "' does not support any profiles.");
|
||||
this.subcommand = subcommand;
|
||||
this.profile = null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Create an exception signalling a subcommand does not support a specific profile.
|
||||
*
|
||||
* @param subcommand subcommand
|
||||
* @param profile unsupported profile
|
||||
*/
|
||||
public UnsupportedProfile(String subcommand, String profile) {
|
||||
super("Subcommand '" + subcommand + "' does not support profile '" + profile + "'.");
|
||||
this.subcommand = subcommand;
|
||||
this.profile = profile;
|
||||
}
|
||||
|
||||
/**
|
||||
* Wrap an exception into another instance with a possibly translated error message.
|
||||
*
|
||||
* @param errorMsg error message
|
||||
* @param e exception
|
||||
*/
|
||||
public UnsupportedProfile(String errorMsg, UnsupportedProfile e) {
|
||||
super(errorMsg, e);
|
||||
this.subcommand = e.getSubcommand();
|
||||
this.profile = e.getProfile();
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the subcommand name.
|
||||
*
|
||||
* @return subcommand
|
||||
*/
|
||||
public String getSubcommand() {
|
||||
return subcommand;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the profile name.
|
||||
* May return <pre>null</pre>.
|
||||
*
|
||||
* @return profile name
|
||||
*/
|
||||
public String getProfile() {
|
||||
return profile;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getExitCode() {
|
||||
return EXIT_CODE;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,9 +0,0 @@
|
|||
// SPDX-FileCopyrightText: 2021 Paul Schaub <vanitasvitae@fsfe.org>
|
||||
//
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
/**
|
||||
* Stateless OpenPGP Interface for Java.
|
||||
* Exception classes.
|
||||
*/
|
||||
package sop.exception;
|
|
@ -1,8 +0,0 @@
|
|||
// SPDX-FileCopyrightText: 2021 Paul Schaub <vanitasvitae@fsfe.org>
|
||||
//
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
/**
|
||||
* Stateless OpenPGP Interface for Java.
|
||||
*/
|
||||
package sop;
|
308
sop-java/src/main/kotlin/sop/exception/SOPGPException.kt
Normal file
308
sop-java/src/main/kotlin/sop/exception/SOPGPException.kt
Normal file
|
@ -0,0 +1,308 @@
|
|||
// SPDX-FileCopyrightText: 2023 Paul Schaub <vanitasvitae@fsfe.org>
|
||||
//
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
package sop.exception
|
||||
|
||||
abstract class SOPGPException : RuntimeException {
|
||||
|
||||
constructor() : super()
|
||||
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
constructor(cause: Throwable) : super(cause)
|
||||
|
||||
constructor(message: String, cause: Throwable) : super(message, cause)
|
||||
|
||||
abstract fun getExitCode(): Int
|
||||
|
||||
/** No acceptable signatures found (sop verify, inline-verify). */
|
||||
class NoSignature : SOPGPException {
|
||||
@JvmOverloads
|
||||
constructor(message: String = "No verifiable signature found.") : super(message)
|
||||
|
||||
constructor(errorMsg: String, e: NoSignature) : super(errorMsg, e)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 3
|
||||
}
|
||||
}
|
||||
|
||||
/** Asymmetric algorithm unsupported (sop encrypt, sign, inline-sign). */
|
||||
class UnsupportedAsymmetricAlgo(message: String, e: Throwable) : SOPGPException(message, e) {
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 13
|
||||
}
|
||||
}
|
||||
|
||||
/** Certificate not encryption capable (e,g, expired, revoked, unacceptable usage). */
|
||||
class CertCannotEncrypt : SOPGPException {
|
||||
constructor(message: String, cause: Throwable) : super(message, cause)
|
||||
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 17
|
||||
}
|
||||
}
|
||||
|
||||
/** Missing required argument. */
|
||||
class MissingArg : SOPGPException {
|
||||
constructor()
|
||||
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 19
|
||||
}
|
||||
}
|
||||
|
||||
/** Incomplete verification instructions (sop decrypt). */
|
||||
class IncompleteVerification(message: String) : SOPGPException(message) {
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 23
|
||||
}
|
||||
}
|
||||
|
||||
/** Unable to decrypt (sop decrypt). */
|
||||
class CannotDecrypt : SOPGPException {
|
||||
constructor()
|
||||
|
||||
constructor(errorMsg: String, e: Throwable) : super(errorMsg, e)
|
||||
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 29
|
||||
}
|
||||
}
|
||||
|
||||
/** Non-UTF-8 or otherwise unreliable password (sop encrypt). */
|
||||
class PasswordNotHumanReadable : SOPGPException {
|
||||
constructor() : super()
|
||||
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 31
|
||||
}
|
||||
}
|
||||
|
||||
/** Unsupported option. */
|
||||
class UnsupportedOption : SOPGPException {
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
constructor(message: String, cause: Throwable) : super(message, cause)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 37
|
||||
}
|
||||
}
|
||||
|
||||
/** Invalid data type (no secret key where KEYS expected, etc.). */
|
||||
class BadData : SOPGPException {
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
constructor(throwable: Throwable) : super(throwable)
|
||||
|
||||
constructor(message: String, throwable: Throwable) : super(message, throwable)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 41
|
||||
}
|
||||
}
|
||||
|
||||
/** Non-Text input where text expected. */
|
||||
class ExpectedText : SOPGPException {
|
||||
constructor() : super()
|
||||
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 53
|
||||
}
|
||||
}
|
||||
|
||||
/** Output file already exists. */
|
||||
class OutputExists(message: String) : SOPGPException(message) {
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 59
|
||||
}
|
||||
}
|
||||
|
||||
/** Input file does not exist. */
|
||||
class MissingInput : SOPGPException {
|
||||
constructor(message: String, cause: Throwable) : super(message, cause)
|
||||
|
||||
constructor(errorMsg: String) : super(errorMsg)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 61
|
||||
}
|
||||
}
|
||||
|
||||
/** A KEYS input is protected (locked) with a password and sop failed to unlock it. */
|
||||
class KeyIsProtected : SOPGPException {
|
||||
constructor() : super()
|
||||
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
constructor(message: String, cause: Throwable) : super(message, cause)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 67
|
||||
}
|
||||
}
|
||||
|
||||
/** Unsupported subcommand. */
|
||||
class UnsupportedSubcommand(message: String) : SOPGPException(message) {
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 69
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* An indirect parameter is a special designator (it starts with @), but sop does not know how
|
||||
* to handle the prefix.
|
||||
*/
|
||||
class UnsupportedSpecialPrefix(errorMsg: String) : SOPGPException(errorMsg) {
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 71
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Exception that gets thrown if a special designator (starting with @) is given, but the
|
||||
* filesystem contains a file matching the designator.
|
||||
*
|
||||
* E.g. <pre>@ENV:FOO</pre> is given, but <pre>./@ENV:FOO</pre> exists on the filesystem.
|
||||
*/
|
||||
class AmbiguousInput(message: String) : SOPGPException(message) {
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 73
|
||||
}
|
||||
}
|
||||
|
||||
/** Key not signature-capable (e.g. expired, revoked, unacceptable usage flags). */
|
||||
class KeyCannotSign : SOPGPException {
|
||||
constructor() : super()
|
||||
|
||||
constructor(message: String) : super(message)
|
||||
|
||||
constructor(s: String, throwable: Throwable) : super(s, throwable)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 79
|
||||
}
|
||||
}
|
||||
|
||||
/** User provided incompatible options (e.g. "--as=clearsigned --no-armor"). */
|
||||
class IncompatibleOptions : SOPGPException {
|
||||
constructor() : super()
|
||||
|
||||
constructor(errorMsg: String) : super(errorMsg)
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 83
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* The user provided a subcommand with an unsupported profile ("--profile=XYZ"), or the user
|
||||
* tried to list profiles of a subcommand that does not support profiles at all.
|
||||
*/
|
||||
class UnsupportedProfile : SOPGPException {
|
||||
/**
|
||||
* Return the subcommand name.
|
||||
*
|
||||
* @return subcommand
|
||||
*/
|
||||
val subcommand: String
|
||||
|
||||
/**
|
||||
* Return the profile name. May return `null`.
|
||||
*
|
||||
* @return profile name
|
||||
*/
|
||||
val profile: String?
|
||||
|
||||
/**
|
||||
* Create an exception signalling a subcommand that does not support any profiles.
|
||||
*
|
||||
* @param subcommand subcommand
|
||||
*/
|
||||
constructor(
|
||||
subcommand: String
|
||||
) : super("Subcommand '$subcommand' does not support any profiles.") {
|
||||
this.subcommand = subcommand
|
||||
profile = null
|
||||
}
|
||||
|
||||
/**
|
||||
* Create an exception signalling a subcommand does not support a specific profile.
|
||||
*
|
||||
* @param subcommand subcommand
|
||||
* @param profile unsupported profile
|
||||
*/
|
||||
constructor(
|
||||
subcommand: String,
|
||||
profile: String
|
||||
) : super("Subcommand '$subcommand' does not support profile '$profile'.") {
|
||||
this.subcommand = subcommand
|
||||
this.profile = profile
|
||||
}
|
||||
|
||||
/**
|
||||
* Wrap an exception into another instance with a possibly translated error message.
|
||||
*
|
||||
* @param errorMsg error message
|
||||
* @param e exception
|
||||
*/
|
||||
constructor(errorMsg: String, e: UnsupportedProfile) : super(errorMsg, e) {
|
||||
subcommand = e.subcommand
|
||||
profile = e.profile
|
||||
}
|
||||
|
||||
override fun getExitCode(): Int = EXIT_CODE
|
||||
|
||||
companion object {
|
||||
const val EXIT_CODE = 89
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue