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

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

?? network.h

?? 遠(yuǎn)程登陸工具軟件源碼 用于遠(yuǎn)程登陸unix
?? H
字號:
/*
 * Networking abstraction in PuTTY.
 *
 * The way this works is: a back end can choose to open any number
 * of sockets - including zero, which might be necessary in some.
 * It can register a bunch of callbacks (most notably for when 
 * data is received) for each socket, and it can call the networking
 * abstraction to send data without having to worry about blocking.
 * The stuff behind the abstraction takes care of selects and
 * nonblocking writes and all that sort of painful gubbins.
 */

#ifndef PUTTY_NETWORK_H
#define PUTTY_NETWORK_H

#ifndef DONE_TYPEDEFS
#define DONE_TYPEDEFS
typedef struct config_tag Config;
typedef struct backend_tag Backend;
typedef struct terminal_tag Terminal;
#endif

typedef struct SockAddr_tag *SockAddr;
/* pay attention to levels of indirection */
typedef struct socket_function_table **Socket;
typedef struct plug_function_table **Plug;

#ifndef OSSOCKET_DEFINED
typedef void *OSSocket;
#endif

struct socket_function_table {
    Plug(*plug) (Socket s, Plug p);
    /* use a different plug (return the old one) */
    /* if p is NULL, it doesn't change the plug */
    /* but it does return the one it's using */
    void (*close) (Socket s);
    int (*write) (Socket s, const char *data, int len);
    int (*write_oob) (Socket s, const char *data, int len);
    void (*flush) (Socket s);
    void (*set_private_ptr) (Socket s, void *ptr);
    void *(*get_private_ptr) (Socket s);
    void (*set_frozen) (Socket s, int is_frozen);
    /* ignored by tcp, but vital for ssl */
    const char *(*socket_error) (Socket s);
};

struct plug_function_table {
    int (*closing)
     (Plug p, const char *error_msg, int error_code, int calling_back);
    /* error_msg is NULL iff it is not an error (ie it closed normally) */
    /* calling_back != 0 iff there is a Plug function */
    /* currently running (would cure the fixme in try_send()) */
    int (*receive) (Plug p, int urgent, char *data, int len);
    /*
     *  - urgent==0. `data' points to `len' bytes of perfectly
     *    ordinary data.
     * 
     *  - urgent==1. `data' points to `len' bytes of data,
     *    which were read from before an Urgent pointer.
     * 
     *  - urgent==2. `data' points to `len' bytes of data,
     *    the first of which was the one at the Urgent mark.
     */
    void (*sent) (Plug p, int bufsize);
    /*
     * The `sent' function is called when the pending send backlog
     * on a socket is cleared or partially cleared. The new backlog
     * size is passed in the `bufsize' parameter.
     */
    int (*accepting)(Plug p, OSSocket sock);
    /*
     * returns 0 if the host at address addr is a valid host for connecting or error
     */
};

/* proxy indirection layer */
/* NB, control of 'addr' is passed via new_connection, which takes
 * responsibility for freeing it */
Socket new_connection(SockAddr addr, char *hostname,
		      int port, int privport,
		      int oobinline, int nodelay, int keepalive,
		      Plug plug, const Config *cfg);
Socket new_listener(char *srcaddr, int port, Plug plug, int local_host_only,
		    const Config *cfg);
SockAddr name_lookup(char *host, int port, char **canonicalname,
		     const Config *cfg);

/* platform-dependent callback from new_connection() */
/* (same caveat about addr as new_connection()) */
Socket platform_new_connection(SockAddr addr, char *hostname,
			       int port, int privport,
			       int oobinline, int nodelay, int keepalive,
			       Plug plug, const Config *cfg);

/* socket functions */

void sk_init(void);		       /* called once at program startup */
void sk_cleanup(void);		       /* called just before program exit */

SockAddr sk_namelookup(const char *host, char **canonicalname);
SockAddr sk_nonamelookup(const char *host);
void sk_getaddr(SockAddr addr, char *buf, int buflen);
int sk_hostname_is_local(char *name);
int sk_address_is_local(SockAddr addr);
enum { ADDRTYPE_IPV4, ADDRTYPE_IPV6, ADDRTYPE_NAME };
int sk_addrtype(SockAddr addr);
void sk_addrcopy(SockAddr addr, char *buf);
void sk_addr_free(SockAddr addr);

/* NB, control of 'addr' is passed via sk_new, which takes responsibility
 * for freeing it, as for new_connection() */
Socket sk_new(SockAddr addr, int port, int privport, int oobinline,
	      int nodelay, int keepalive, Plug p);

Socket sk_newlistener(char *srcaddr, int port, Plug plug, int local_host_only);

Socket sk_register(OSSocket sock, Plug plug);

#define sk_plug(s,p) (((*s)->plug) (s, p))
#define sk_close(s) (((*s)->close) (s))
#define sk_write(s,buf,len) (((*s)->write) (s, buf, len))
#define sk_write_oob(s,buf,len) (((*s)->write_oob) (s, buf, len))
#define sk_flush(s) (((*s)->flush) (s))

#ifdef DEFINE_PLUG_METHOD_MACROS
#define plug_closing(p,msg,code,callback) (((*p)->closing) (p, msg, code, callback))
#define plug_receive(p,urgent,buf,len) (((*p)->receive) (p, urgent, buf, len))
#define plug_sent(p,bufsize) (((*p)->sent) (p, bufsize))
#define plug_accepting(p, sock) (((*p)->accepting)(p, sock))
#endif

/*
 * Each socket abstraction contains a `void *' private field in
 * which the client can keep state.
 *
 * This is perhaps unnecessary now that we have the notion of a plug,
 * but there is some existing code that uses it, so it stays.
 */
#define sk_set_private_ptr(s, ptr) (((*s)->set_private_ptr) (s, ptr))
#define sk_get_private_ptr(s) (((*s)->get_private_ptr) (s))

/*
 * Special error values are returned from sk_namelookup and sk_new
 * if there's a problem. These functions extract an error message,
 * or return NULL if there's no problem.
 */
const char *sk_addr_error(SockAddr addr);
#define sk_socket_error(s) (((*s)->socket_error) (s))

/*
 * Set the `frozen' flag on a socket. A frozen socket is one in
 * which all READABLE notifications are ignored, so that data is
 * not accepted from the peer until the socket is unfrozen. This
 * exists for two purposes:
 * 
 *  - Port forwarding: when a local listening port receives a
 *    connection, we do not want to receive data from the new
 *    socket until we have somewhere to send it. Hence, we freeze
 *    the socket until its associated SSH channel is ready; then we
 *    unfreeze it and pending data is delivered.
 * 
 *  - Socket buffering: if an SSH channel (or the whole connection)
 *    backs up or presents a zero window, we must freeze the
 *    associated local socket in order to avoid unbounded buffer
 *    growth.
 */
#define sk_set_frozen(s, is_frozen) (((*s)->set_frozen) (s, is_frozen))

/*
 * Call this after an operation that might have tried to send on a
 * socket, to clean up any pending network errors.
 */
void net_pending_errors(void);

/*
 * Simple wrapper on getservbyname(), needed by ssh.c. Returns the
 * port number, in host byte order (suitable for printf and so on).
 * Returns 0 on failure. Any platform not supporting getservbyname
 * can just return 0 - this function is not required to handle
 * numeric port specifications.
 */
int net_service_lookup(char *service);

/********** SSL stuff **********/

/*
 * This section is subject to change, but you get the general idea
 * of what it will eventually look like.
 */

typedef struct certificate *Certificate;
typedef struct our_certificate *Our_Certificate;
    /* to be defined somewhere else, somehow */

typedef struct ssl_client_socket_function_table **SSL_Client_Socket;
typedef struct ssl_client_plug_function_table **SSL_Client_Plug;

struct ssl_client_socket_function_table {
    struct socket_function_table base;
    void (*renegotiate) (SSL_Client_Socket s);
    /* renegotiate the cipher spec */
};

struct ssl_client_plug_function_table {
    struct plug_function_table base;
    int (*refuse_cert) (SSL_Client_Plug p, Certificate cert[]);
    /* do we accept this certificate chain?  If not, why not? */
    /* cert[0] is the server's certificate, cert[] is NULL-terminated */
    /* the last certificate may or may not be the root certificate */
     Our_Certificate(*client_cert) (SSL_Client_Plug p);
    /* the server wants us to identify ourselves */
    /* may return NULL if we want anonymity */
};

SSL_Client_Socket sk_ssl_client_over(Socket s,	/* pre-existing (tcp) connection */
				     SSL_Client_Plug p);

#define sk_renegotiate(s) (((*s)->renegotiate) (s))

#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜精品久久久久久超碰| 国产日产欧美一区二区三区| 日韩无一区二区| 国产精品情趣视频| 五月婷婷久久综合| 99久久久精品| 日韩精品一区二区三区四区视频 | 日韩欧美中文字幕公布| 欧美—级在线免费片| 轻轻草成人在线| 91女厕偷拍女厕偷拍高清| 精品少妇一区二区三区在线播放 | 丝袜诱惑亚洲看片| 成人av在线电影| 精品日韩欧美在线| 亚洲一区二区三区视频在线| 顶级嫩模精品视频在线看| 欧美一激情一区二区三区| 亚洲日本免费电影| 国产精品一区免费在线观看| 欧美另类videos死尸| 亚洲天堂福利av| 国产成人一区二区精品非洲| 日韩视频123| 五月激情综合婷婷| 欧美日韩在线观看一区二区 | 亚洲欧美成aⅴ人在线观看| 国产一区二区剧情av在线| 欧美一区二区黄| 日韩精品一区第一页| 欧美在线你懂得| 亚洲男人天堂av| 99r精品视频| 亚洲老司机在线| 91视频免费看| 亚洲男女毛片无遮挡| 91亚洲精品乱码久久久久久蜜桃| 国产精品毛片a∨一区二区三区| 国产九色sp调教91| 久久人人爽人人爽| 国产麻豆欧美日韩一区| 久久精品视频免费| 成人一道本在线| 国产精品视频一二| 一本一道综合狠狠老| 一区二区三区在线视频播放| 色婷婷综合久久久久中文 | 欧美一区二区网站| 麻豆精品国产91久久久久久| 欧美一区2区视频在线观看| 日韩av在线发布| xfplay精品久久| 成人黄色国产精品网站大全在线免费观看 | 成人毛片视频在线观看| 午夜一区二区三区在线观看| 欧美色偷偷大香| 蜜臀av性久久久久蜜臀aⅴ流畅 | 色成人在线视频| 亚洲韩国精品一区| 日韩欧美一区二区久久婷婷| 国产麻豆精品一区二区| 国产精品免费久久久久| 欧美三级韩国三级日本一级| 全部av―极品视觉盛宴亚洲| 久久综合网色—综合色88| www.日本不卡| 亚洲gay无套男同| 精品三级av在线| 波多野结衣视频一区| 亚洲一区二区三区不卡国产欧美| 91麻豆精品国产自产在线观看一区| 久久精品国产精品亚洲红杏| 国产精品久久夜| 欧美裸体一区二区三区| 国产精品一二三四| 亚洲成人免费看| 国产农村妇女精品| 欧美老肥妇做.爰bbww视频| 国产精品99久| 午夜精品在线看| 国产精品不卡在线| 欧美成人一区二区三区片免费| 99久久精品免费看国产免费软件| 肉肉av福利一精品导航| 国产精品久久久久久久久快鸭 | 欧美视频一区二| 国产成人亚洲综合a∨婷婷图片| 香蕉久久一区二区不卡无毒影院 | 亚洲私人影院在线观看| 欧美不卡一区二区| 欧美日韩国产综合视频在线观看| 国产suv精品一区二区6| 香蕉影视欧美成人| 亚洲美女区一区| 国产日韩欧美在线一区| 欧美mv和日韩mv的网站| 欧美二区在线观看| 欧洲一区二区三区免费视频| 成人精品免费看| 国产又粗又猛又爽又黄91精品| 香蕉av福利精品导航| 国产精品毛片大码女人| 26uuu国产一区二区三区| 精彩视频一区二区| 日本色综合中文字幕| 一区二区三区在线观看网站| 亚洲第一久久影院| 久久精品日产第一区二区三区高清版| 在线不卡免费av| 色天天综合久久久久综合片| 国产一区二区视频在线| 亚洲a一区二区| 亚洲美女在线国产| 国产欧美日韩中文久久| 国产亚洲欧美日韩日本| 日韩欧美国产综合| 欧美日韩免费观看一区三区| 成人av电影在线播放| 国产精品资源站在线| 亚洲va欧美va人人爽午夜 | 欧美精品在线视频| 91在线观看下载| 国产老妇另类xxxxx| 久久99久久久久| 亚洲成av人**亚洲成av**| 中文字幕亚洲电影| 国产欧美日韩激情| 欧美不卡视频一区| 欧美日产在线观看| 91麻豆精品国产无毒不卡在线观看 | 欧美性感一区二区三区| 色综合天天综合给合国产| 成人丝袜视频网| 国产麻豆精品久久一二三| 精品一区二区三区免费观看 | 色94色欧美sute亚洲13| av中文字幕一区| 成人激情综合网站| 欧美三级午夜理伦三级中视频| 一本一本久久a久久精品综合麻豆| 白白色 亚洲乱淫| 91蝌蚪porny九色| 欧美专区日韩专区| 精品久久一区二区| 久久夜色精品国产噜噜av| 精品福利视频一区二区三区| 欧美酷刑日本凌虐凌虐| 精品美女被调教视频大全网站| 精品播放一区二区| 国产女人水真多18毛片18精品视频| 国产午夜精品在线观看| 国产欧美日本一区视频| 亚洲人被黑人高潮完整版| 亚洲自拍偷拍网站| 日日摸夜夜添夜夜添亚洲女人| 免费精品视频在线| 国产91综合一区在线观看| 欧美在线小视频| 欧美一区二区三区日韩| 久久免费美女视频| 国产精品嫩草影院com| 亚洲综合激情网| 国产在线精品一区二区三区不卡| 粉嫩av一区二区三区粉嫩| 91美女精品福利| 日韩一区二区中文字幕| 国产精品婷婷午夜在线观看| 蜜桃av噜噜一区二区三区小说| 激情丁香综合五月| 色综合中文字幕国产 | 亚洲成人av一区| 成人免费视频caoporn| 在线免费观看日本欧美| 欧美一级黄色片| 国产精品久久久久影院亚瑟| 天天综合色天天综合| 国产成人aaaa| 欧美精品亚洲二区| 一区在线中文字幕| 久久97超碰国产精品超碰| 欧美日本在线一区| 中文av一区二区| 免费看日韩精品| 一本大道久久a久久精二百| 69久久夜色精品国产69蝌蚪网| 亚洲精品国久久99热| 国产成人无遮挡在线视频| 欧美日韩另类一区| 成人免费在线观看入口| 日日摸夜夜添夜夜添国产精品| 色婷婷激情一区二区三区| 国产日韩av一区二区| 日韩成人精品在线| 在线视频中文字幕一区二区| 亚洲欧美一区二区三区久本道91 | 91精品中文字幕一区二区三区| 国产三级欧美三级| 美洲天堂一区二卡三卡四卡视频| 91老师片黄在线观看| 中文字幕高清一区|