196 lines
4.8 KiB
C
196 lines
4.8 KiB
C
|
// -*- c++ -*-
|
||
|
// Generated by gtkmmproc -- DO NOT MODIFY!
|
||
|
#ifndef _PANGOMM_TABARRAY_H
|
||
|
#define _PANGOMM_TABARRAY_H
|
||
|
|
||
|
#include <glibmm.h>
|
||
|
|
||
|
/* $Id$ */
|
||
|
|
||
|
/* tabarray.h
|
||
|
*
|
||
|
* Copyright (C) 1998-1999 The gtkmm Development Team
|
||
|
*
|
||
|
* This library is free software; you can redistribute it and/or
|
||
|
* modify it under the terms of the GNU Library General Public
|
||
|
* License as published by the Free Software Foundation; either
|
||
|
* version 2 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
|
||
|
* Library General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU Library General Public
|
||
|
* License along with this library; if not, write to the Free
|
||
|
* Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||
|
*/
|
||
|
|
||
|
#include <pangomm/attrlist.h>
|
||
|
#include <pango/pango-tabs.h>
|
||
|
#include <pango/pango-break.h> //For PangoLogAttrs.
|
||
|
|
||
|
#include <utility>
|
||
|
#include <glibmmconfig.h>
|
||
|
GLIBMM_USING_STD(pair)
|
||
|
|
||
|
|
||
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
||
|
extern "C" { typedef struct _PangoTabArray PangoTabArray; }
|
||
|
#endif
|
||
|
|
||
|
namespace Pango
|
||
|
{
|
||
|
|
||
|
|
||
|
/** @addtogroup pangommEnums Enums and Flags */
|
||
|
|
||
|
/**
|
||
|
* @ingroup pangommEnums
|
||
|
*/
|
||
|
enum TabAlign
|
||
|
{
|
||
|
TAB_LEFT
|
||
|
};
|
||
|
|
||
|
} // namespace Pango
|
||
|
|
||
|
|
||
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
||
|
namespace Glib
|
||
|
{
|
||
|
|
||
|
template <>
|
||
|
class Value<Pango::TabAlign> : public Glib::Value_Enum<Pango::TabAlign>
|
||
|
{
|
||
|
public:
|
||
|
static GType value_type() G_GNUC_CONST;
|
||
|
};
|
||
|
|
||
|
} // namespace Glib
|
||
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
||
|
|
||
|
|
||
|
namespace Pango
|
||
|
{
|
||
|
|
||
|
|
||
|
/** A Pango::TabArray contains an array of tab stops.
|
||
|
* Each tab stop has an alignment and a position.
|
||
|
*/
|
||
|
class TabArray
|
||
|
{
|
||
|
public:
|
||
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
||
|
typedef TabArray CppObjectType;
|
||
|
typedef PangoTabArray BaseObjectType;
|
||
|
|
||
|
static GType get_type() G_GNUC_CONST;
|
||
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
||
|
|
||
|
TabArray();
|
||
|
|
||
|
explicit TabArray(PangoTabArray* gobject, bool make_a_copy = true);
|
||
|
|
||
|
TabArray(const TabArray& other);
|
||
|
TabArray& operator=(const TabArray& other);
|
||
|
|
||
|
~TabArray();
|
||
|
|
||
|
void swap(TabArray& other);
|
||
|
|
||
|
///Provides access to the underlying C instance.
|
||
|
PangoTabArray* gobj() { return gobject_; }
|
||
|
|
||
|
///Provides access to the underlying C instance.
|
||
|
const PangoTabArray* gobj() const { return gobject_; }
|
||
|
|
||
|
///Provides access to the underlying C instance. The caller is responsible for freeing it. Use when directly setting fields in structs.
|
||
|
PangoTabArray* gobj_copy() const;
|
||
|
|
||
|
protected:
|
||
|
PangoTabArray* gobject_;
|
||
|
|
||
|
private:
|
||
|
|
||
|
|
||
|
public:
|
||
|
explicit TabArray(int initial_size, bool positions_in_pixels = true);
|
||
|
|
||
|
|
||
|
/** Gets the number of tab stops in @a tab_array .
|
||
|
* @return The number of tab stops in the array.
|
||
|
*/
|
||
|
int get_size() const;
|
||
|
|
||
|
/** Resizes a tab array. You must subsequently initialize any tabs that
|
||
|
* were added as a result of growing the array.
|
||
|
* @param new_size New size of the array.
|
||
|
*/
|
||
|
void resize(int new_size);
|
||
|
|
||
|
/** Sets the alignment and location of a tab stop.
|
||
|
* @a alignment must always be Pango::TAB_LEFT in the current
|
||
|
* implementation.
|
||
|
* @param tab_index The index of a tab stop.
|
||
|
* @param alignment Tab alignment.
|
||
|
* @param location Tab location in pango units.
|
||
|
*/
|
||
|
void set_tab(int tab_index, TabAlign alignment, int location);
|
||
|
|
||
|
/** Gets the alignment and position of a tab stop.
|
||
|
* @return An std::pair<TabAlign, int>. The first element represents the tab stop alignment, the second one is the tab position.
|
||
|
*/
|
||
|
std::pair<TabAlign,int> get_tab(int tab_index) const;
|
||
|
|
||
|
/** Gets an array of std::pairs containing the tab stop alignments and tab positions.
|
||
|
* @return An array of std::pair<TabAlign, int>. The first element in each pair represents the tab stop alignment, the second one is the tab position.
|
||
|
*/
|
||
|
Glib::ArrayHandle< std::pair<TabAlign,int> > get_tabs() const;
|
||
|
|
||
|
|
||
|
/** Returns <tt>true</tt> if the tab positions are in pixels, <tt>false</tt> if they are
|
||
|
* in Pango units.
|
||
|
* @return Whether positions are in pixels.
|
||
|
*/
|
||
|
bool get_positions_in_pixels() const;
|
||
|
|
||
|
|
||
|
};
|
||
|
|
||
|
} //namespace Pango
|
||
|
|
||
|
|
||
|
namespace Pango
|
||
|
{
|
||
|
|
||
|
/** @relates Pango::TabArray
|
||
|
* @param lhs The left-hand side
|
||
|
* @param rhs The right-hand side
|
||
|
*/
|
||
|
inline void swap(TabArray& lhs, TabArray& rhs)
|
||
|
{ lhs.swap(rhs); }
|
||
|
|
||
|
} // namespace Pango
|
||
|
|
||
|
namespace Glib
|
||
|
{
|
||
|
|
||
|
/** @relates Pango::TabArray
|
||
|
* @param object The C instance
|
||
|
* @param take_copy False if the result should take ownership of the C instance. True if it should take a new copy or ref.
|
||
|
* @result A C++ instance that wraps this C instance.
|
||
|
*/
|
||
|
Pango::TabArray wrap(PangoTabArray* object, bool take_copy = false);
|
||
|
|
||
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
||
|
template <>
|
||
|
class Value<Pango::TabArray> : public Glib::Value_Boxed<Pango::TabArray>
|
||
|
{};
|
||
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
||
|
|
||
|
} // namespace Glib
|
||
|
|
||
|
#endif /* _PANGOMM_TABARRAY_H */
|
||
|
|