13
0
livetrax/libs/gtkmm2/pango/pangomm/tabarray.h
David Robillard 35fc31a1de Remove ancient/unused flowcanvas and libglademm from repository.
Update libraries to latest stable released version (except gnomecanvasmm, which is strangely packaged...).
Fixes building (at least here).


git-svn-id: svn://localhost/ardour2/trunk@2790 d708f5d6-7413-0410-9779-e7cbd77b26cf
2007-12-18 06:05:55 +00:00

200 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;
/** Return value: whether positions are in pixels.
* @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
{
/** A Glib::wrap() method for this object.
*
* @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.
*
* @relates Pango::TabArray
*/
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 */