亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? history.h

?? 基于的linux的oracle sqlplus替代工具
?? H
字號:
/* History.h -- the names of functions that you can call in history. *//* Copyright (C) 1989, 1992 Free Software Foundation, Inc.   This file contains the GNU History Library (the Library), a set of   routines for managing the text of previously typed lines.   The Library 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, or (at your option)   any later version.   The Library 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.   The GNU General Public License is often shipped with GNU software, and   is generally kept in a file called COPYING or LICENSE.  If you do not   have a copy of the license, write to the Free Software Foundation,   59 Temple Place, Suite 330, Boston, MA 02111 USA. */#ifndef _HISTORY_H_#define _HISTORY_H_#ifdef __cplusplusextern "C" {#endif#if defined READLINE_LIBRARY#  include "rlstdc.h"#  include "rltypedefs.h"#else#  include <readline/rlstdc.h>#  include <readline/rltypedefs.h>#endif#ifdef __STDC__typedef void *histdata_t;#elsetypedef char *histdata_t;#endif/* The structure used to store a history entry. */typedef struct _hist_entry {  char *line;  histdata_t data;} HIST_ENTRY;/* A structure used to pass the current state of the history stuff around. */typedef struct _hist_state {  HIST_ENTRY **entries;		/* Pointer to the entries themselves. */  int offset;			/* The location pointer within this array. */  int length;			/* Number of elements within this array. */  int size;			/* Number of slots allocated to this array. */  int flags;} HISTORY_STATE;/* Flag values for the `flags' member of HISTORY_STATE. */#define HS_STIFLED	0x01/* Initialization and state management. *//* Begin a session in which the history functions might be used.  This   just initializes the interactive variables. */extern void using_history PARAMS((void));/* Return the current HISTORY_STATE of the history. */extern HISTORY_STATE *history_get_history_state PARAMS((void));/* Set the state of the current history array to STATE. */extern void history_set_history_state PARAMS((HISTORY_STATE *));/* Manage the history list. *//* Place STRING at the end of the history list.   The associated data field (if any) is set to NULL. */extern void add_history PARAMS((const char *));/* A reasonably useless function, only here for completeness.  WHICH   is the magic number that tells us which element to delete.  The   elements are numbered from 0. */extern HIST_ENTRY *remove_history PARAMS((int));/* Make the history entry at WHICH have LINE and DATA.  This returns   the old entry so you can dispose of the data.  In the case of an   invalid WHICH, a NULL pointer is returned. */extern HIST_ENTRY *replace_history_entry PARAMS((int, const char *, histdata_t));/* Clear the history list and start over. */extern void clear_history PARAMS((void));/* Stifle the history list, remembering only MAX number of entries. */extern void stifle_history PARAMS((int));/* Stop stifling the history.  This returns the previous amount the   history was stifled by.  The value is positive if the history was   stifled, negative if it wasn't. */extern int unstifle_history PARAMS((void));/* Return 1 if the history is stifled, 0 if it is not. */extern int history_is_stifled PARAMS((void));/* Information about the history list. *//* Return a NULL terminated array of HIST_ENTRY which is the current input   history.  Element 0 of this list is the beginning of time.  If there   is no history, return NULL. */extern HIST_ENTRY **history_list PARAMS((void));/* Returns the number which says what history element we are now   looking at.  */extern int where_history PARAMS((void));  /* Return the history entry at the current position, as determined by   history_offset.  If there is no entry there, return a NULL pointer. */extern HIST_ENTRY *current_history PARAMS((void));/* Return the history entry which is logically at OFFSET in the history   array.  OFFSET is relative to history_base. */extern HIST_ENTRY *history_get PARAMS((int));/* Return the number of bytes that the primary history entries are using.   This just adds up the lengths of the_history->lines. */extern int history_total_bytes PARAMS((void));/* Moving around the history list. *//* Set the position in the history list to POS. */extern int history_set_pos PARAMS((int));/* Back up history_offset to the previous history entry, and return   a pointer to that entry.  If there is no previous entry, return   a NULL pointer. */extern HIST_ENTRY *previous_history PARAMS((void));/* Move history_offset forward to the next item in the input_history,   and return the a pointer to that entry.  If there is no next entry,   return a NULL pointer. */extern HIST_ENTRY *next_history PARAMS((void));/* Searching the history list. *//* Search the history for STRING, starting at history_offset.   If DIRECTION < 0, then the search is through previous entries,   else through subsequent.  If the string is found, then   current_history () is the history entry, and the value of this function   is the offset in the line of that history entry that the string was   found in.  Otherwise, nothing is changed, and a -1 is returned. */extern int history_search PARAMS((const char *, int));/* Search the history for STRING, starting at history_offset.   The search is anchored: matching lines must begin with string.   DIRECTION is as in history_search(). */extern int history_search_prefix PARAMS((const char *, int));/* Search for STRING in the history list, starting at POS, an   absolute index into the list.  DIR, if negative, says to search   backwards from POS, else forwards.   Returns the absolute index of the history element where STRING   was found, or -1 otherwise. */extern int history_search_pos PARAMS((const char *, int, int));/* Managing the history file. *//* Add the contents of FILENAME to the history list, a line at a time.   If FILENAME is NULL, then read from ~/.history.  Returns 0 if   successful, or errno if not. */extern int read_history PARAMS((const char *));/* Read a range of lines from FILENAME, adding them to the history list.   Start reading at the FROM'th line and end at the TO'th.  If FROM   is zero, start at the beginning.  If TO is less than FROM, read   until the end of the file.  If FILENAME is NULL, then read from   ~/.history.  Returns 0 if successful, or errno if not. */extern int read_history_range PARAMS((const char *, int, int));/* Write the current history to FILENAME.  If FILENAME is NULL,   then write the history list to ~/.history.  Values returned   are as in read_history ().  */extern int write_history PARAMS((const char *));/* Append NELEMENT entries to FILENAME.  The entries appended are from   the end of the list minus NELEMENTs up to the end of the list. */extern int append_history PARAMS((int, const char *));/* Truncate the history file, leaving only the last NLINES lines. */extern int history_truncate_file PARAMS((const char *, int));/* History expansion. *//* Expand the string STRING, placing the result into OUTPUT, a pointer   to a string.  Returns:   0) If no expansions took place (or, if the only change in      the text was the de-slashifying of the history expansion      character)   1) If expansions did take place  -1) If there was an error in expansion.   2) If the returned line should just be printed.  If an error ocurred in expansion, then OUTPUT contains a descriptive  error message. */extern int history_expand PARAMS((char *, char **));/* Extract a string segment consisting of the FIRST through LAST   arguments present in STRING.  Arguments are broken up as in   the shell. */extern char *history_arg_extract PARAMS((int, int, const char *));/* Return the text of the history event beginning at the current   offset into STRING.  Pass STRING with *INDEX equal to the   history_expansion_char that begins this specification.   DELIMITING_QUOTE is a character that is allowed to end the string   specification for what to search for in addition to the normal   characters `:', ` ', `\t', `\n', and sometimes `?'. */extern char *get_history_event PARAMS((const char *, int *, int));/* Return an array of tokens, much as the shell might.  The tokens are   parsed out of STRING. */extern char **history_tokenize PARAMS((const char *));/* Exported history variables. */extern int history_base;extern int history_length;extern int history_max_entries;extern char history_expansion_char;extern char history_subst_char;extern char *history_word_delimiters;extern char history_comment_char;extern char *history_no_expand_chars;extern char *history_search_delimiter_chars;extern int history_quotes_inhibit_expansion;/* Backwards compatibility */extern int max_input_history;/* If set, this function is called to decide whether or not a particular   history expansion should be treated as a special case for the calling   application and not expanded. */extern rl_linebuf_func_t *history_inhibit_expansion_function;#ifdef __cplusplus}#endif#endif /* !_HISTORY_H_ */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久亚洲二区三区| 91丨porny丨中文| 91精品国产综合久久久久久久久久| 亚洲欧美一区二区三区孕妇| 色综合天天综合网天天看片 | 日韩欧美成人一区二区| 免费成人在线影院| 欧美成人精品福利| 国产毛片精品一区| 国产欧美日韩视频在线观看| 白白色亚洲国产精品| 亚洲免费在线观看| 欧美特级限制片免费在线观看| 天天影视色香欲综合网老头| 日韩你懂的电影在线观看| 国产一区二区成人久久免费影院 | 国产精品传媒视频| 欧美日韩一级黄| 国产一区二区中文字幕| 亚洲欧美自拍偷拍| 欧美高清视频一二三区 | 国产91在线观看| 最新中文字幕一区二区三区| 欧美日本一区二区在线观看| 麻豆国产精品一区二区三区 | 蜜桃av一区二区| 亚洲欧洲无码一区二区三区| 欧美群妇大交群中文字幕| 久久狠狠亚洲综合| 亚洲免费观看高清完整版在线| 67194成人在线观看| 成人免费的视频| 日韩国产在线一| 中文字幕欧美日韩一区| 欧美日韩国产综合视频在线观看| 国产综合久久久久影院| 一区二区在线观看视频| 久久综合久色欧美综合狠狠| 一本色道久久加勒比精品| 蜜乳av一区二区| 一区二区三区四区五区视频在线观看| 欧美一区二区三区四区高清| 99re免费视频精品全部| 久久成人18免费观看| 亚洲影视在线播放| 国产精品乱码人人做人人爱| 日韩欧美一卡二卡| 欧美视频自拍偷拍| 91啪亚洲精品| 成人禁用看黄a在线| 精品伊人久久久久7777人| 亚洲午夜电影网| 一区二区中文字幕在线| 久久久精品天堂| 精品久久99ma| 欧美一区二区三区在线视频| 在线一区二区三区| 99国产麻豆精品| 成人一区在线看| 国产精品69毛片高清亚洲| 六月丁香婷婷久久| 亚洲国产精品天堂| 亚洲精品免费播放| 中文字幕一区二| 国产精品天干天干在线综合| 久久久99久久| 日韩欧美一级在线播放| 337p亚洲精品色噜噜狠狠| 欧美三级视频在线播放| 欧美自拍偷拍午夜视频| 色av成人天堂桃色av| www.亚洲精品| av男人天堂一区| 成人影视亚洲图片在线| 懂色av中文字幕一区二区三区| 国产麻豆一精品一av一免费 | 日韩一区二区电影在线| 日韩丝袜美女视频| 欧美一级高清片在线观看| 69久久99精品久久久久婷婷| 91精品国产综合久久香蕉的特点 | 中文字幕免费观看一区| 国产欧美日韩精品a在线观看| 国产欧美一区二区在线| 国产精品三级在线观看| 中文欧美字幕免费| 中文字幕在线播放不卡一区| 最新中文字幕一区二区三区| 一区二区久久久久久| 亚洲成人免费在线观看| 视频在线观看一区二区三区| 日产欧产美韩系列久久99| 裸体歌舞表演一区二区| 国产精品中文欧美| 99久久精品情趣| 在线免费av一区| 欧美一级片在线观看| 欧美v日韩v国产v| 中文字幕高清一区| 亚洲精品成人少妇| 日本亚洲一区二区| 国产一区二区影院| 91免费版pro下载短视频| 欧美午夜一区二区三区| 欧美一二三区在线观看| 国产丝袜在线精品| 一区二区高清在线| 久久99久国产精品黄毛片色诱| 国产福利精品一区| 欧洲精品一区二区| 久久久亚洲国产美女国产盗摄 | 五月激情丁香一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产在线一区二区| 91同城在线观看| 精品免费国产二区三区| 亚洲欧美日韩一区| 久久99精品久久久| 97精品视频在线观看自产线路二| 欧美日韩精品三区| 中文字幕欧美日本乱码一线二线 | 中文字幕亚洲不卡| 青青草原综合久久大伊人精品优势 | 亚洲美女屁股眼交| 免费观看日韩电影| aaa欧美色吧激情视频| 日韩一区二区麻豆国产| 日韩一区在线看| 精品影视av免费| 精品视频资源站| www国产成人| 亚洲成av人综合在线观看| 粉嫩蜜臀av国产精品网站| 538在线一区二区精品国产| 中文字幕永久在线不卡| 久久99精品国产.久久久久| 在线观看不卡视频| 国产精品二三区| 国产精品2024| 欧美一级二级三级蜜桃| 亚洲精品美国一| 成人免费视频一区二区| 精品欧美一区二区在线观看| 亚洲日本丝袜连裤袜办公室| 国产一区中文字幕| 欧美一区二区三区四区视频| 亚洲九九爱视频| 成人精品国产福利| 国产三级精品在线| 精品一区二区三区香蕉蜜桃| 欧美视频中文一区二区三区在线观看 | 国产精品乱码一区二区三区软件| 蜜桃久久久久久| 欧美精品久久99久久在免费线 | 激情国产一区二区 | 久久综合久久综合九色| 日本vs亚洲vs韩国一区三区二区| 91久久免费观看| 日韩一区有码在线| av在线一区二区| 中文字幕欧美区| 本田岬高潮一区二区三区| 国产丝袜美腿一区二区三区| 激情欧美一区二区三区在线观看| 日韩欧美国产一区二区三区| 日本人妖一区二区| 欧美一区二区精美| 免费国产亚洲视频| 日韩欧美一二三区| 九九精品一区二区| 久久综合色之久久综合| 激情欧美一区二区| 国产日韩在线不卡| www.欧美.com| 亚洲色图欧美偷拍| 久久国产乱子精品免费女| 六月丁香婷婷色狠狠久久| 欧美日韩亚洲丝袜制服| 精品国产乱码久久久久久1区2区| 美女视频黄久久| 日韩一区二区在线看片| 久久99精品国产麻豆婷婷| 久久午夜色播影院免费高清 | 亚洲男同1069视频| 欧美主播一区二区三区| 天使萌一区二区三区免费观看| 欧美精品亚洲一区二区在线播放| 日韩国产一区二| 26uuu久久综合| av中文字幕亚洲| 亚洲成人av免费| 精品国产欧美一区二区| 国产乱码精品一区二区三区忘忧草| 国产精品视频免费看| 欧洲视频一区二区| 久久精品免费看| 中文字幕永久在线不卡| 欧美日本在线视频| 国产999精品久久久久久绿帽| 自拍偷在线精品自拍偷无码专区|