Skip to content
Variant.h 2.48 KiB
Newer Older
Hiroshi Sumita's avatar
Hiroshi Sumita committed
/* vim:set et ts=4 sts=4:
 *
 * libpyzy - The Chinese PinYin and Bopomofo conversion library.
 *
 * Copyright (c) 2008-2010 Peng Huang <shawn.p.huang@gmail.com>
 *
Hiroshi Sumita's avatar
Hiroshi Sumita committed
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
Hiroshi Sumita's avatar
Hiroshi Sumita committed
 *
Hiroshi Sumita's avatar
Hiroshi Sumita committed
 * This library 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
Hiroshi Sumita's avatar
Hiroshi Sumita committed
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
Hiroshi Sumita's avatar
Hiroshi Sumita committed
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301
Hiroshi Sumita's avatar
Hiroshi Sumita committed
 * USA
 */
#ifndef __PYZY_VARIANT_H_
#define __PYZY_VARIANT_H_

namespace PyZy {

/**
 * \brief Variant class to handle various type of value.
 */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
class Variant {
public:
    /**
     * \brief The type contained in the variant.
     */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
    enum Type {
        /** null */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
        TYPE_NULL,
        /** boolean value */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
        TYPE_BOOL,
        /** unsigned int value */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
        TYPE_UNSIGNED_INT,
    };

    /**
     * \brief Creates a Variant object from the argument.
     * @param value boolean value.
     * @return Variant object.
     */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
    static Variant fromBool (bool value);

    /**
     * \brief Creates a Variant object from the argument.
     * @param value unsigned int value.
     * @return Variant object.
     */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
    static Variant fromUnsignedInt (unsigned int value);

    /**
     * \brief Creates a null Variant object.
     * @return Variant object.
     */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
    static Variant nullVariant (void);

    /**
     * \brief Gets a type of the contained value.
     * @return type of the contained value.
     * @see Type
     */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
    Type getType (void) const;

    /**
     * \brief Gets a value as bool.
     * @return value of the variant as bool.
     *
     * This method doesn't check the type.
     */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
    bool getBool (void) const;

    /**
     * \brief Gets a value as unsigned int.
     * @return value of the variant as bool.
     *
     * This method doesn't check the type.
     */
Hiroshi Sumita's avatar
Hiroshi Sumita committed
    unsigned int getUnsignedInt (void) const;

private:
    Variant();

    Type m_type;
    union {
        bool bool_value;
        unsigned int  unsigned_int_value;
    } m_value;
};

}  // namespace PyZy

#endif