![]() | ![]() | ![]() | Conglomerate Programmer's Reference Manual | ![]() |
---|
CongDocument —
struct CongDocument; #define CONG_DOCUMENT (obj) #define CONG_DOCUMENT_CLASS (klass) #define IS_CONG_DOCUMENT (obj) GType cong_document_get_type (void); CongDocument* cong_document_construct (CongDocument *doc, xmlDocPtr xml_doc, CongDispspec *ds, const gchar *url); CongDocument* cong_document_new_from_xmldoc (xmlDocPtr xml_doc, CongDispspec *ds, const gchar *url); xmlDocPtr cong_document_get_xml (CongDocument *doc); CongNodePtr cong_document_get_root_element (CongDocument *doc); CongDocumentTraversal* cong_document_get_traversal (CongDocument *doc); CongTraversalNode* cong_document_get_root_traversal_node (CongDocument *doc); CongFindDialogData* cong_document_get_find_dialog_data (CongDocument *doc); CongDispspecElement* cong_document_get_dispspec_element_for_node (CongDocument *doc, CongNodePtr node); gchar* cong_document_get_filename (CongDocument *doc); gchar* cong_document_get_full_uri (CongDocument *doc); gchar* cong_document_get_parent_uri (CongDocument *doc); const CongXMLChar* cong_document_get_dtd_public_identifier (CongDocument *doc); xmlNsPtr cong_document_get_xml_ns (CongDocument *doc, const gchar *ns_uri); xmlNsPtr cong_document_get_nsptr (CongDocument *doc, const gchar *xmlns); void cong_document_save (CongDocument *doc, const char *filename, GtkWindow *parent_window); gboolean cong_document_is_modified (CongDocument *doc); void cong_document_set_modified (CongDocument *doc, gboolean modified); void cong_document_set_primary_window (CongDocument *doc, CongPrimaryWindow *window); CongPrimaryWindow* cong_document_get_primary_window (CongDocument *doc); void cong_document_set_url (CongDocument *doc, const gchar *url); glong cong_document_get_seconds_since_last_save_or_load (const CongDocument *doc); gchar* cong_document_get_node_name (CongDocument *doc, CongNodePtr node); guint cong_document_get_num_nodes (CongDocument *doc); void cong_document_node_ref (CongDocument *doc, CongNodePtr node); void cong_document_node_unref (CongDocument *doc, CongNodePtr node); void cong_document_set_with_ref (CongDocument *doc, CongNodePtr *node_ptr, CongNodePtr node); CongCommand* cong_document_begin_command (CongDocument *doc, const gchar *description, const gchar *consolidation_id); void cong_document_end_command (CongDocument *doc, CongCommand *cmd); void cong_document_abort_command (CongDocument *doc, CongCommand *cmd); void cong_document_begin_edit (CongDocument *doc); void cong_document_end_edit (CongDocument *doc); gboolean cong_document_is_within_edit (CongDocument *doc); void cong_document_private_node_make_orphan (CongDocument *doc, CongNodePtr node); void cong_document_private_node_add_after (CongDocument *doc, CongNodePtr node, CongNodePtr older_sibling); void cong_document_private_node_add_before (CongDocument *doc, CongNodePtr node, CongNodePtr younger_sibling); void cong_document_private_node_set_parent (CongDocument *doc, CongNodePtr node, CongNodePtr adoptive_parent, gboolean add_to_end); void cong_document_private_node_set_text (CongDocument *doc, CongNodePtr node, const xmlChar *new_content); void cong_document_private_tag_remove (CongDocument *doc, CongNodePtr x); void cong_document_private_node_set_attribute (CongDocument *doc, CongNodePtr node, xmlNs *ns_ptr, const xmlChar *name, const xmlChar *value); void cong_document_private_node_remove_attribute (CongDocument *doc, CongNodePtr node, xmlNs *ns_ptr, const xmlChar *name); void cong_document_private_on_selection_change (CongDocument *doc); void cong_document_private_on_cursor_change (CongDocument *doc); void cong_document_private_set_dtd_ptr (CongDocument *doc, xmlDtdPtr dtd_ptr); void cong_document_register_view (CongDocument *doc, CongView *view); void cong_document_unregister_view (CongDocument *doc, CongView *view); CongCursor* cong_document_get_cursor (CongDocument *doc); CongSelection* cong_document_get_selection (CongDocument *doc); CongNodePtr cong_document_get_selected_node (CongDocument *doc); PangoLanguage* cong_document_get_language_for_node (CongDocument *doc, CongNodePtr node); CongCommandHistory* cong_document_get_command_history (CongDocument *doc); void cong_document_undo (CongDocument *doc); void cong_document_redo (CongDocument *doc); void cong_document_select_node (CongDocument *doc, CongNodePtr node); void cong_document_cut_selection (CongDocument *doc); void cong_document_copy_selection (CongDocument *doc); gboolean cong_document_can_paste (CongDocument *doc); gboolean cong_document_can_print (CongDocument *doc); void cong_document_paste_clipboard (CongDocument *doc); void cong_document_paste_source_at (CongDocument *doc, CongLocation *insert_loc, const gchar *source_fragment); void cong_document_paste_source_under (CongDocument *doc, CongNodePtr relative_to_node, const gchar *source_fragment); void cong_document_paste_source_before (CongDocument *doc, CongNodePtr relative_to_node, const gchar *source_fragment); void cong_document_paste_source_after (CongDocument *doc, CongNodePtr relative_to_node, const gchar *source_fragment); void cong_document_view_source (CongDocument *doc); gboolean (*CongDocumentRecursionCallback) (CongDocument *doc, CongNodePtr node, gpointer user_data, guint recursion_level); gboolean cong_document_for_each_node (CongDocument *doc, CongDocumentRecursionCallback callback, gpointer callback_data); gboolean cong_document_for_each_child_of_node (CongDocument *doc, CongNodePtr parent, CongDocumentRecursionCallback callback, gpointer callback_data); CongNodePtr cong_document_make_nodes_from_source_fragment (CongDocument *doc, const gchar *source_fragment); xmlElementPtr cong_document_get_dtd_element (CongDocument *cong_doc, CongNodePtr node); GList* cong_document_get_valid_new_child_elements (CongDocument *doc, CongNodePtr node, CongElementType tag_type); GList* cong_document_get_valid_new_previous_sibling_elements (CongDocument *doc, CongNodePtr node, CongElementType tag_type); GList* cong_document_get_valid_new_next_sibling_elements (CongDocument *doc, CongNodePtr node, CongElementType tag_type); gboolean cong_document_node_can_be_deleted (CongDocument *doc, CongNodePtr node);
"begin-edit" void user_function (CongDocument *congdocument, gpointer user_data); "cursor-change" void user_function (CongDocument *congdocument, gpointer user_data); "end-edit" void user_function (CongDocument *congdocument, gpointer user_data); "node-add-after" void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gpointer user_data); "node-add-before" void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gpointer user_data); "node-make-orphan" void user_function (CongDocument *congdocument, gpointer arg1, gpointer user_data); "node-remove-attribute" void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gchar *arg3, gpointer user_data); "node-set-attribute" void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gchar *arg3, gchar *arg4, gpointer user_data); "node-set-parent" void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gboolean arg3, gpointer user_data); "node-set-text" void user_function (CongDocument *congdocument, gpointer arg1, gchar *arg2, gpointer user_data); "selection-change" void user_function (CongDocument *congdocument, gpointer user_data); "set-dtd-ptr" void user_function (CongDocument *congdocument, gpointer arg1, gpointer user_data); "set-url" void user_function (CongDocument *congdocument, gchar *arg1, gpointer user_data);
#define CONG_DOCUMENT(obj) G_TYPE_CHECK_INSTANCE_CAST (obj, CONG_DOCUMENT_TYPE, CongDocument)
obj : |
#define CONG_DOCUMENT_CLASS(klass) G_TYPE_CHECK_CLASS_CAST (klass, CONG_DOCUMENT_TYPE, CongDocumentClass)
klass : |
#define IS_CONG_DOCUMENT(obj) G_TYPE_CHECK_INSTANCE_TYPE (obj, CONG_DOCUMENT_TYPE)
obj : |
CongDocument* cong_document_construct (CongDocument *doc, xmlDocPtr xml_doc, CongDispspec *ds, const gchar *url);
TODO: Write me
doc : | |
xml_doc : | |
ds : | |
url : | |
Returns : |
CongDocument* cong_document_new_from_xmldoc (xmlDocPtr xml_doc, CongDispspec *ds, const gchar *url);
The new CongDocument is created with a reference count of 1; any views constructed of the document will increment its reference count
xml_doc : | The xmlDocPtr which the CongDocument is to wrap. It takes ownership of it. |
ds : | |
url : | |
Returns : | the new CongDocument |
xmlDocPtr cong_document_get_xml (CongDocument *doc);
Retrieve the xmlDocPtr wrapped by a CongDocument. You should not attempt to modify it directly, but instead use methods of the CongDocument
doc : | The CongDocument. |
Returns : | the xmlDocPtr wrapped by the CongDocument |
CongNodePtr cong_document_get_root_element (CongDocument *doc);
doc : | |
Returns : | the root element of the document, if any (as opposed to the root node) |
CongDocumentTraversal* cong_document_get_traversal (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
CongTraversalNode* cong_document_get_root_traversal_node (CongDocument *doc);
The CongDocumentTraversal maintains a tree of CongTraversalNode objects corresponding to a depth-first traversal of its xml tree, but with the entity references having only the entity definition as their sole child.
doc : | The CongDocumentTraversal of interest |
Returns : | the CongTraversalNode corresponding to the root xml node of the document |
CongFindDialogData* cong_document_get_find_dialog_data (CongDocument *doc);
doc : | |
Returns : |
CongDispspecElement* cong_document_get_dispspec_element_for_node (CongDocument *doc, CongNodePtr node);
TODO: Write me
doc : | |
node : | |
Returns : |
gchar* cong_document_get_filename (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
gchar* cong_document_get_full_uri (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
gchar* cong_document_get_parent_uri (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
const CongXMLChar* cong_document_get_dtd_public_identifier (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
xmlNsPtr cong_document_get_xml_ns (CongDocument *doc, const gchar *ns_uri);
Locates a namespace by URI within a CongDocument
doc : | The CongDocument of interest |
ns_uri : | The URI of the namespace |
Returns : | the xmlNsPtr for the namespace, or NULL if not found |
xmlNsPtr cong_document_get_nsptr (CongDocument *doc, const gchar *xmlns);
doc : | |
xmlns : | |
Returns : |
void cong_document_save (CongDocument *doc, const char *filename, GtkWindow *parent_window);
TODO: Write me
doc : | |
filename : | |
parent_window : |
gboolean cong_document_is_modified (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
void cong_document_set_modified (CongDocument *doc, gboolean modified);
TODO: Write me
doc : | |
modified : |
void cong_document_set_primary_window (CongDocument *doc, CongPrimaryWindow *window);
TODO: Write me
doc : | |
window : |
CongPrimaryWindow* cong_document_get_primary_window (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
void cong_document_set_url (CongDocument *doc, const gchar *url);
TODO: Write me
doc : | |
url : |
glong cong_document_get_seconds_since_last_save_or_load (const CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
gchar* cong_document_get_node_name (CongDocument *doc, CongNodePtr node);
Generate a user-visible, translated string that is a name for this node.
doc : | |
node : | |
Returns : | the node name, which must be deleted by the caller. |
guint cong_document_get_num_nodes (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
void cong_document_node_ref (CongDocument *doc, CongNodePtr node);
Add an "external reference" to the node; it will not be deleted until it has been both removed from the tree AND has lost all external references.
doc : | |
node : |
void cong_document_node_unref (CongDocument *doc, CongNodePtr node);
Remove an "external reference" to the node; it will be deleted if it has been both removed from the tree AND this was its last external reference.
doc : | |
node : |
void cong_document_set_with_ref (CongDocument *doc, CongNodePtr *node_ptr, CongNodePtr node);
Sets node_ptr to node, doing any necessary reference count modifications to the old and new value
doc : | |
node_ptr : | A pointer to a CongNodePtr |
node : | a ptr to a node, or NULL |
CongCommand* cong_document_begin_command (CongDocument *doc, const gchar *description, const gchar *consolidation_id);
Begins creating a named command which will act upon the document. You can then add modifications to this command, and then finish with a call to cong_document_end_command()
doc : | The CongDocument upon which the command is to act. |
description : | Human-readable, translated name for this command, as it will appear in the undo/redo history widget |
consolidation_id : | A string ID (or NULL) for this command to allow multiple similar commands to be consolidated into a single command. For example, multiple characters being typed at the keboard can be merged into a single "Typing" command. |
Returns : | a CongCommand to which modifications should be added |
void cong_document_end_command (CongDocument *doc, CongCommand *cmd);
Finish creating a command which has acted upon the document. You should have created this command using a call to cong_document_begin_command()
doc : | The CongDocument upon which the command acted. |
cmd : | The CongCommand which is now complete |
void cong_document_abort_command (CongDocument *doc, CongCommand *cmd);
Finish command without applying it to document
doc : | The CongDocument upon which the command acted. |
cmd : | The CongCommand which should be aborted |
gboolean cong_document_is_within_edit (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
void cong_document_private_node_make_orphan (CongDocument *doc, CongNodePtr node);
TODO: Write me
doc : | |
node : |
void cong_document_private_node_add_after (CongDocument *doc, CongNodePtr node, CongNodePtr older_sibling);
TODO: Write me
doc : | |
node : | |
older_sibling : |
void cong_document_private_node_add_before (CongDocument *doc, CongNodePtr node, CongNodePtr younger_sibling);
TODO: Write me
doc : | |
node : | |
younger_sibling : |
void cong_document_private_node_set_parent (CongDocument *doc, CongNodePtr node, CongNodePtr adoptive_parent, gboolean add_to_end);
TODO: Write me
doc : | |
node : | |
adoptive_parent : | |
add_to_end : | if TRUE, add the node to the end of the parent's list; if FALSE add to the start |
void cong_document_private_node_set_text (CongDocument *doc, CongNodePtr node, const xmlChar *new_content);
TODO: Write me
doc : | |
node : | |
new_content : |
void cong_document_private_tag_remove (CongDocument *doc, CongNodePtr x);
doc : | |
x : |
void cong_document_private_node_set_attribute (CongDocument *doc, CongNodePtr node, xmlNs *ns_ptr, const xmlChar *name, const xmlChar *value);
TODO: Write me
doc : | |
node : | |
ns_ptr : | |
name : | |
value : |
void cong_document_private_node_remove_attribute (CongDocument *doc, CongNodePtr node, xmlNs *ns_ptr, const xmlChar *name);
TODO: Write me
doc : | |
node : | |
ns_ptr : | |
name : |
void cong_document_private_on_selection_change (CongDocument *doc);
TODO: Write me
doc : |
void cong_document_private_on_cursor_change (CongDocument *doc);
TODO: Write me
doc : |
void cong_document_private_set_dtd_ptr (CongDocument *doc, xmlDtdPtr dtd_ptr);
TODO: Write me
doc : | |
dtd_ptr : |
void cong_document_register_view (CongDocument *doc, CongView *view);
TODO: Write me
doc : | |
view : |
void cong_document_unregister_view (CongDocument *doc, CongView *view);
TODO: Write me
doc : | |
view : |
CongCursor* cong_document_get_cursor (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
CongSelection* cong_document_get_selection (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
CongNodePtr cong_document_get_selected_node (CongDocument *doc);
Convenience wrapper around CongSelection for dealing with selection of specific nodes (as opposed to text ranges).
doc : | the document |
Returns : | If a specific node is selected, returns that node. If a text range is selected instead, or there is no selection, NULL is returned. |
PangoLanguage* cong_document_get_language_for_node (CongDocument *doc, CongNodePtr node);
Every node within a document has an implied language, although the logic to determine this may depend on the dispspec, on attributes of the nodes, and perhaps even on user prefererences (and hence the value may change unexpectedly).
doc : | |
node : | |
Returns : | a PangoLanguage ptr which will exist for the whole lifetime of the program |
CongCommandHistory* cong_document_get_command_history (CongDocument *doc);
TODO: Write me
doc : | |
Returns : |
void cong_document_select_node (CongDocument *doc, CongNodePtr node);
TODO: Write me
doc : | |
node : |
void cong_document_cut_selection (CongDocument *doc);
TODO: Write me
doc : |
void cong_document_copy_selection (CongDocument *doc);
TODO: Write me
doc : |
gboolean cong_document_can_paste (CongDocument *doc);
doc : | |
Returns : | TRUE |
void cong_document_paste_clipboard (CongDocument *doc);
TODO: Write me
doc : |
void cong_document_paste_source_at (CongDocument *doc, CongLocation *insert_loc, const gchar *source_fragment);
TODO: Write me
doc : | |
insert_loc : | |
source_fragment : |
void cong_document_paste_source_under (CongDocument *doc, CongNodePtr relative_to_node, const gchar *source_fragment);
TODO: Write me
doc : | |
relative_to_node : | |
source_fragment : |
void cong_document_paste_source_before (CongDocument *doc, CongNodePtr relative_to_node, const gchar *source_fragment);
TODO: Write me
doc : | |
relative_to_node : | |
source_fragment : |
void cong_document_paste_source_after (CongDocument *doc, CongNodePtr relative_to_node, const gchar *source_fragment);
TODO: Write me
doc : | |
relative_to_node : | |
source_fragment : |
void cong_document_view_source (CongDocument *doc);
TODO: Write me
doc : |
gboolean (*CongDocumentRecursionCallback) (CongDocument *doc, CongNodePtr node, gpointer user_data, guint recursion_level);
doc : | |
node : | |
user_data : | |
recursion_level : | |
Returns : |
gboolean cong_document_for_each_node (CongDocument *doc, CongDocumentRecursionCallback callback, gpointer callback_data);
TODO: Write me
doc : | |
callback : | |
callback_data : | |
Returns : |
gboolean cong_document_for_each_child_of_node (CongDocument *doc, CongNodePtr parent, CongDocumentRecursionCallback callback, gpointer callback_data);
TODO: Write me
doc : | |
parent : | |
callback : | |
callback_data : | |
Returns : |
CongNodePtr cong_document_make_nodes_from_source_fragment (CongDocument *doc, const gchar *source_fragment);
TODO: Write me
doc : | |
source_fragment : | |
Returns : |
xmlElementPtr cong_document_get_dtd_element (CongDocument *cong_doc, CongNodePtr node);
Helper function to get the xmlElementPtr within the DTD for a node Currently only looks at the actual DTD, but in future might attempt to use the dispspec to infer an DTD and return that So don't store the return value; it might get deleted etc
cong_doc : | |
node : | |
Returns : |
GList* cong_document_get_valid_new_child_elements (CongDocument *doc, CongNodePtr node, CongElementType tag_type);
Get the set of valid children for a node. If the document contains a DTD, this function will return the intersection of the valid children and elements in the display spec of type tag_type. If the document does not contain a dtd, the function will fallback on returning the elements in the display spec of type tag_type.
doc : | |
node : | node for which to get valid children |
tag_type : | either CONG_ELEMENT_TYPE_STRUCTURAL, CONG_ELEMENT_TYPE_SPAN, or CONG_ELEMENT_TYPE_ALL |
Returns : | GList of CongElementDescription |
GList* cong_document_get_valid_new_previous_sibling_elements (CongDocument *doc, CongNodePtr node, CongElementType tag_type);
Get the set of valid previous siblings for a node. If the document contains a DTD, this function will return the intersection of the valid previous siblings and elements in the display spec of type tag_type. If the document does not contain a dtd, the function will fallback on returning the elements in the display spec of type tag_type.
doc : | |
node : | CongNodePtr node for which to get valid previous siblings |
tag_type : | either CONG_ELEMENT_TYPE_STRUCTURAL, CONG_ELEMENT_TYPE_SPAN, or CONG_ELEMENT_TYPE_ALL |
Returns : | GList of CongElementDescription |
GList* cong_document_get_valid_new_next_sibling_elements (CongDocument *doc, CongNodePtr node, CongElementType tag_type);
Get the set of valid next siblings for a node. If the document contains a DTD, this function will return the intersection of the valid next siblings and elements in the display spec of type tag_type. If the document does not contain a dtd, the function will fallback on returning the elements in the display spec of type tag_type.
doc : | |
node : | node for which to get valid next siblings |
tag_type : | either CONG_ELEMENT_TYPE_STRUCTURAL, CONG_ELEMENT_TYPE_SPAN, or CONG_ELEMENT_TYPE_ALL |
Returns : | GList of CongElementDescription |
gboolean cong_document_node_can_be_deleted (CongDocument *doc, CongNodePtr node);
Helper function that determines if a node can safely be deleted. It will fail if the node or its subtree contains the cursor or the start/end of the selection, to avoid these containing dangling pointers to dead memory. Used to fix bug 108530, to ensure that the cursor and selection are always moved out of the way.
doc : | |
node : | |
Returns : | TRUE if the node can be safely deleted, FALSE otherwise |
void user_function (CongDocument *congdocument, gpointer user_data);
congdocument : | the object which received the signal. |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer user_data);
congdocument : | the object which received the signal. |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer user_data);
congdocument : | the object which received the signal. |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gpointer user_data);
congdocument : | the object which received the signal. |
arg1 : | |
arg2 : | |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gpointer user_data);
congdocument : | the object which received the signal. |
arg1 : | |
arg2 : | |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer arg1, gpointer user_data);
congdocument : | the object which received the signal. |
arg1 : | |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gchar *arg3, gpointer user_data);
congdocument : | the object which received the signal. |
arg1 : | |
arg2 : | |
arg3 : | |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gchar *arg3, gchar *arg4, gpointer user_data);
congdocument : | the object which received the signal. |
arg1 : | |
arg2 : | |
arg3 : | |
arg4 : | |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer arg1, gpointer arg2, gboolean arg3, gpointer user_data);
congdocument : | the object which received the signal. |
arg1 : | |
arg2 : | |
arg3 : | |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer arg1, gchar *arg2, gpointer user_data);
congdocument : | the object which received the signal. |
arg1 : | |
arg2 : | |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer user_data);
congdocument : | the object which received the signal. |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gpointer arg1, gpointer user_data);
congdocument : | the object which received the signal. |
arg1 : | |
user_data : | user data set when the signal handler was connected. |
void user_function (CongDocument *congdocument, gchar *arg1, gpointer user_data);
congdocument : | the object which received the signal. |
arg1 : | |
user_data : | user data set when the signal handler was connected. |
<< CongApp | CongDocumentTraversal >> |