diff options
-rw-r--r-- | ChangeLog | 13 | ||||
-rw-r--r-- | doc-jp/README.menu | 11 | ||||
-rw-r--r-- | menu.c | 94 |
3 files changed, 109 insertions, 9 deletions
@@ -1,3 +1,14 @@ +2002-11-28 Hironori SAKAMOTO <hsaka@mth.biglobe.ne.jp> + + * [w3m-dev 03493] scroll menu + * menu.c (mLineU): added + (mLineD): added + (MenuKeymap): C-r, C-s, J, K + (mouse_scroll_line): added + (process_mMouse): drag + BTN4, BTN5 + * doc-jp/README.menu: update + 2002-11-27 Fumitoshi UKAI <ukai@debian.or.jp> * version.c.in: w3m/0.3.2.1+cvs @@ -5204,4 +5215,4 @@ a * [w3m-dev 03276] compile error on EWS4800 * release-0-2-1 * import w3m-0.2.1 -$Id: ChangeLog,v 1.565 2002/11/27 03:06:04 ukai Exp $ +$Id: ChangeLog,v 1.566 2002/11/27 16:28:36 ukai Exp $ diff --git a/doc-jp/README.menu b/doc-jp/README.menu index 6700e65..0cb8424 100644 --- a/doc-jp/README.menu +++ b/doc-jp/README.menu @@ -1,6 +1,6 @@ w3m �Υ�˥塼�ˤĤ��� - (1999/11/03) ���� ��§ + (2002/11/27) ���� ��§ hsaka@mth.biglobe.ne.jp [1] ������� @@ -13,10 +13,16 @@ w3m �Υ�˥塼�ˤĤ��� BS(C-h), DEL(C-?), ������ : ��� C-n, j, ������ : ���ι��ܤ� C-p, k, ������ : ��ι��ܤ� + J : ���ܤ��˥��������� + K : ���ܤ˥��������� C-a : ��Ƭ�ι��ܤ� C-e : �Ǹ�ι��ܤ� C-f, C-v : ���ڡ����ι��ܤ� C-b, M-v : ���ڡ����ι��ܤ� + C-s, / : ���ܤ˸����äƸ��� + C-r, ? : ���ܤ��˸����äƸ��� + n : ���ι��ܤ� + N : ���ι��ܤ� C-z : �����ڥ�� # INS ���̾� ^[[2~ �Ǥ��� ^[[L(������), ^[[E(PocketBSD) �ˤ� @@ -41,6 +47,7 @@ w3m �Υ�˥塼�ˤĤ��� �� (�ȳ�) : ���(��˥塼�ξõ�) �� ( : ) : ���ڡ����ޤ������ڡ����ι��ܤ� (Ĺ����˥塼�ξ��) + �� (�ɥ�å�) : ���������� [3] ��˥塼�Υ������ޥ��� @@ -62,7 +69,7 @@ w3m �Υ�˥塼�ˤĤ��� ��� menu.default �� menu.submenu �Ƥ��������� ����Ǥ��륳�ޥ��(FUNCTION)�� README.func �Ƥ��������� MENU_ID �Ȥ��� "Main" �ϥᥤ���˥塼�ˡ�"Select" �ϥХåե����� - ��˥塼��ͽ��Ƥ��ޤ��� + ��˥塼�ˡ�"SelectTab" �ϥ��������˥塼��ͽ��Ƥ��ޤ��� KEYS �ϥХ���ɤ��륭����ʣ�������ǽ�Ǥ��� DATA �����ꤵ��Ƥ���Х��ޥ��(FUNCTION)�ΰ����Ȥ��ƻȤ��ޤ��� @@ -1,4 +1,4 @@ -/* $Id: menu.c,v 1.20 2002/11/25 16:57:17 ukai Exp $ */ +/* $Id: menu.c,v 1.21 2002/11/27 16:28:37 ukai Exp $ */ /* * w3m menu.c */ @@ -85,6 +85,8 @@ static int mNext(char c); static int mPrev(char c); static int mFore(char c); static int mBack(char c); +static int mLineU(char c); +static int mLineD(char c); static int mOk(char c); static int mCancel(char c); static int mClose(char c); @@ -109,7 +111,7 @@ static int (*MenuKeymap[128]) (char c) = { /* C-h C-i C-j C-k C-l C-m C-n C-o */ mCancel,mNull, mOk, mNull, mNull, mOk, mDown, mNull, /* C-p C-q C-r C-s C-t C-u C-v C-w */ - mUp, mNull, mNull, mNull, mNull, mNull, mNext, mNull, + mUp, mNull, mSrchB, mSrchF, mNull, mNull, mNext, mNull, /* C-x C-y C-z C-[ C-\ C-] C-^ C-_ */ mNull, mNull, mSusp, mEsc, mNull, mNull, mNull, mNull, /* SPC ! " # $ % & ' */ @@ -123,7 +125,7 @@ static int (*MenuKeymap[128]) (char c) = { /* @ A B C D E F G */ mNull, mNull, mNull, mNull, mNull, mNull, mNull, mNull, /* H I J K L M N O */ - mNull, mNull, mNull, mNull, mNull, mNull, mSrchP, mNull, + mNull, mNull, mLineU, mLineD, mNull, mNull, mSrchP, mNull, /* P Q R S T U V W */ mNull, mNull, mNull, mNull, mNull, mNull, mNull, mNull, /* X Y Z [ \ ] ^ _ */ @@ -897,6 +899,42 @@ mBack(char c) } static int +mLineU(char c) +{ + int mselect = CurrentMenu->select; + + if (mselect >= CurrentMenu->nitem) + return mLast(c); + if (CurrentMenu->offset + CurrentMenu->height >= CurrentMenu->nitem) + mselect++; + else { + down_menu(CurrentMenu, 1); + if (mselect < CurrentMenu->offset) + mselect++; + } + goto_menu(CurrentMenu, mselect, 1); + return (MENU_NOTHING); +} + +static int +mLineD(char c) +{ + int mselect = CurrentMenu->select; + + if (mselect <= 0) + return mTop(c); + if (CurrentMenu->offset <= 0) + mselect--; + else { + up_menu(CurrentMenu, 1); + if (mselect >= CurrentMenu->offset + CurrentMenu->height) + mselect--; + } + goto_menu(CurrentMenu, mselect, -1); + return (MENU_NOTHING); +} + +static int mOk(char c) { int mselect = CurrentMenu->select; @@ -1087,10 +1125,21 @@ mSrchP(char c) #define MOUSE_BTN_RESET -1 static int +mMouse_scroll_line(void) +{ + int i = 0; + if (relative_wheel_scroll) + i = (relative_wheel_scroll_ratio * CurrentMenu->height + 99) / 100; + else + i = fixed_wheel_scroll_count; + return i ? i : 1; +} + +static int process_mMouse(int btn, int x, int y) { Menu *menu; - int mselect; + int mselect, i; static int press_btn = MOUSE_BTN_RESET, press_x, press_y; char c = ' '; @@ -1100,7 +1149,9 @@ process_mMouse(int btn, int x, int y) return (MENU_NOTHING); if (btn == MOUSE_BTN_UP) { - if (press_btn == MOUSE_BTN1_DOWN || press_btn == MOUSE_BTN3_DOWN) { + switch (press_btn) { + case MOUSE_BTN1_DOWN: + case MOUSE_BTN3_DOWN: if (x < menu->x - FRAME_WIDTH || x >= menu->x + menu->width + FRAME_WIDTH || y < menu->y - 1 || y >= menu->y + menu->height + 1) { @@ -1112,6 +1163,16 @@ process_mMouse(int btn, int x, int y) x < menu->x + menu->width + FRAME_WIDTH)) { return (MENU_NOTHING); } + else if (press_y > y) { + for (i = 0; i < press_y - y; i++) + mLineU(c); + return (MENU_NOTHING); + } + else if (press_y < y) { + for (i = 0; i < y - press_y; i++) + mLineD(c); + return (MENU_NOTHING); + } else if (y == menu->y - 1) { mPrev(c); return (MENU_NOTHING); @@ -1126,13 +1187,34 @@ process_mMouse(int btn, int x, int y) return (MENU_NOTHING); return (select_menu(menu, mselect)); } + break; + case MOUSE_BTN4_DOWN_RXVT: + for (i = 0; i < mMouse_scroll_line(); i++) + mLineD(c); + break; + case MOUSE_BTN5_DOWN_RXVT: + for (i = 0; i < mMouse_scroll_line(); i++) + mLineU(c); + break; } } - else { + else if (btn == MOUSE_BTN4_DOWN_XTERM) { + for (i = 0; i < mMouse_scroll_line(); i++) + mLineD(c); + } + else if (btn == MOUSE_BTN5_DOWN_XTERM) { + for (i = 0; i < mMouse_scroll_line(); i++) + mLineU(c); + } + + if (btn != MOUSE_BTN4_DOWN_RXVT || press_btn == MOUSE_BTN_RESET) { press_btn = btn; press_x = x; press_y = y; } + else { + press_btn = MOUSE_BTN_RESET; + } return (MENU_NOTHING); } |