1 /* editor initialisation and callback handler.
3 Copyright (C) 1996, 1997, 1998, 2001, 2002, 2003, 2004, 2005, 2006,
4 2007 Free Software Foundation, Inc.
6 Authors: 1996, 1997 Paul Sheer
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
25 * \brief Source: editor initialisation and callback handler
34 #include <sys/types.h>
42 #include "lib/global.h"
44 #include "lib/tty/tty.h" /* LINES, COLS */
45 #include "lib/tty/key.h" /* is_idle() */
47 #include "edit-impl.h"
48 #include "edit-widget.h"
50 #include "src/dialog.h"
51 #include "src/widget.h" /* ButtonBar */
52 #include "src/menu.h" /* menubar_new() */
53 #include "src/cmddef.h"
56 struct WMenuBar
*edit_menubar
;
58 int column_highlighting
= 0;
60 static cb_ret_t
edit_callback (Widget
*, widget_msg_t msg
, int parm
);
63 edit_get_shortcut (unsigned long command
)
66 const char *shortcut
= NULL
;
68 shortcut
= lookup_keymap_shortcut (editor_map
, command
);
70 return g_strdup (shortcut
);
72 ext_map
= lookup_keymap_shortcut (editor_map
, CK_Ext_Mode
);
74 shortcut
= lookup_keymap_shortcut (editor_x_map
, command
);
76 return g_strdup_printf ("%s %s", ext_map
, shortcut
);
82 edit_event (Gpm_Event
*event
, void *data
)
84 WEdit
*edit
= (WEdit
*) data
;
86 /* Unknown event type */
87 if (!(event
->type
& (GPM_DOWN
| GPM_DRAG
| GPM_UP
)))
90 /* rest of the upper frame, the menu is invisible - call menu */
91 if ((event
->type
& GPM_DOWN
) && (event
->y
== 1))
92 return edit_menubar
->widget
.mouse (event
, edit_menubar
);
94 edit_update_curs_row (edit
);
95 edit_update_curs_col (edit
);
97 /* Outside editor window */
98 if (event
->y
<= 1 || event
->x
<= 0
99 || event
->x
> edit
->num_widget_columns
100 || event
->y
> edit
->num_widget_lines
+ 1)
104 if ((event
->buttons
& GPM_B_UP
) && (event
->type
& GPM_DOWN
)) {
105 edit_move_up (edit
, 2, 1);
108 if ((event
->buttons
& GPM_B_DOWN
) && (event
->type
& GPM_DOWN
)) {
109 edit_move_down (edit
, 2, 1);
113 /* A lone up mustn't do anything */
114 if (edit
->mark2
!= -1 && event
->type
& (GPM_UP
| GPM_DRAG
))
117 if (event
->type
& (GPM_DOWN
| GPM_UP
))
118 edit_push_key_press (edit
);
120 if (option_cursor_beyond_eol
) {
121 long line_len
= edit_move_forward3 (edit
, edit_bol (edit
, edit
->curs1
), 0,
122 edit_eol(edit
, edit
->curs1
));
124 if ( event
->x
> line_len
) {
125 edit
->over_col
= event
->x
- line_len
- edit
->start_col
- option_line_state_width
- 1;
126 edit
->prev_col
= line_len
;
129 edit
->prev_col
= event
->x
- option_line_state_width
- edit
->start_col
- 1;
132 edit
->prev_col
= event
->x
- edit
->start_col
- option_line_state_width
- 1;
135 if (--event
->y
> (edit
->curs_row
+ 1))
136 edit_move_down (edit
, event
->y
- (edit
->curs_row
+ 1), 0);
137 else if (event
->y
< (edit
->curs_row
+ 1))
138 edit_move_up (edit
, (edit
->curs_row
+ 1) - event
->y
, 0);
140 edit_move_to_prev_col (edit
, edit_bol (edit
, edit
->curs1
));
142 if (event
->type
& GPM_DOWN
) {
143 edit_mark_cmd (edit
, 1); /* reset */
147 if (!(event
->type
& GPM_DRAG
))
148 edit_mark_cmd (edit
, 0);
151 edit_find_bracket (edit
);
152 edit
->force
|= REDRAW_COMPLETELY
;
153 edit_update_curs_row (edit
);
154 edit_update_curs_col (edit
);
155 edit_update_screen (edit
);
161 edit_command_execute (WEdit
*edit
, unsigned long command
)
163 if (command
== CK_Menu
)
164 edit_menu_cmd (edit
);
166 edit_execute_key_command (edit
, command
, -1);
167 edit_update_screen (edit
);
173 edit_set_buttonbar (WEdit
*edit
, WButtonBar
*bb
)
175 buttonbar_set_label (bb
, 1, Q_("ButtonBar|Help"), editor_map
, (Widget
*) edit
);
176 buttonbar_set_label (bb
, 2, Q_("ButtonBar|Save"), editor_map
, (Widget
*) edit
);
177 buttonbar_set_label (bb
, 3, Q_("ButtonBar|Mark"), editor_map
, (Widget
*) edit
);
178 buttonbar_set_label (bb
, 4, Q_("ButtonBar|Replac"), editor_map
, (Widget
*) edit
);
179 buttonbar_set_label (bb
, 5, Q_("ButtonBar|Copy"), editor_map
, (Widget
*) edit
);
180 buttonbar_set_label (bb
, 6, Q_("ButtonBar|Move"), editor_map
, (Widget
*) edit
);
181 buttonbar_set_label (bb
, 7, Q_("ButtonBar|Search"), editor_map
, (Widget
*) edit
);
182 buttonbar_set_label (bb
, 8, Q_("ButtonBar|Delete"), editor_map
, (Widget
*) edit
);
183 buttonbar_set_label (bb
, 9, Q_("ButtonBar|PullDn"), editor_map
, (Widget
*) edit
);
184 buttonbar_set_label (bb
, 10, Q_("ButtonBar|Quit"), editor_map
, (Widget
*) edit
);
187 /* Callback for the edit dialog */
189 edit_dialog_callback (Dlg_head
*h
, Widget
*sender
,
190 dlg_msg_t msg
, int parm
, void *data
)
194 WButtonBar
*buttonbar
;
196 edit
= (WEdit
*) find_widget_type (h
, edit_callback
);
197 menubar
= find_menubar (h
);
198 buttonbar
= find_buttonbar (h
);
202 edit_set_buttonbar (edit
, buttonbar
);
206 widget_set_size (&edit
->widget
, 0, 0, LINES
- 1, COLS
);
207 widget_set_size (&buttonbar
->widget
, LINES
- 1, 0, 1, COLS
);
208 widget_set_size (&menubar
->widget
, 0, 0, 1, COLS
);
209 menubar_arrange (menubar
);
213 if (sender
== (Widget
*) menubar
)
214 return send_message ((Widget
*) edit
, WIDGET_COMMAND
, parm
);
215 if (sender
== (Widget
*) buttonbar
)
216 return send_message ((Widget
*) edit
, WIDGET_COMMAND
, parm
);
220 if (!edit_ok_to_exit (edit
))
225 return default_dlg_callback (h
, sender
, msg
, parm
, data
);
230 edit_file (const char *_file
, int line
)
232 static gboolean made_directory
= FALSE
;
235 if (!made_directory
) {
236 char *dir
= concat_dir_and_file (home_dir
, EDIT_DIR
);
237 made_directory
= (mkdir (dir
, 0700) != -1 || errno
== EEXIST
);
241 wedit
= edit_init (NULL
, LINES
- 2, COLS
, _file
, line
);
246 /* Create a new dialog and add it widgets to it */
248 create_dlg (0, 0, LINES
, COLS
, NULL
, edit_dialog_callback
,
249 "[Internal File Editor]", NULL
, DLG_WANT_TAB
);
251 edit_dlg
->get_shortcut
= edit_get_shortcut
;
252 edit_menubar
= menubar_new (0, 0, COLS
, NULL
);
253 add_widget (edit_dlg
, edit_menubar
);
254 edit_init_menu (edit_menubar
);
256 init_widget (&(wedit
->widget
), 0, 0, LINES
- 1, COLS
,
257 edit_callback
, edit_event
);
258 widget_want_cursor (wedit
->widget
, 1);
260 add_widget (edit_dlg
, wedit
);
262 add_widget (edit_dlg
, buttonbar_new (TRUE
));
266 destroy_dlg (edit_dlg
);
272 edit_get_file_name (const WEdit
*edit
)
274 return edit
->filename
;
278 edit_update_screen (WEdit
* e
)
280 edit_scroll_screen_over_cursor (e
);
282 edit_update_curs_col (e
);
285 /* pop all events for this window for internal handling */
287 e
->force
|= REDRAW_PAGE
;
289 if (e
->force
& REDRAW_COMPLETELY
)
290 e
->force
|= REDRAW_PAGE
;
291 edit_render_keypress (e
);
296 edit_callback (Widget
*w
, widget_msg_t msg
, int parm
)
298 WEdit
*e
= (WEdit
*) w
;
302 e
->force
|= REDRAW_COMPLETELY
;
303 e
->num_widget_lines
= LINES
- 2;
304 e
->num_widget_columns
= COLS
;
308 edit_update_screen (e
);
314 cb_ret_t ret
= MSG_NOT_HANDLED
;
316 /* The user may override the access-keys for the menu bar. */
317 if (edit_translate_key (e
, parm
, &cmd
, &ch
)) {
318 edit_execute_key_command (e
, cmd
, ch
);
319 edit_update_screen (e
);
321 } else if (edit_drop_hotkey_menu (e
, parm
))
328 /* command from menubar or buttonbar */
329 return edit_command_execute (e
, parm
);
332 widget_move (&e
->widget
, e
->curs_row
+ EDIT_TEXT_VERTICAL_OFFSET
,
333 e
->curs_col
+ e
->start_col
+ e
->over_col
+
334 EDIT_TEXT_HORIZONTAL_OFFSET
+ option_line_state_width
);
342 return default_proc (msg
, parm
);