e382869a16
git-svn-id: https://geany.svn.sourceforge.net/svnroot/geany/trunk@4894 ea778897-0a13-0410-b9d1-a72fbfd435f5
306 lines
9.6 KiB
C
306 lines
9.6 KiB
C
/*
|
|
* editor.h - this file is part of Geany, a fast and lightweight IDE
|
|
*
|
|
* Copyright 2005-2010 Enrico Tröger <enrico(dot)troeger(at)uvena(dot)de>
|
|
* Copyright 2006-2010 Nick Treleaven <nick(dot)treleaven(at)btinternet(dot)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., 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
|