1 /* -*- Mode: C; indent-tabs-mode:nil; c-basic-offset: 8-*- */ 2 3 /* libcroco - Library for parsing and applying CSS 4 * Copyright (C) 2006-2019 Free Software Foundation, Inc. 5 * 6 * This file is not part of the GNU gettext program, but is used with 7 * GNU gettext. 8 * 9 * The original copyright notice is as follows: 10 */ 11 12 /* 13 * This file is part of The Croco Library 14 * 15 * Copyright (C) 2003-2004 Dodji Seketeli. All Rights Reserved. 16 * 17 * This program is free software; you can redistribute it and/or 18 * modify it under the terms of version 2.1 of the GNU Lesser General Public 19 * License as published by the Free Software Foundation. 20 * 21 * This program is distributed in the hope that it will be useful, 22 * but WITHOUT ANY WARRANTY; without even the implied warranty of 23 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 24 * GNU General Public License for more details. 25 * 26 * You should have received a copy of the GNU Lesser General Public License 27 * along with this program; if not, write to the Free Software 28 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 29 * USA 30 */ 31 32 /** 33 *@file 34 *Declaration file of the #CRString class. 35 */ 36 37 #ifndef __CR_STRING_H__ 38 #define __CR_STRING_H__ 39 40 #include <glib.h> 41 #include "cr-utils.h" 42 #include "cr-parsing-location.h" 43 44 G_BEGIN_DECLS 45 46 typedef struct _CRString CRString ; 47 48 /** 49 *This is a ship implementation of string based on GString. 50 *Actually, the aim of CRString is to store the parsing location 51 *(line,column,byte offset) at which a given string has been parsed 52 *in the input CSS. 53 *So this class has a gstring field of type GString that users can 54 *freely manipulate, and also a CRParginLocation type where the 55 *parsing location is store. If you don't want to deal with parsing 56 *location stuffs, then use GString instead. If we were in C++ for example, 57 *CRString would just inherit GString and just add accessors to 58 *the CRParsingLocation data ... but we are not and we still have 59 *to provide the parsing location information. 60 */ 61 struct _CRString { 62 /** 63 *The GString where all the string 64 *operation happen. 65 */ 66 GString *stryng ; 67 /** 68 *The parsing location storage area. 69 */ 70 CRParsingLocation location ; 71 } ; 72 73 CRString * cr_string_new (void) ; 74 75 CRString *cr_string_new_from_string (const gchar * a_string) ; 76 CRString * cr_string_new_from_gstring (GString const *a_string) ; 77 CRString *cr_string_dup (CRString const *a_this) ; 78 gchar *cr_string_dup2 (CRString const *a_this) ; 79 const gchar *cr_string_peek_raw_str (CRString const *a_this) ; 80 gint cr_string_peek_raw_str_len (CRString const *a_this) ; 81 void cr_string_destroy (CRString *a_this) ; 82 83 G_END_DECLS 84 85 #endif 86