grim/libgnt
Clone
Summary
Browse
Changes
Graph
override the dependency if we're on a new enough version of meson
release-2.x.y
2021-08-03, Gary Kramlich
757982d6c981
override the dependency if we're on a new enough version of meson
Testing Done:
Just ran meson to make sure there weren't any errors.
Reviewed at https://reviews.imfreedom.org/r/836/
/*
* GNT - The GLib Ncurses Toolkit
*
* GNT is the legal property of its developers, whose names are too numerous
* to list here. Please refer to the COPYRIGHT file distributed with this
* source distribution.
*
* This library is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
*/
#ifndef GNT_TEXT_VIEW_H
#define GNT_TEXT_VIEW_H
/**
* SECTION:gnttextview
* @section_id: libgnt-gnttextview
* @title: GntTextView
* @short_description: A widget for displaying larger bodies of formatted text
*/
#include
"gnt.h"
#include
"gntcolors.h"
#include
"gntkeys.h"
#include
"gntwidget.h"
#define GNT_TYPE_TEXT_VIEW (gnt_text_view_get_gtype())
#define GNT_TEXT_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), GNT_TYPE_TEXT_VIEW, GntTextView))
#define GNT_TEXT_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), GNT_TYPE_TEXT_VIEW, GntTextViewClass))
#define GNT_IS_TEXT_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), GNT_TYPE_TEXT_VIEW))
#define GNT_IS_TEXT_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GNT_TYPE_TEXT_VIEW))
#define GNT_TEXT_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), GNT_TYPE_TEXT_VIEW, GntTextViewClass))
#ifndef GNT_DISABLE_DEPRECATED
/**
* GNT_TEXT_VIEW_FLAGS:
*
* Deprecated: 2.14.0: This is an internal implementation detail.
*/
#define GNT_TEXT_VIEW_FLAGS(obj) (GNT_TEXT_VIEW(obj)->priv.flags)
/**
* GNT_TEXT_VIEW_SET_FLAGS:
*
* Deprecated: 2.14.0: This is an internal implementation detail.
*/
#define GNT_TEXT_VIEW_SET_FLAGS(obj, flags) (GNT_TEXT_VIEW_FLAGS(obj) |= flags)
/**
* GNT_TEXT_VIEW_UNSET_FLAGS:
*
* Deprecated: 2.14.0: This is an internal implementation detail.
*/
#define GNT_TEXT_VIEW_UNSET_FLAGS(obj, flags) (GNT_TEXT_VIEW_FLAGS(obj) &= ~(flags))
#endif
typedef
struct
_GntTextView
GntTextView
;
typedef
struct
_GntTextViewClass
GntTextViewClass
;
#ifndef GNT_DISABLE_DEPRECATED
/**
* GntTextViewPriv:
*
* Deprecated: 2.14.0: This is an internal implementation detail.
*/
typedef
struct
_GntTextViewPriv
GntTextViewPriv
;
#endif
/**
* GntTextViewFlag:
*
* Since: 2.1.0
*/
typedef
enum
{
GNT_TEXT_VIEW_NO_SCROLL
=
1
<<
0
,
GNT_TEXT_VIEW_WRAP_CHAR
=
1
<<
1
,
GNT_TEXT_VIEW_TOP_ALIGN
=
1
<<
2
,
/* Since: 2.1.1 */
}
GntTextViewFlag
;
/**
* GntTextView:
*
* Access to any fields is deprecated. See inline comments for replacements.
*/
struct
_GntTextView
{
GntWidget
parent
;
GString
*
GNTSEAL
(
string
);
/* Deprecated. Use gnt_text_view_get_text. */
GList
*
GNTSEAL
(
list
);
/* List of GntTextLine */
GList
*
GNTSEAL
(
tags
);
/* A list of tags */
GntTextViewFlag
GNTSEAL
(
flags
);
};
typedef
enum
{
GNT_TEXT_FLAG_NORMAL
=
0
,
GNT_TEXT_FLAG_BOLD
=
1
<<
0
,
GNT_TEXT_FLAG_UNDERLINE
=
1
<<
1
,
GNT_TEXT_FLAG_BLINK
=
1
<<
2
,
GNT_TEXT_FLAG_DIM
=
1
<<
3
,
GNT_TEXT_FLAG_HIGHLIGHT
=
1
<<
4
,
}
GntTextFormatFlags
;
struct
_GntTextViewClass
{
GntWidgetClass
parent
;
/*< private >*/
void
(
*
gnt_reserved1
)(
void
);
void
(
*
gnt_reserved2
)(
void
);
void
(
*
gnt_reserved3
)(
void
);
void
(
*
gnt_reserved4
)(
void
);
};
G_BEGIN_DECLS
/**
* gnt_text_view_get_gtype:
*
* Returns: GType for GntTextView.
*/
GType
gnt_text_view_get_gtype
(
void
);
/**
* gnt_text_view_new:
*
* Create a new textview.
*
* Returns: The newly created textview.
*/
GntWidget
*
gnt_text_view_new
(
void
);
/**
* gnt_text_view_scroll:
* @view: The textview to scroll.
* @scroll: scroll > 0 means scroll up, < 0 means scroll down, == 0 means scroll to the end.
*
* Scroll the textview.
*/
void
gnt_text_view_scroll
(
GntTextView
*
view
,
int
scroll
);
/**
* gnt_text_view_append_text_with_flags:
* @view: The textview.
* @text: The text to append to the textview.
* @flags: The text-flags to apply to the new text.
*
* Append new text in a textview.
*/
void
gnt_text_view_append_text_with_flags
(
GntTextView
*
view
,
const
char
*
text
,
GntTextFormatFlags
flags
);
/**
* gnt_text_view_append_text_with_tag:
* @view: The textview.
* @text: The text to append.
* @flags: The text-flags to apply to the new text.
* @tag: The tag for the appended text, so it can be changed later (see gnt_text_view_tag_change())
*
* Append text in the textview, with some identifier (tag) for the added text.
*/
void
gnt_text_view_append_text_with_tag
(
GntTextView
*
view
,
const
char
*
text
,
GntTextFormatFlags
flags
,
const
char
*
tag
);
/**
* gnt_text_view_get_text:
* @view: The textview.
*
* Get the text of the textview.
*
* Returns: The text.
*
* Since: 2.14.0
*/
const
gchar
*
gnt_text_view_get_text
(
GntTextView
*
view
);
/**
* gnt_text_view_next_line:
* @view: The textview.
*
* Move the cursor to the beginning of the next line and resets text-attributes.
* It first completes the current line with the current text-attributes.
*/
void
gnt_text_view_next_line
(
GntTextView
*
view
);
#ifndef GNT_DISABLE_DEPRECATED
/**
* gnt_text_format_flag_to_chtype:
* @flags: The GNT text format.
*
* Convert GNT-text formats to ncurses-text attributes.
*
* Returns: Nucrses text attribute.
*
* Deprecated: 2.14.1: This is an internal implementation detail.
*/
chtype
gnt_text_format_flag_to_chtype
(
GntTextFormatFlags
flags
);
#endif
/**
* gnt_text_view_clear:
* @view: The textview.
*
* Clear the contents of the textview.
*/
void
gnt_text_view_clear
(
GntTextView
*
view
);
/**
* gnt_text_view_get_lines_below:
* @view: The textview.
*
* The number of lines below the bottom-most visible line.
*
* Returns: Number of lines below the bottom-most visible line.
*/
int
gnt_text_view_get_lines_below
(
GntTextView
*
view
);
/**
* gnt_text_view_get_lines_above:
* @view: The textview.
*
* The number of lines above the topmost visible line.
*
* Returns: Number of lines above the topmost visible line.
*/
int
gnt_text_view_get_lines_above
(
GntTextView
*
view
);
/**
* gnt_text_view_tag_change:
* @view: The textview.
* @name: The name of the tag.
* @text: The new text for the text. If 'text' is %NULL, the tag is removed.
* @all: %TRUE if all of the instancess of the tag should be changed, %FALSE if
* only the first instance should be changed.
*
* Change the text of a tag.
*
* Returns: The number of instances changed.
*/
int
gnt_text_view_tag_change
(
GntTextView
*
view
,
const
char
*
name
,
const
char
*
text
,
gboolean
all
);
/**
* gnt_text_view_attach_scroll_widget:
* @view: The textview.
* @widget: The trigger widget.
*
* Setup hooks so that pressing up/down/page-up/page-down keys when 'widget' is
* in focus scrolls the textview.
*/
void
gnt_text_view_attach_scroll_widget
(
GntTextView
*
view
,
GntWidget
*
widget
);
/**
* gnt_text_view_attach_pager_widget:
* @view: The textview.
* @pager: The widget to trigger the PAGER.
*
* Setup appropriate hooks so that pressing some keys when the 'pager' widget
* is in focus triggers the PAGER to popup with the contents of the textview
* in it.
*
* The default key-combination to trigger the pager is a-v, and the default
* PAGER application is $PAGER. Both can be changed in ~/.gntrc like this:
*
* <programlisting>
* [pager]
* key = a-v
* path = /path/to/pager
* </programlisting>
*/
void
gnt_text_view_attach_pager_widget
(
GntTextView
*
view
,
GntWidget
*
pager
);
/**
* gnt_text_view_attach_editor_widget:
* @view: The textview.
* @widget: The widget to trigger the EDITOR.
*
* Setup appropriate hooks so that pressing some keys when 'widget'
* is in focus triggers the EDITOR to popup with the contents of the textview
* in it.
*
* The default key-combination to trigger the pager is a-e, and the default
* EDITOR application is $EDITOR. Both can be changed in ~/.gntrc like this:
*
* <programlisting>
* [editor]
* key = a-e
* path = /path/to/editor
* </programlisting>
*/
void
gnt_text_view_attach_editor_widget
(
GntTextView
*
view
,
GntWidget
*
widget
);
/**
* gnt_text_view_set_flag:
* @view: The textview widget
* @flag: The flag to set
*
* Set a GntTextViewFlag for the textview widget.
*
* Since: 2.1.0
*/
void
gnt_text_view_set_flag
(
GntTextView
*
view
,
GntTextViewFlag
flag
);
G_END_DECLS
#endif
/* GNT_TEXT_VIEW_H */