updated for version 7.0198

This commit is contained in:
Bram Moolenaar
2006-02-15 22:18:42 +00:00
parent e45828b593
commit 4c7ed462cb
11 changed files with 75 additions and 38 deletions

View File

@ -1,4 +1,4 @@
*change.txt* For Vim version 7.0aa. Last change: 2006 Feb 13 *change.txt* For Vim version 7.0aa. Last change: 2006 Feb 15
VIM REFERENCE MANUAL by Bram Moolenaar VIM REFERENCE MANUAL by Bram Moolenaar
@ -1171,7 +1171,7 @@ gq{motion} Format the lines that {motion} moves over.
Formatting is done with one of three methods: Formatting is done with one of three methods:
1. If 'formatexpr' is not empty the expression is 1. If 'formatexpr' is not empty the expression is
evaluated. This can differ for each buffer. evaluated. This can differ for each buffer.
2. If 'formatprg' is not mepty an external program 2. If 'formatprg' is not empty an external program
is used. is used.
3. Otherise formatting is done internally. 3. Otherise formatting is done internally.

View File

@ -1,4 +1,4 @@
*todo.txt* For Vim version 7.0aa. Last change: 2006 Feb 14 *todo.txt* For Vim version 7.0aa. Last change: 2006 Feb 15
VIM REFERENCE MANUAL by Bram Moolenaar VIM REFERENCE MANUAL by Bram Moolenaar
@ -32,22 +32,20 @@ be worked on, but only if you sponsor Vim development. See |sponsor|.
Support WINDOW TABS. Works like several pages, each with their own split Support WINDOW TABS. Works like several pages, each with their own split
windows. Let's call them "tab pages". windows. Let's call them "tab pages".
- Mouse click in tab name should select that tab.
todo: - line at top of frame with tabs.
- ":qa"? for the name ignore the help window, unless it's the only one).
- "2gt" doesn't restore syntax HL. GUI: scrollbars are wrong. Add a number for the window count?
- line at top of frame with tabs. 'tabline' option 0/1/2 like 'laststatus' Add a '+' if one of the windows is modified?
Use the name of the first buffer in the tab (ignoring the help window,
unless it's the only one). Add a number for the window count.
Add 'tabtext' option, like 'statusline'. Add 'tabtext' option, like 'statusline'.
Select tab with mouse. Add an "X" to close the current tab (like firefox).
- When deleting a buffer also close windows in other tab pages. - When deleting a buffer also close windows in other tab pages.
- check all places where (firstwin == lastwin) is used (and vise versa) - check all places where firstwin and lastwin are used
- check all places wheren only_one_window() is used. - check all places wheren only_one_window() is used.
- When Vim window is resized all tabs must be resized. - Add tabpage(): returns current tab page number.
- E999 - E999
- ":tabclose N" close tab N - ":tabclose N" close tab N
docs: - docs:
:tabedit :tabedit
:tabfind :tabfind
:tab N :tab N
@ -58,21 +56,20 @@ windows. Let's call them "tab pages".
"gt": Use "1gt" - "99gt" to switch to another tab. "gt" goes to the "gt": Use "1gt" - "99gt" to switch to another tab. "gt" goes to the
next one. Hint in docs: To mess with another buffer, without next one. Hint in docs: To mess with another buffer, without
changing the window layout, do this in another tab. changing the window layout, do this in another tab.
'tabline' values 0/1/2
add GUI Tabs for some systems. - add GUI Tabs for some systems.
Patch for GTK 1.2 passed on by Christian Michon, 2004 Jan 6. Patch for GTK 1.2 passed on by Christian Michon, 2004 Jan 6.
Simple patch for GTK by Luis M (nov 7). Simple patch for GTK by Luis M (nov 7).
- Need to be able to search the windows in inactive tabs, e.g. for the
Don't forget to provide an "X" to close the current tab. quickfix window.
Need to be able to search the windows in inactive tabs, e.g. for the
quickfix window.
Crash with X command server (Ciaran McCreesh). Crash with X command server (Ciaran McCreesh).
Ctags still hasn't included the patch... Ctags still hasn't included the patch...
"fsutil hardlink" can create a hard link on an NTFS file system. (Daniel
Einspanjer) What library function can detect that?
spelling: spelling:
- Also use the spelling dictionary for dictionary completion. - Also use the spelling dictionary for dictionary completion.
When 'dictionary' is empty and/or when "kspell" is in 'complete'. When 'dictionary' is empty and/or when "kspell" is in 'complete'.

View File

@ -3456,6 +3456,9 @@ update_window_manager_hints(void)
* otherwise the hints don't work. */ * otherwise the hints don't work. */
width = gui_get_base_width(); width = gui_get_base_width();
height = gui_get_base_height(); height = gui_get_base_height();
# ifdef FEAT_MENU
height += tabpageline_height() * gui.char_height;
# endif
# ifdef HAVE_GTK2 # ifdef HAVE_GTK2
width += get_menu_tool_width(); width += get_menu_tool_width();
height += get_menu_tool_height(); height += get_menu_tool_height();

View File

@ -2181,6 +2181,13 @@ static struct vimoption
{(char_u *)0L, (char_u *)0L} {(char_u *)0L, (char_u *)0L}
#endif #endif
}, },
{"tabline", "tal", P_NUM|P_VI_DEF|P_RALL,
#ifdef FEAT_WINDOWS
(char_u *)&p_tal, PV_NONE,
#else
(char_u *)NULL, PV_NONE,
#endif
{(char_u *)1L, (char_u *)0L}},
{"tabstop", "ts", P_NUM|P_VI_DEF|P_RBUF, {"tabstop", "ts", P_NUM|P_VI_DEF|P_RBUF,
(char_u *)&p_ts, PV_TS, (char_u *)&p_ts, PV_TS,
{(char_u *)8L, (char_u *)0L}}, {(char_u *)8L, (char_u *)0L}},
@ -7259,6 +7266,12 @@ set_num_option(opt_idx, varp, value, errbuf, errbuflen, opt_flags)
{ {
last_status(FALSE); last_status(FALSE);
} }
/* (re)set tab page line */
else if (pp == &p_tal)
{
shell_new_rows(); /* recompute window positions and heights */
}
#endif #endif
#ifdef FEAT_GUI #ifdef FEAT_GUI

View File

@ -577,6 +577,7 @@ EXTERN char_u *p_lispwords; /* 'lispwords' */
#endif #endif
#ifdef FEAT_WINDOWS #ifdef FEAT_WINDOWS
EXTERN long p_ls; /* 'laststatus' */ EXTERN long p_ls; /* 'laststatus' */
EXTERN long p_tal; /* 'tabline' */
#endif #endif
EXTERN char_u *p_lcs; /* 'listchars' */ EXTERN char_u *p_lcs; /* 'listchars' */

View File

@ -34,6 +34,7 @@ void gui_send_mouse_event __ARGS((int button, int x, int y, int repeated_click,
int gui_xy2colrow __ARGS((int x, int y, int *colp)); int gui_xy2colrow __ARGS((int x, int y, int *colp));
void gui_menu_cb __ARGS((vimmenu_T *menu)); void gui_menu_cb __ARGS((vimmenu_T *menu));
void gui_init_which_components __ARGS((char_u *oldval)); void gui_init_which_components __ARGS((char_u *oldval));
void gui_remove_scrollbars __ARGS((void));
void gui_create_scrollbar __ARGS((scrollbar_T *sb, int type, win_T *wp)); void gui_create_scrollbar __ARGS((scrollbar_T *sb, int type, win_T *wp));
scrollbar_T *gui_find_scrollbar __ARGS((long ident)); scrollbar_T *gui_find_scrollbar __ARGS((long ident));
void gui_drag_scrollbar __ARGS((scrollbar_T *sb, long value, int still_dragging)); void gui_drag_scrollbar __ARGS((scrollbar_T *sb, long value, int still_dragging));

View File

@ -26,6 +26,7 @@ void shell_new_rows __ARGS((void));
void shell_new_columns __ARGS((void)); void shell_new_columns __ARGS((void));
void win_size_save __ARGS((garray_T *gap)); void win_size_save __ARGS((garray_T *gap));
void win_size_restore __ARGS((garray_T *gap)); void win_size_restore __ARGS((garray_T *gap));
int win_comp_pos __ARGS((void));
void win_setheight __ARGS((int height)); void win_setheight __ARGS((int height));
void win_setheight_win __ARGS((int height, win_T *win)); void win_setheight_win __ARGS((int height, win_T *win));
void win_setwidth __ARGS((int width)); void win_setwidth __ARGS((int width));

View File

@ -701,8 +701,14 @@ updateWindow(wp)
if (clip_star.available && clip_isautosel()) if (clip_star.available && clip_isautosel())
clip_update_selection(); clip_update_selection();
#endif #endif
win_update(wp); win_update(wp);
#ifdef FEAT_WINDOWS #ifdef FEAT_WINDOWS
/* When the screen was cleared redraw the tab pages line. */
if (redraw_tabpage)
draw_tabpage();
if (wp->w_redr_status if (wp->w_redr_status
# ifdef FEAT_CMDL_INFO # ifdef FEAT_CMDL_INFO
|| p_ru || p_ru
@ -7057,6 +7063,9 @@ screenclear2()
win_rest_invalid(firstwin); win_rest_invalid(firstwin);
redraw_cmdline = TRUE; redraw_cmdline = TRUE;
#ifdef FEAT_WINDOWS
redraw_tabpage = TRUE;
#endif
if (must_redraw == CLEAR) /* no need to clear again */ if (must_redraw == CLEAR) /* no need to clear again */
must_redraw = NOT_VALID; must_redraw = NOT_VALID;
compute_cmdrow(); compute_cmdrow();
@ -8468,11 +8477,14 @@ draw_tabpage()
c = '/'; c = '/';
else else
c = '\\'; c = '\\';
screen_putchar(c, 0, col++, attr); if (t_colors < 8)
screen_putchar(c, 0, col++, attr);
if (tp->tp_topframe != topframe) if (tp->tp_topframe != topframe)
attr = attr_nosel; attr = attr_nosel;
screen_putchar(' ', 0, col++, attr);
if (tp->tp_topframe == topframe) if (tp->tp_topframe == topframe)
wp = curwin; wp = curwin;
else else
@ -8488,11 +8500,17 @@ draw_tabpage()
len = tabwidth; len = tabwidth;
screen_puts_len(NameBuff, len, 0, col, attr); screen_puts_len(NameBuff, len, 0, col, attr);
col += len; col += len;
screen_putchar(' ', 0, col++, attr);
} }
screen_putchar('\\', 0, col++, attr); if (t_colors < 8)
while (col < Columns) {
screen_putchar('_', 0, col++, attr_fill); screen_putchar('\\', 0, col++, attr);
c = '_';
}
else
c = ' ';
screen_fill(0, 1, col, (int)Columns, c, c, attr_fill);
} }
#endif #endif

View File

@ -1555,11 +1555,13 @@ typedef struct w_line
typedef struct tabpage_S tabpage_T; typedef struct tabpage_S tabpage_T;
struct tabpage_S struct tabpage_S
{ {
tabpage_T *tp_next; /* next tabpage or NULL */ tabpage_T *tp_next; /* next tabpage or NULL */
frame_T *tp_topframe; frame_T *tp_topframe; /* topframe for the windows */
win_T *tp_curwin; /* current window in this Tab page */ win_T *tp_curwin; /* current window in this Tab page */
win_T *tp_firstwin; /* first window in this Tab page */ win_T *tp_firstwin; /* first window in this Tab page */
win_T *tp_lastwin; /* last window in this Tab page */ win_T *tp_lastwin; /* last window in this Tab page */
long tp_old_Rows; /* Rows when Tab page was left */
long tp_old_Columns; /* Columns when Tab page was left */
}; };
/* /*

View File

@ -6079,9 +6079,8 @@ static char *(highlight_init_both[]) =
"DiffText term=reverse cterm=bold ctermbg=Red gui=bold guibg=Red", "DiffText term=reverse cterm=bold ctermbg=Red gui=bold guibg=Red",
"PmenuThumb cterm=reverse gui=reverse", "PmenuThumb cterm=reverse gui=reverse",
"PmenuSbar ctermbg=Grey guibg=Grey", "PmenuSbar ctermbg=Grey guibg=Grey",
"TabPage term=underline cterm=underline ctermbg=grey gui=underline guibg=grey", "TabPageSel term=bold cterm=bold gui=bold",
"TabPageSel term=reverse,bold cterm=reverse,bold gui=reverse,bold", "TabPageFill term=reverse cterm=reverse gui=reverse",
"TabPageFill term=underline cterm=underline ctermbg=grey gui=underline guibg=grey",
NULL NULL
}; };
@ -6110,6 +6109,7 @@ static char *(highlight_init_light[]) =
"DiffAdd term=bold ctermbg=LightBlue guibg=LightBlue", "DiffAdd term=bold ctermbg=LightBlue guibg=LightBlue",
"DiffChange term=bold ctermbg=LightMagenta guibg=LightMagenta", "DiffChange term=bold ctermbg=LightMagenta guibg=LightMagenta",
"DiffDelete term=bold ctermfg=Blue ctermbg=LightCyan gui=bold guifg=Blue guibg=LightCyan", "DiffDelete term=bold ctermfg=Blue ctermbg=LightCyan gui=bold guifg=Blue guibg=LightCyan",
"TabPage term=underline cterm=underline ctermbg=LightGrey gui=underline guibg=LightGrey",
NULL NULL
}; };
@ -6138,6 +6138,7 @@ static char *(highlight_init_dark[]) =
"DiffAdd term=bold ctermbg=DarkBlue guibg=DarkBlue", "DiffAdd term=bold ctermbg=DarkBlue guibg=DarkBlue",
"DiffChange term=bold ctermbg=DarkMagenta guibg=DarkMagenta", "DiffChange term=bold ctermbg=DarkMagenta guibg=DarkMagenta",
"DiffDelete term=bold ctermfg=Blue ctermbg=DarkCyan gui=bold guifg=Blue guibg=DarkCyan", "DiffDelete term=bold ctermfg=Blue ctermbg=DarkCyan gui=bold guifg=Blue guibg=DarkCyan",
"TabPage term=underline cterm=underline ctermbg=DarkGrey gui=underline guibg=DarkGrey",
NULL NULL
}; };

View File

@ -36,5 +36,5 @@
#define VIM_VERSION_NODOT "vim70aa" #define VIM_VERSION_NODOT "vim70aa"
#define VIM_VERSION_SHORT "7.0aa" #define VIM_VERSION_SHORT "7.0aa"
#define VIM_VERSION_MEDIUM "7.0aa ALPHA" #define VIM_VERSION_MEDIUM "7.0aa ALPHA"
#define VIM_VERSION_LONG "VIM - Vi IMproved 7.0aa ALPHA (2006 Feb 14)" #define VIM_VERSION_LONG "VIM - Vi IMproved 7.0aa ALPHA (2006 Feb 15)"
#define VIM_VERSION_LONG_DATE "VIM - Vi IMproved 7.0aa ALPHA (2006 Feb 14, compiled " #define VIM_VERSION_LONG_DATE "VIM - Vi IMproved 7.0aa ALPHA (2006 Feb 15, compiled "