/* * editor.h - this file is part of Geany, a fast and lightweight IDE * * Copyright 2005-2010 Enrico Tröger * Copyright 2006-2010 Nick Treleaven * * 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., 675 Mass Ave, Cambridge, MA 02139, USA. * * $Id$ */ #ifndef GEANY_EDITOR_H #define GEANY_EDITOR_H 1 #include "Scintilla.h" #include "ScintillaWidget.h" /** Default character set to define which characters should be treated as part of a word. */ #define GEANY_WORDCHARS "_abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789" #define GEANY_MAX_WORD_LENGTH 192 /** Whether to use tabs, spaces or both to indent. */ typedef enum { GEANY_INDENT_TYPE_SPACES, /**< Spaces. */ GEANY_INDENT_TYPE_TABS, /**< Tabs. */ GEANY_INDENT_TYPE_BOTH /**< Both. */ } GeanyIndentType; typedef enum { GEANY_AUTOINDENT_NONE = 0, GEANY_AUTOINDENT_BASIC, GEANY_AUTOINDENT_CURRENTCHARS, GEANY_AUTOINDENT_MATCHBRACES } GeanyAutoIndent; typedef enum { GEANY_VIRTUAL_SPACE_DISABLED = 0, GEANY_VIRTUAL_SPACE_SELECTION = 1, GEANY_VIRTUAL_SPACE_ALWAYS = 3 } GeanyVirtualSpace; /* Auto-close brackets/quotes */ enum { GEANY_AC_PARENTHESIS = 1, GEANY_AC_CBRACKET = 2, GEANY_AC_SBRACKET = 4, GEANY_AC_SQUOTE = 8, GEANY_AC_DQUOTE = 16 }; /** Geany indicator types, can be used with Editor indicator functions to highlight * text in the document. */ typedef enum { /** Indicator to highlight errors in the document text. This is a red squiggly underline. */ GEANY_INDICATOR_ERROR = 0, /** Indicator used to highlight search results in the document. This is a * rounded box around the text. */ /* start container indicator outside of lexer indicators (0..7), see Scintilla docs */ GEANY_INDICATOR_SEARCH = 8 } GeanyIndicator; /** Indentation prefs that might be different according to project or filetype. * Use @c editor_get_indent_prefs() to lookup the prefs for a particular document. * * @since 0.15 **/ typedef struct GeanyIndentPrefs { gint width; /**< Indent width. */ GeanyIndentType type; /**< Whether to use tabs, spaces or both to indent. */ /** Width of a tab, but only when using GEANY_INDENT_TYPE_BOTH. * To get the display tab width, use sci_get_tab_width(). */ gint hard_tab_width; GeanyAutoIndent auto_indent_mode; gboolean detect_type; } GeanyIndentPrefs; /** Default prefs when creating a new editor window. * Some of these can be overridden per document or per project. */ typedef struct GeanyEditorPrefs { GeanyIndentPrefs *indentation; /*< Default indentation prefs. @see editor_get_indent_prefs(). */ gboolean show_white_space; gboolean show_indent_guide; gboolean show_line_endings; /* 0 - line, 1 - background. This setting may be overriden when a project is opened. Use * @c editor_get_long_line_type(). */ gint long_line_global_type; /* This setting may be overriden when a project is opened. Use @c editor_get_long_line_column(). */ gint long_line_global_column; gchar *long_line_color; gboolean show_markers_margin; /* view menu */ gboolean show_linenumber_margin; /* view menu */ gboolean show_scrollbars; /* hidden pref */ gboolean scroll_stop_at_last_line; gboolean line_wrapping; gboolean use_indicators; gboolean folding; gboolean unfold_all_children; gboolean disable_dnd; gboolean use_tab_to_indent; /* makes tab key indent instead of insert a tab char */ gboolean smart_home_key; gboolean newline_strip; gboolean auto_complete_symbols; gboolean auto_close_xml_tags; gboolean complete_snippets; gint symbolcompletion_min_chars; gint symbolcompletion_max_height; gboolean brace_match_ltgt; /* whether to highlight < and > chars (hidden pref) */ gboolean use_gtk_word_boundaries; /* hidden pref */ gboolean complete_snippets_whilst_editing; /* hidden pref */ gint line_break_column; gboolean auto_continue_multiline; gchar *comment_toggle_mark; guint autocompletion_max_entries; guint autoclose_chars; gboolean autocomplete_doc_words; gboolean completion_drops_rest_of_word; gchar *color_scheme; gint show_virtual_space; /* This setting may be overriden when a project is opened. Use @c editor_get_long_line_type(). */ gboolean long_line_global_enabled; } GeanyEditorPrefs; extern GeanyEditorPrefs editor_prefs; /** Editor-owned fields for each document. */ struct GeanyEditor { GeanyDocument *document; /**< The document associated with the editor. */ ScintillaObject *sci; /**< The Scintilla editor @c GtkWidget. */ gboolean line_wrapping; /**< @c TRUE if line wrapping is enabled. */ gboolean auto_indent; /**< @c TRUE if auto-indentation is enabled. */ /** Percentage to scroll view by on paint, if positive. */ gfloat scroll_percent; GeanyIndentType indent_type; /* Use editor_get_indent_prefs() instead. */ gboolean line_breaking; /**< Whether to split long lines as you type. */ }; typedef struct { gchar *current_word; /* holds word under the mouse or keyboard cursor */ gint click_pos; /* text position where the mouse was clicked */ } EditorInfo; extern EditorInfo editor_info; typedef struct SCNotification SCNotification; void editor_init(void); GeanyEditor *editor_create(GeanyDocument *doc); void editor_destroy(GeanyEditor *editor); ScintillaObject *editor_create_widget(GeanyEditor *editor); void editor_sci_notify_cb(GtkWidget *widget, gint scn, gpointer scnt, gpointer data); gboolean editor_start_auto_complete(GeanyEditor *editor, gint pos, gboolean force); gboolean editor_complete_word_part(GeanyEditor *editor); void editor_goto_next_snippet_cursor(GeanyEditor *editor); gboolean editor_complete_snippet(GeanyEditor *editor, gint pos); void editor_show_macro_list(GeanyEditor *editor); gboolean editor_show_calltip(GeanyEditor *editor, gint pos); void editor_do_comment_toggle(GeanyEditor *editor); void editor_do_comment(GeanyEditor *editor, gint line, gboolean allow_empty_lines, gboolean toggle); gint editor_do_uncomment(GeanyEditor *editor, gint line, gboolean toggle); gint editor_lexer_get_type_keyword_idx(gint lexer); void editor_insert_multiline_comment(GeanyEditor *editor); void editor_insert_alternative_whitespace(GeanyEditor *editor); void editor_indent(GeanyEditor *editor, gboolean increase); void editor_smart_line_indentation(GeanyEditor *editor, gint pos); void editor_indentation_by_one_space(GeanyEditor *editor, gint pos, gboolean decrease); gboolean editor_line_in_view(GeanyEditor *editor, gint line); void editor_scroll_to_line(GeanyEditor *editor, gint line, gfloat percent_of_view); void editor_display_current_line(GeanyEditor *editor, gfloat percent_of_view); void editor_finalize(void); void editor_snippets_init(void); void editor_snippets_free(void); /* 0 - line, 1 - background, 2 - disabled */ gint editor_get_long_line_type(void); gint editor_get_long_line_column(void); /* General editing functions */ void editor_find_current_word(GeanyEditor *editor, gint pos, gchar *word, size_t wordlen, const gchar *wc); gchar *editor_get_word_at_pos(GeanyEditor *editor, gint pos, const gchar *wordchars); gchar *editor_get_default_selection(GeanyEditor *editor, gboolean use_current_word, const gchar *wordchars); void editor_select_word(GeanyEditor *editor); void editor_select_lines(GeanyEditor *editor, gboolean extra_line); void editor_select_paragraph(GeanyEditor *editor); void editor_set_font(GeanyEditor *editor, const gchar *font); void editor_indicator_set_on_line(GeanyEditor *editor, gint indic, gint line); void editor_indicator_clear_errors(GeanyEditor *editor); void editor_indicator_set_on_range(GeanyEditor *editor, gint indic, gint start, gint end); void editor_indicator_clear(GeanyEditor *editor, gint indic); const gchar *editor_get_eol_char_name(GeanyEditor *editor); gint editor_get_eol_char_len(GeanyEditor *editor); const gchar *editor_get_eol_char(GeanyEditor *editor); void editor_fold_all(GeanyEditor *editor); void editor_unfold_all(GeanyEditor *editor); void editor_replace_tabs(GeanyEditor *editor); void editor_replace_spaces(GeanyEditor *editor); void editor_strip_line_trailing_spaces(GeanyEditor *editor, gint line); void editor_strip_trailing_spaces(GeanyEditor *editor); void editor_ensure_final_newline(GeanyEditor *editor); void editor_insert_color(GeanyEditor *editor, const gchar *colour); const GeanyIndentPrefs *editor_get_indent_prefs(GeanyEditor *editor); void editor_set_indent_type(GeanyEditor *editor, GeanyIndentType type); void editor_set_line_wrapping(GeanyEditor *editor, gboolean wrap); gboolean editor_goto_pos(GeanyEditor *editor, gint pos, gboolean mark); gboolean editor_goto_line(GeanyEditor *editor, gint line_no, gint offset); void editor_set_indentation_guides(GeanyEditor *editor); void editor_apply_update_prefs(GeanyEditor *editor); gchar *editor_get_calltip_text(GeanyEditor *editor, const TMTag *tag); void editor_insert_text_block(GeanyEditor *editor, const gchar *text, gint insert_pos, gint cursor_index, gint newline_indent_size, gboolean replace_newlines); void editor_toggle_fold(GeanyEditor *editor, gint line, gint modifiers); #endif