view CodeGeneration/JavaEnumeration.mustache @ 0:3ecef5782f2c

initial commit
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 18 Oct 2023 17:59:44 +0200
parents
children 26c08ff926a3
line wrap: on
line source

package be.uclouvain.orthanc;

/**
 * SPDX-FileCopyrightText: 2023 Sebastien Jodogne, UCLouvain, Belgium
 * SPDX-License-Identifier: GPL-3.0-or-later
 */

/**
 * Java plugin for Orthanc
 * Copyright (C) 2023 Sebastien Jodogne, UCLouvain, Belgium
 *
 * This program is free software: you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program. If not, see http://www.gnu.org/licenses/.
 **/


{{#has_documentation}}
/**
{{#documentation}}
 * {{line}}
{{/documentation}}
 **/
{{/has_documentation}}
public enum {{short_name}} {
    {{#values}}
    {{#has_documentation}}
    /**
    {{#documentation}}
     * {{line}}
    {{/documentation}}
     **/
    {{/has_documentation}}
    {{key}}({{value}}){{^last}},{{/last}}{{#last}};{{/last}}
    {{/values}}

    private int value;

    private {{short_name}}(int value) {
        this.value = value;
    }

    /**
     * Return the enumeration value that corresponds to an integer value of interest.
     * @param value The integer value.
     * @return The enumeration value.
     **/
    protected static {{short_name}} getInstance(int value) {
        {{#values}}
        if (value == {{value}}) {
            return {{key}};
        }
        {{/values}}

        throw new IllegalArgumentException("Value out of range for enumeration {{short_name}}: " + value);
    }

    /**
     * Get the integer value corresponding to this enumeration value.
     * @return The integer value.
     **/
    public int getValue() {
        return value;
    }
}