/* This is -*- C -*- */
/* $Id: guppi-seq.h,v 1.21 2001/11/19 05:40:40 trow Exp $ */
/*
* guppi-seq.h
*
* Copyright (C) 2000 EMC Capital Management, Inc.
* Copyright (C) 2001 The Free Software Foundation
*
* Developed by Jon Trowbridge <trow@gnu.org> and
* Havoc Pennington <hp@pobox.com>.
*
* This program 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307
* USA
*/
#ifndef _INC_GUPPI_SEQ_H
#define _INC_GUPPI_SEQ_H
/* #include <gtk/gtk.h> */
#include "guppi-data.h"
#include "guppi-defs.h"
BEGIN_GUPPI_DECLS
typedef struct _GuppiSeq GuppiSeq;
typedef struct _GuppiSeqClass GuppiSeqClass;
struct _GuppiSeq {
GuppiData parent;
gpointer missing_data;
};
struct _GuppiSeqClass {
GuppiDataClass parent_class;
/* virtual functions */
void (*size_hint) (GuppiSeq *, gsize);
void (*get_bounds) (GuppiSeq *, gint *min, gint *max);
void (*shift_indices) (GuppiSeq *, gint delta);
void (*insert_generic) (GuppiSeq *, gint, gsize);
void (*delete_many) (GuppiSeq *, gint, gsize);
xmlNodePtr (*export_xml_element) (GuppiSeq *seq, gint i, GuppiXMLDocument *);
gboolean (*import_xml_element) (GuppiSeq *seq, GuppiXMLDocument *, xmlNodePtr);
gboolean support_missing_values;
gboolean (*has_missing) (GuppiSeq *);
gsize (*missing_count) (GuppiSeq *);
gboolean (*missing) (GuppiSeq *, gint i);
void (*set_missing) (GuppiSeq *, gint, gboolean);
void (*set_range_missing) (GuppiSeq *, gint i0, gint i1, gboolean x);
void (*set_many_missing) (GuppiSeq *, gint *ind, gsize N, gboolean x);
void (*set_all_missing) (GuppiSeq *, gboolean x);
void (*insert_missing) (GuppiSeq *, gint i, gboolean x, gsize N);
void (*copy_missing) (GuppiSeq *dest, GuppiSeq *src);
/* signals */
void (*changed_shift_indices) (GuppiSeq *seq, gint);
void (*changed_set) (GuppiSeq *seq, gint, gint);
void (*changed_insert) (GuppiSeq *seq, gint, gsize);
void (*changed_grow) (GuppiSeq *seq, gint i0, gint i1);
void (*changed_delete) (GuppiSeq *seq, gint, gsize);
};
#define GUPPI_TYPE_SEQ (guppi_seq_get_type())
#define GUPPI_SEQ(obj) (GTK_CHECK_CAST((obj),GUPPI_TYPE_SEQ,GuppiSeq))
#define GUPPI_SEQ0(obj) ((obj) ? (GUPPI_SEQ(obj)) : NULL)
#define GUPPI_SEQ_CLASS(klass) (GTK_CHECK_CLASS_CAST((klass),GUPPI_TYPE_SEQ,GuppiSeqClass))
#define GUPPI_IS_SEQ(obj) (GTK_CHECK_TYPE((obj), GUPPI_TYPE_SEQ))
#define GUPPI_IS_SEQ0(obj) (((obj) == NULL) || (GUPPI_IS_SEQ(obj)))
#define GUPPI_IS_SEQ_CLASS(klass) (GTK_CHECK_CLASS_TYPE((klass), GUPPI_TYPE_SEQ))
GtkType guppi_seq_get_type (void);
void guppi_seq_size_hint (GuppiSeq *seq, gsize expected_size);
void guppi_seq_indices (const GuppiSeq *seq, gint *min, gint *max);
#define guppi_seq_bounds(seq, min, max) (guppi_seq_indices((seq), (min), (max)))
gint guppi_seq_min_index (const GuppiSeq *seq);
gint guppi_seq_max_index (const GuppiSeq *seq);
/* Size = max index - min index + 1 */
gsize guppi_seq_size (const GuppiSeq *seq);
/* Count = size - # of missing values (so size == count in many cases) */
gsize guppi_seq_count (const GuppiSeq *seq);
gboolean guppi_seq_empty (const GuppiSeq *seq); /* size == 0 */
gboolean guppi_seq_nonempty (const GuppiSeq *seq); /* size != 0 */
gboolean guppi_seq_absent (const GuppiSeq *seq); /* count == 0 */
gboolean guppi_seq_present (const GuppiSeq *seq); /* count != 0 */
gboolean guppi_seq_in_bounds (const GuppiSeq *seq, gint i);
gboolean guppi_seq_contains_bounds (const GuppiSeq *seq, const GuppiSeq *seq2);
gboolean guppi_seq_equal_bounds (const GuppiSeq *seq, const GuppiSeq *seq2);
void guppi_seq_common_bounds (const GuppiSeq *seq, const GuppiSeq *seq2,
gint *min, gint *max);
void guppi_seq_shift_indices (GuppiSeq *seq, gint delta);
void guppi_seq_set_min_index (GuppiSeq *seq, gint min);
void guppi_seq_set_max_index (GuppiSeq *seq, gint max);
void guppi_seq_delete (GuppiSeq *seq, gint i);
void guppi_seq_delete_many (GuppiSeq *seq, gint i, gsize N);
void guppi_seq_delete_range (GuppiSeq *seq, gint i0, gint i1);
void guppi_seq_grow_to_include (GuppiSeq *seq, gint i);
void guppi_seq_grow_to_include_range (GuppiSeq *seq, gint i0, gint i1);
void guppi_seq_grow_to_overlap (GuppiSeq *seq, const GuppiSeq *seq_to_overlap);
/* Missing values */
gboolean guppi_seq_has_missing (GuppiSeq *seq);
gsize guppi_seq_missing_count (GuppiSeq *seq);
gboolean guppi_seq_missing (GuppiSeq *seq, gint i);
gboolean guppi_seq_available (GuppiSeq *seq, gint i);
void guppi_seq_set_missing (GuppiSeq *seq, gint i);
void guppi_seq_insert_missing (GuppiSeq *seq, gint i);
void guppi_seq_prepend_missing (GuppiSeq *seq);
void guppi_seq_append_missing (GuppiSeq *seq);
/* Don't call these unless you know what you are doing... */
void guppi_seq_changed_shift_indices (GuppiSeq *seq, gint i, GuppiDataOp *op);
void guppi_seq_changed_set (GuppiSeq *seq, gint i, gint j, GuppiDataOp *op);
void guppi_seq_changed_insert (GuppiSeq *seq, gint i, gsize N, GuppiDataOp *op);
void guppi_seq_changed_grow (GuppiSeq *seq, gint i0, gint i1, GuppiDataOp *op);
void guppi_seq_changed_delete (GuppiSeq *seq, gint i, gsize N, GuppiDataOp *op);
END_GUPPI_DECLS
#endif /* _INC_GUPPI_SEQ_H */
/* $Id: guppi-seq.h,v 1.21 2001/11/19 05:40:40 trow Exp $ */
syntax highlighted by Code2HTML, v. 0.9.1