Blame src/ibusattribute.h

Packit Service 1d8f1c
/* -*- mode: C; c-basic-offset: 4; indent-tabs-mode: nil; -*- */
Packit Service 1d8f1c
/* vim:set et sts=4: */
Packit Service 1d8f1c
/* IBus - The Input Bus
Packit Service 1d8f1c
 * Copyright (C) 2008-2013 Peng Huang <shawn.p.huang@gmail.com>
Packit Service 1d8f1c
 * Copyright (C) 2008-2013 Red Hat, Inc.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * This library is free software; you can redistribute it and/or
Packit Service 1d8f1c
 * modify it under the terms of the GNU Lesser General Public
Packit Service 1d8f1c
 * License as published by the Free Software Foundation; either
Packit Service 1d8f1c
 * version 2.1 of the License, or (at your option) any later version.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * This library is distributed in the hope that it will be useful,
Packit Service 1d8f1c
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 1d8f1c
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 1d8f1c
 * Lesser General Public License for more details.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * You should have received a copy of the GNU Lesser General Public
Packit Service 1d8f1c
 * License along with this library; if not, write to the Free Software
Packit Service 1d8f1c
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301
Packit Service 1d8f1c
 * USA
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
Packit Service 1d8f1c
#if !defined (__IBUS_H_INSIDE__) && !defined (IBUS_COMPILATION)
Packit Service 1d8f1c
#error "Only <ibus.h> can be included directly"
Packit Service 1d8f1c
#endif
Packit Service 1d8f1c
Packit Service 1d8f1c
#ifndef __IBUS_ATTRIBUTE_H_
Packit Service 1d8f1c
#define __IBUS_ATTRIBUTE_H_
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * SECTION: ibusattribute
Packit Service 1d8f1c
 * @short_description: Attributes of IBusText.
Packit Service 1d8f1c
 * @see_also: #IBusText
Packit Service 1d8f1c
 * @stability: Stable
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * An IBusAttribute represents an attribute that associate to IBusText.
Packit Service 1d8f1c
 * It decorates preedit buffer and auxiliary text with underline, foreground
Packit Service 1d8f1c
 * and background colors.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
Packit Service 1d8f1c
#include "ibusserializable.h"
Packit Service 1d8f1c
Packit Service 1d8f1c
G_BEGIN_DECLS
Packit Service 1d8f1c
Packit Service 1d8f1c
/*
Packit Service 1d8f1c
 * Type macros.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
/* define IBusAttribute macros */
Packit Service 1d8f1c
#define IBUS_TYPE_ATTRIBUTE             \
Packit Service 1d8f1c
    (ibus_attribute_get_type ())
Packit Service 1d8f1c
#define IBUS_ATTRIBUTE(obj)             \
Packit Service 1d8f1c
    (G_TYPE_CHECK_INSTANCE_CAST ((obj), IBUS_TYPE_ATTRIBUTE, IBusAttribute))
Packit Service 1d8f1c
#define IBUS_ATTRIBUTE_CLASS(klass)     \
Packit Service 1d8f1c
    (G_TYPE_CHECK_CLASS_CAST ((klass), IBUS_TYPE_ATTRIBUTE, IBusAttributeClass))
Packit Service 1d8f1c
#define IBUS_IS_ATTRIBUTE(obj)          \
Packit Service 1d8f1c
    (G_TYPE_CHECK_INSTANCE_TYPE ((obj), IBUS_TYPE_ATTRIBUTE))
Packit Service 1d8f1c
#define IBUS_IS_ATTRIBUTE_CLASS(klass)  \
Packit Service 1d8f1c
    (G_TYPE_CHECK_CLASS_TYPE ((klass), IBUS_TYPE_ATTRIBUTE))
Packit Service 1d8f1c
#define IBUS_ATTRIBUTE_GET_CLASS(obj)   \
Packit Service 1d8f1c
    (G_TYPE_INSTANCE_GET_CLASS ((obj), IBUS_TYPE_ATTRIBUTE, IBusAttributeClass))
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * IBusAttrType:
Packit Service 1d8f1c
 * @IBUS_ATTR_TYPE_UNDERLINE: Decorate with underline.
Packit Service 1d8f1c
 * @IBUS_ATTR_TYPE_FOREGROUND: Foreground color.
Packit Service 1d8f1c
 * @IBUS_ATTR_TYPE_BACKGROUND: Background color.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Type enumeration of IBusText attribute.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
typedef enum {
Packit Service 1d8f1c
    IBUS_ATTR_TYPE_UNDERLINE    = 1,
Packit Service 1d8f1c
    IBUS_ATTR_TYPE_FOREGROUND   = 2,
Packit Service 1d8f1c
    IBUS_ATTR_TYPE_BACKGROUND   = 3,
Packit Service 1d8f1c
} IBusAttrType;
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * IBusAttrUnderline:
Packit Service 1d8f1c
 * @IBUS_ATTR_UNDERLINE_NONE: No underline.
Packit Service 1d8f1c
 * @IBUS_ATTR_UNDERLINE_SINGLE: Single underline.
Packit Service 1d8f1c
 * @IBUS_ATTR_UNDERLINE_DOUBLE: Double underline.
Packit Service 1d8f1c
 * @IBUS_ATTR_UNDERLINE_LOW: Low underline ? FIXME
Packit Service 1d8f1c
 * @IBUS_ATTR_UNDERLINE_ERROR: Error underline
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Type of IBusText attribute.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
typedef enum {
Packit Service 1d8f1c
    IBUS_ATTR_UNDERLINE_NONE    = 0,
Packit Service 1d8f1c
    IBUS_ATTR_UNDERLINE_SINGLE  = 1,
Packit Service 1d8f1c
    IBUS_ATTR_UNDERLINE_DOUBLE  = 2,
Packit Service 1d8f1c
    IBUS_ATTR_UNDERLINE_LOW     = 3,
Packit Service 1d8f1c
    IBUS_ATTR_UNDERLINE_ERROR   = 4,
Packit Service 1d8f1c
} IBusAttrUnderline;
Packit Service 1d8f1c
Packit Service 1d8f1c
typedef struct _IBusAttribute IBusAttribute;
Packit Service 1d8f1c
typedef struct _IBusAttributeClass IBusAttributeClass;
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * IBusAttribute:
Packit Service 1d8f1c
 * @type: IBusAttributeType
Packit Service 1d8f1c
 * @value: Value for the type.
Packit Service 1d8f1c
 * @start_index: The starting index, inclusive.
Packit Service 1d8f1c
 * @end_index: The ending index, exclusive.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Signify the type, value and scope of the attribute.
Packit Service 1d8f1c
 * The scope starts from @start_index till the @end_index-1.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
struct _IBusAttribute {
Packit Service 1d8f1c
    IBusSerializable parent;
Packit Service 1d8f1c
Packit Service 1d8f1c
    /*< public >*/
Packit Service 1d8f1c
    guint type;
Packit Service 1d8f1c
    guint value;
Packit Service 1d8f1c
    guint start_index;
Packit Service 1d8f1c
    guint end_index;
Packit Service 1d8f1c
};
Packit Service 1d8f1c
Packit Service 1d8f1c
struct _IBusAttributeClass {
Packit Service 1d8f1c
    IBusSerializableClass parent;
Packit Service 1d8f1c
};
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * ibus_attribute_get_type:
Packit Service 1d8f1c
 * @returns: GType of IBusAttribute.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Returns GType of IBusAttribute.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
GType                ibus_attribute_get_type    ();
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * ibus_attribute_new:
Packit Service 1d8f1c
 * @type: Type of the attribute.
Packit Service 1d8f1c
 * @value: Value of the attribute.
Packit Service 1d8f1c
 * @start_index: Where attribute starts.
Packit Service 1d8f1c
 * @end_index: Where attribute ends.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Creates a new IBusAttribute.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Returns: (transfer none): A newly allocated IBusAttribute.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
IBusAttribute       *ibus_attribute_new         (guint           type,
Packit Service 1d8f1c
                                                 guint           value,
Packit Service 1d8f1c
                                                 guint           start_index,
Packit Service 1d8f1c
                                                 guint           end_index);
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * ibus_attribute_get_attr_type:
Packit Service 1d8f1c
 * @attr: An #IBusAttribute
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Gets an enum of #IBusAttrType.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Returns: An enum of #IBusAttrType.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
guint                ibus_attribute_get_attr_type
Packit Service 1d8f1c
                                                (IBusAttribute *attr);
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * ibus_attribute_get_value:
Packit Service 1d8f1c
 * @attr: An #IBusAttribute
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Gets an unsigned int value relative with #IBusAttrType.
Packit Service 1d8f1c
 * If the type is %IBUS_ATTR_TYPE_UNDERLINE, the return value is
Packit Service 1d8f1c
 * #IBusAttrUnderline. If the type is %IBUS_ATTR_TYPE_FOREGROUND,
Packit Service 1d8f1c
 * the return value is the color RGB.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Returns: An unsigned int value relative with #IBusAttrType.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
guint                ibus_attribute_get_value   (IBusAttribute *attr);
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * ibus_attribute_get_start_index:
Packit Service 1d8f1c
 * @attr: An #IBusAttribute
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Gets a start unsigned index
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Returns: A start unsigned index
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
guint                ibus_attribute_get_start_index
Packit Service 1d8f1c
                                                (IBusAttribute *attr);
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * ibus_attribute_get_end_index:
Packit Service 1d8f1c
 * @attr: An #IBusAttribute
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Gets an end unsigned index
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Returns: A end unsigned index
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
guint                ibus_attribute_get_end_index
Packit Service 1d8f1c
                                                (IBusAttribute *attr);
Packit Service 1d8f1c
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * ibus_attr_underline_new:
Packit Service 1d8f1c
 * @underline_type: Type of underline.
Packit Service 1d8f1c
 * @start_index: Where attribute starts.
Packit Service 1d8f1c
 * @end_index: Where attribute ends.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Creates a new underline #IBusAttribute.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Returns: (transfer none): A newly allocated #IBusAttribute.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
IBusAttribute       *ibus_attr_underline_new    (guint           underline_type,
Packit Service 1d8f1c
                                                 guint           start_index,
Packit Service 1d8f1c
                                                 guint           end_index);
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * ibus_attr_foreground_new:
Packit Service 1d8f1c
 * @color: Color in RGB.
Packit Service 1d8f1c
 * @start_index: Where attribute starts.
Packit Service 1d8f1c
 * @end_index: Where attribute ends.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Creates a new foreground #IBusAttribute.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Returns: (transfer none): A newly allocated #IBusAttribute.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
IBusAttribute       *ibus_attr_foreground_new   (guint           color,
Packit Service 1d8f1c
                                                 guint           start_index,
Packit Service 1d8f1c
                                                 guint           end_index);
Packit Service 1d8f1c
/**
Packit Service 1d8f1c
 * ibus_attr_background_new:
Packit Service 1d8f1c
 * @color: Color in RGB.
Packit Service 1d8f1c
 * @start_index: Where attribute starts.
Packit Service 1d8f1c
 * @end_index: Where attribute ends.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Creates a new background #IBusAttribute.
Packit Service 1d8f1c
 *
Packit Service 1d8f1c
 * Returns: (transfer none): A newly allocated #IBusAttribute.
Packit Service 1d8f1c
 */
Packit Service 1d8f1c
IBusAttribute       *ibus_attr_background_new   (guint           color,
Packit Service 1d8f1c
                                                 guint           start_index,
Packit Service 1d8f1c
                                                 guint           end_index);
Packit Service 1d8f1c
Packit Service 1d8f1c
G_END_DECLS
Packit Service 1d8f1c
#endif
Packit Service 1d8f1c