2 * document-private.h - this file is part of Geany, a fast and lightweight IDE
4 * Copyright 2008-2011 Enrico Tröger <enrico(dot)troeger(at)uvena(dot)de>
5 * Copyright 2008-2011 Nick Treleaven <nick(dot)treleaven(at)btinternet(dot)com>
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24 #ifndef GEANY_DOCUMENT_PRIVATE_H
25 #define GEANY_DOCUMENT_PRIVATE_H
28 /* available UNDO actions, UNDO_SCINTILLA is a pseudo action to trigger Scintilla's
41 FILE_CHANGED
, /* also valid for deleted files */
47 typedef struct FileEncoding
55 /* Private GeanyDocument fields */
56 typedef struct GeanyDocumentPrivate
58 /* GtkLabel shown in the notebook header. */
60 /* GtkTreeView object for this document within the Symbols treeview of the sidebar. */
62 /* GtkTreeStore object for this document within the Symbols treeview of the sidebar. */
63 GtkTreeStore
*tag_store
;
64 /* Iter for this document within the Open Files treeview of the sidebar. */
66 /* Used by the Undo/Redo management code. */
67 GTrashStack
*undo_actions
;
68 /* Used by the Undo/Redo management code. */
69 GTrashStack
*redo_actions
;
70 /* Used so Undo/Redo works for encoding changes. */
71 FileEncoding saved_encoding
;
72 gboolean colourise_needed
; /* use document.c:queue_colourise() instead */
73 gint line_count
; /* Number of lines in the document. */
74 gint symbol_list_sort_mode
;
75 /* indicates whether a file is on a remote filesystem, works only with GIO/GVfs */
77 /* File status on disk of the document */
78 FileDiskStatus file_disk_status
;
79 /* Reference to a GFileMonitor object, only used when GIO file monitoring is used. */
81 /* Time of the last disk check, only used when legacy file monitoring is used. */
83 /* Modification time of the document on disk, only used when legacy file monitoring is used. */
85 /* ID of the idle callback updating the tag list */
86 guint tag_list_update_source
;