Blob Blame History Raw
// Generated by gmmproc 2.54.1 -- DO NOT MODIFY!
#ifndef _GLIBMM_ENUMS_H
#define _GLIBMM_ENUMS_H


/* Copyright (C) 2016 The gtkmm Development Team
 *
 * 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.
 *
 * 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
 * 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, see <http://www.gnu.org/licenses/>.
 */


#include <glib.h>

namespace Glib
{
/** @addtogroup glibmmEnums glibmm Enums and Flags */

/** 
 *  @var ParamFlags PARAM_READABLE
 * The parameter is readable.
 * 
 *  @var ParamFlags PARAM_WRITABLE
 * The parameter is writable.
 * 
 *  @var ParamFlags PARAM_READWRITE
 * Alias for PARAM_READABLE | PARAM_WRITABLE.
 * 
 *  @var ParamFlags PARAM_CONSTRUCT
 * The parameter will be set upon object construction.
 * 
 *  @var ParamFlags PARAM_CONSTRUCT_ONLY
 * The parameter can only be set upon object construction.
 * 
 *  @var ParamFlags PARAM_LAX_VALIDATION
 * Upon parameter conversion (see g_param_value_convert())
 * strict validation is not required.
 * 
 *  @var ParamFlags PARAM_STATIC_NAME
 * The string used as name when constructing the 
 * parameter is guaranteed to remain valid and
 * unmodified for the lifetime of the parameter. 
 * @newin{2,8}
 * 
 *  @var ParamFlags PARAM_STATIC_NICK
 * The string used as nick when constructing the
 * parameter is guaranteed to remain valid and
 * unmmodified for the lifetime of the parameter.
 * @newin{2,8}
 * 
 *  @var ParamFlags PARAM_STATIC_BLURB
 * The string used as blurb when constructing the 
 * parameter is guaranteed to remain valid and 
 * unmodified for the lifetime of the parameter. 
 * @newin{2,8}
 * 
 *  @var ParamFlags PARAM_EXPLICIT_NOTIFY
 * Calls to g_object_set_property() for this
 * property will not automatically result in a "notify" signal being
 * emitted: the implementation must call g_object_notify() themselves
 * in case the property actually changes.  @newin{2,42}
 * 
 *  @var ParamFlags PARAM_PRIVATE
 * Internal.
 * 
 *  @var ParamFlags PARAM_DEPRECATED
 * The parameter is deprecated and will be removed
 * in a future version. A warning will be generated if it is used
 * while running with G_ENABLE_DIAGNOSTIC=1.
 * @newin{2,26}
 * 
 *  @enum ParamFlags
 * 
 * Through the ParamFlags flag values, certain aspects of parameters
 * can be configured. See also G_PARAM_STATIC_STRINGS.
 *
 * @ingroup glibmmEnums
 * @par Bitwise operators:
 * <tt>%ParamFlags operator|(ParamFlags, ParamFlags)</tt><br>
 * <tt>%ParamFlags operator&(ParamFlags, ParamFlags)</tt><br>
 * <tt>%ParamFlags operator^(ParamFlags, ParamFlags)</tt><br>
 * <tt>%ParamFlags operator~(ParamFlags)</tt><br>
 * <tt>%ParamFlags& operator|=(ParamFlags&, ParamFlags)</tt><br>
 * <tt>%ParamFlags& operator&=(ParamFlags&, ParamFlags)</tt><br>
 * <tt>%ParamFlags& operator^=(ParamFlags&, ParamFlags)</tt><br>
 */
enum ParamFlags
{
  PARAM_READABLE = 1 << 0,
  PARAM_WRITABLE = 1 << 1,
  PARAM_READWRITE = 0x3,
  PARAM_CONSTRUCT = 1 << 2,
  PARAM_CONSTRUCT_ONLY = 1 << 3,
  PARAM_LAX_VALIDATION = 1 << 4,
  PARAM_STATIC_NAME = 1 << 5,
  PARAM_PRIVATE = 0x20,
  PARAM_STATIC_NICK = 1 << 6,
  PARAM_STATIC_BLURB = 1 << 7,
  PARAM_EXPLICIT_NOTIFY = 1 << 30,
  PARAM_DEPRECATED = (gint)(1u << 31)
};

/** @ingroup glibmmEnums */
inline ParamFlags operator|(ParamFlags lhs, ParamFlags rhs)
  { return static_cast<ParamFlags>(static_cast<unsigned>(lhs) | static_cast<unsigned>(rhs)); }

/** @ingroup glibmmEnums */
inline ParamFlags operator&(ParamFlags lhs, ParamFlags rhs)
  { return static_cast<ParamFlags>(static_cast<unsigned>(lhs) & static_cast<unsigned>(rhs)); }

/** @ingroup glibmmEnums */
inline ParamFlags operator^(ParamFlags lhs, ParamFlags rhs)
  { return static_cast<ParamFlags>(static_cast<unsigned>(lhs) ^ static_cast<unsigned>(rhs)); }

/** @ingroup glibmmEnums */
inline ParamFlags operator~(ParamFlags flags)
  { return static_cast<ParamFlags>(~static_cast<unsigned>(flags)); }

/** @ingroup glibmmEnums */
inline ParamFlags& operator|=(ParamFlags& lhs, ParamFlags rhs)
  { return (lhs = static_cast<ParamFlags>(static_cast<unsigned>(lhs) | static_cast<unsigned>(rhs))); }

/** @ingroup glibmmEnums */
inline ParamFlags& operator&=(ParamFlags& lhs, ParamFlags rhs)
  { return (lhs = static_cast<ParamFlags>(static_cast<unsigned>(lhs) & static_cast<unsigned>(rhs))); }

/** @ingroup glibmmEnums */
inline ParamFlags& operator^=(ParamFlags& lhs, ParamFlags rhs)
  { return (lhs = static_cast<ParamFlags>(static_cast<unsigned>(lhs) ^ static_cast<unsigned>(rhs))); }


} //namespace Glib


#endif /* _GLIBMM_ENUMS_H */