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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? obex_object.c

?? 這是Linux環境下的openobex
?? C
?? 第 1 頁 / 共 2 頁
字號:
/********************************************************************* *                 * Filename:      obex_object.c * Version:       0.8 * Description:   OBEX object related functions * Status:        Experimental. * Author:        Dag Brattli <dagb@cs.uit.no> * Created at:    Fri Apr 23 14:04:29 1999 * CVS ID:        $Id: obex_object.c,v 1.23 2006/01/03 18:36:15 holtmann Exp $ * *     Copyright (c) 1999, 2000 Pontus Fuchs, All Rights Reserved. *     Copyright (c) 1999, 2000 Dag Brattli, All Rights Reserved. *      *     This library is free software; you can redistribute it and/or *     modify it under the terms of the GNU Lesser General Public *     License as published by the Free Software Foundation; either *     version 2 of the License, or (at your option) any later version. * *     This 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 *     Lesser General Public License for more details. * *     You should have received a copy of the GNU Lesser General Public *     License along with this library; if not, write to the Free Software *     Foundation, Inc., 59 Temple Place, Suite 330, Boston,  *     MA  02111-1307  USA     * ********************************************************************/#ifdef HAVE_CONFIG_H#include <config.h>#endif#include <stdio.h>#include <string.h>#include "obex_main.h"#include "obex_object.h"#include "obex_header.h"#include "obex_connect.h"/* * Function obex_object_new () * *    Create a new OBEX object * */obex_object_t *obex_object_new(void){	obex_object_t *object;	object =  malloc(sizeof(obex_object_t));	if (object == NULL)		return(NULL);	memset(object, 0, sizeof(obex_object_t));	obex_object_setrsp(object, OBEX_RSP_NOT_IMPLEMENTED, OBEX_RSP_NOT_IMPLEMENTED);	return object;}/* * Function free_headerq(q) * *    Free all headers in a header queue. * */static inline void free_headerq(slist_t **q){	struct obex_header_element *h;		DEBUG(4, "\n");	while(*q != NULL) {	 	h = (*q)->data;		*q = slist_remove(*q, h);		g_netbuf_free(h->buf);		free(h);	}}/* * Function obex_object_delete (object) * *    Delete OBEX object * */int obex_object_delete(obex_object_t *object){	DEBUG(4, "\n");	obex_return_val_if_fail(object != NULL, -1);	/* Free the headerqueues */	free_headerq(&object->tx_headerq);	free_headerq(&object->rx_headerq);	free_headerq(&object->rx_headerq_rm);	/* Free tx and rx msgs */	g_netbuf_free(object->tx_nonhdr_data);	object->tx_nonhdr_data = NULL;	g_netbuf_free(object->rx_nonhdr_data);	object->rx_nonhdr_data = NULL;		g_netbuf_free(object->rx_body);	object->rx_body = NULL;		free(object);	return 0;}/* * Function obex_object_setcmd () * *    Set command of object * */int obex_object_setcmd(obex_object_t *object, uint8_t cmd, uint8_t lastcmd){	DEBUG(4,"%02x\n", cmd);	object->cmd = cmd;	object->opcode = cmd;	object->lastopcode = lastcmd;	return 1;}/* * Function obex_object_setrsp () * *    Set the response for an object * */int obex_object_setrsp(obex_object_t *object, uint8_t rsp, uint8_t lastrsp){	DEBUG(4,"\n");	object->opcode = rsp;	object->lastopcode = lastrsp;	return 1;}/* * Function int obex_object_addheader(obex_object_t *object, uint8_t hi,  *                      obex_headerdata_t hv, uint32_t hv_size, unsigned int flags) * *    Add a header to the TX-queue. * */int obex_object_addheader(obex_t *self, obex_object_t *object, uint8_t hi,	obex_headerdata_t hv, uint32_t hv_size, unsigned int flags){	int ret = -1;	struct obex_header_element *element;	unsigned int maxlen;	DEBUG(4, "\n");	/* End of stream marker */	if(flags & OBEX_FL_STREAM_DATAEND)	{		if(self->object == NULL)			return -1;		self->object->s_stop = TRUE;		self->object->s_buf = hv.bs;		self->object->s_len = hv_size;		return 1;	}	/* Stream data */	if(flags & OBEX_FL_STREAM_DATA)	{		if(self->object == NULL)			return -1;		self->object->s_buf = hv.bs;		self->object->s_len = hv_size;		return 1;	}		if(flags & OBEX_FL_FIT_ONE_PACKET)	{		/* In this command all headers must fit in one packet! */		DEBUG(3, "Fit one packet!\n");		maxlen = self->mtu_tx - object->totallen - sizeof(struct obex_common_hdr);	}	else	{		maxlen = self->mtu_tx - sizeof(struct obex_common_hdr);	}	element = malloc(sizeof(struct obex_header_element));	if(element == NULL)		return -1;	memset(element, 0, sizeof(struct obex_header_element));	element->hi = hi;		/* Is this a stream? */	if(flags & OBEX_FL_STREAM_START)	{		DEBUG(3, "Adding stream\n");		element->stream = TRUE;		object->tx_headerq = slist_append(object->tx_headerq, element);		return 1;	}		switch (hi & OBEX_HI_MASK) {	case OBEX_INT:		DEBUG(2, "4BQ header %d\n", hv.bq4);				element->buf = g_netbuf_new(sizeof(struct obex_uint_hdr));		if(element->buf) {			element->length = (unsigned int) sizeof(struct obex_uint_hdr);			ret = insert_uint_header(element->buf, hi, hv.bq4);		}		break;			case OBEX_BYTE:		DEBUG(2, "1BQ header %d\n", hv.bq1);		element->buf = g_netbuf_new(sizeof(struct obex_ubyte_hdr));		if(element->buf) {			element->length = sizeof(struct obex_ubyte_hdr);			ret = insert_ubyte_header(element->buf, hi, hv.bq1);		}		break;	case OBEX_BYTE_STREAM:		DEBUG(2, "BS  header size %d\n", hv_size);		element->buf = g_netbuf_new(hv_size + sizeof(struct obex_byte_stream_hdr) );		if(element->buf) {			element->length = hv_size + sizeof(struct obex_byte_stream_hdr);			ret = insert_byte_stream_header(element->buf, hi, hv.bs, hv_size);		}		break;		case OBEX_UNICODE:		DEBUG(2, "Unicode header size %d\n", hv_size);		element->buf = g_netbuf_new(hv_size + sizeof(struct obex_unicode_hdr) );		if(element->buf) {			element->length = hv_size + sizeof(struct obex_unicode_hdr);			ret = insert_unicode_header(element->buf, hi, hv.bs, hv_size);		}		break;		default:		DEBUG(2, "Unsupported encoding %02x\n", hi & OBEX_HI_MASK);		ret = -1;		break;	}	/* Check if you can send this header without violating MTU or OBEX_FIT_ONE_PACKET */	if( (element->hi != OBEX_HDR_BODY) || (flags & OBEX_FL_FIT_ONE_PACKET) )	{		if(maxlen < element->length)	{			DEBUG(0, "Header to big\n");			ret = -1;		}	}	if (ret > 0) {		object->totallen += ret;		object->tx_headerq = slist_append(object->tx_headerq, element);		ret = 1;	} else {		g_netbuf_free(element->buf);		free(element);	}	return ret;}/* * Function send_stream(object, header, txmsg, tx_left) * *  Send a streaming header. * */static int send_stream(obex_t *self,				struct obex_header_element *h,				GNetBuf *txmsg, unsigned int tx_left){	obex_object_t *object;	struct obex_byte_stream_hdr *body_txh;	int actual; 	/* Number of bytes sent in this fragment */	DEBUG(4, "\n");		object = self->object;		/* Fill in length and header type later, but reserve space for it */	body_txh  = (struct obex_byte_stream_hdr*) g_netbuf_put(txmsg,				sizeof(struct obex_byte_stream_hdr) );	tx_left -= sizeof(struct obex_byte_stream_hdr);	actual = sizeof(struct obex_byte_stream_hdr);		do {		if(object->s_len == 0) {			/* Ask app for more data if no more */			object->s_offset = 0;			object->s_buf = NULL;			obex_deliver_event(self, OBEX_EV_STREAMEMPTY, 0, 0, FALSE);			DEBUG(4, "s_len=%d, s_stop = %d\n",						object->s_len, object->s_stop);			/* End of stream ?*/			if(object->s_stop)				break;			/* User suspended and didn't provide any new data */			if (object->suspend && object->s_buf == NULL)				break;			/* Error ?*/			if(object->s_buf == NULL) {				DEBUG(1, "Unexpected end-of-stream\n");				return -1;			}		}				if(tx_left < object->s_len) {			/*燭here is more data left in buffer than tx_left */			DEBUG(4, "More data than tx_left. Buffer will not be empty\n");						g_netbuf_put_data(txmsg, (uint8_t*) object->s_buf + object->s_offset, tx_left);			object->s_len -= tx_left;			object->s_offset += tx_left;			actual += tx_left;			tx_left = 0;		}		else {			/* There less data in buffer than tx_left */			DEBUG(4, "Less data that tx_left. Buffer will be empty\n");			g_netbuf_put_data(txmsg, (uint8_t*) object->s_buf + object->s_offset, object->s_len);			tx_left -= object->s_len;			object->s_offset += object->s_len;			actual += object->s_len;			object->s_len = 0;			if (object->suspend)				tx_left = 0;		}	} while(tx_left > 0);		DEBUG(4, "txmsg full or no more stream-data. actual = %d\n", actual);	body_txh->hi = OBEX_HDR_BODY;		if(object->s_stop && object->s_len == 0) {		/* We are done. Remove header from tx-queue */		object->tx_headerq = slist_remove(object->tx_headerq, h);		body_txh->hi = OBEX_HDR_BODY_END;		g_netbuf_free(h->buf);		free(h);	}		body_txh->hl = htons((uint16_t)actual);	return actual;}/* * Function send_body(object, header, txmsg, tx_left) * *  Fragment and send the body * */static int send_body(obex_object_t *object,				struct obex_header_element *h,				GNetBuf *txmsg, unsigned int tx_left){	struct obex_byte_stream_hdr *body_txh;	unsigned int actual;        			body_txh = (struct obex_byte_stream_hdr*) txmsg->tail;				if(!h->body_touched) {		/* This is the first time we try to send this header		   obex_object_addheaders has added a struct_byte_stream_hdr		   before the actual body-data. We shall send this in every fragment		   so we just remove it for now.*/		g_netbuf_pull(h->buf,  sizeof(struct obex_byte_stream_hdr) );		h->body_touched = TRUE;	}			if(tx_left < ( h->buf->len +			sizeof(struct obex_byte_stream_hdr) ) )	{		DEBUG(4, "Add BODY header\n");		body_txh->hi = OBEX_HDR_BODY;		body_txh->hl = htons((uint16_t)tx_left);		g_netbuf_put(txmsg, sizeof(struct obex_byte_stream_hdr) );		g_netbuf_put_data(txmsg, h->buf->data, tx_left				- sizeof(struct obex_byte_stream_hdr) );		g_netbuf_pull(h->buf, tx_left				- sizeof(struct obex_byte_stream_hdr) );		/* We have completely filled the tx-buffer */		actual = tx_left;	}	else	{		DEBUG(4, "Add BODY_END header\n");		body_txh->hi = OBEX_HDR_BODY_END;		body_txh->hl = htons((uint16_t) (h->buf->len + sizeof(struct obex_byte_stream_hdr)));		g_netbuf_put(txmsg, sizeof(struct obex_byte_stream_hdr) );		g_netbuf_put_data(txmsg, h->buf->data, h->buf->len);		actual = h->buf->len;				object->tx_headerq = slist_remove(object->tx_headerq, h);		g_netbuf_free(h->buf);		free(h);	}	return actual;}/* * Function obex_object_send() * *    Send away all headers attached to an object. Returns: *       1 on sucessfully done *       0 on progress made *     < 0 on error */int obex_object_send(obex_t *self, obex_object_t *object,		      int allowfinalcmd, int forcefinalbit){	struct obex_header_element *h;	GNetBuf *txmsg;	int actual, finished = 0;	uint16_t tx_left;	int addmore = TRUE;	int real_opcode;	DEBUG(4, "\n");	/* Calc how many bytes of headers we can fit in this package */	tx_left = self->mtu_tx - sizeof(struct obex_common_hdr);	switch(self->trans.type)	{#ifdef HAVE_IRDA	case OBEX_TRANS_IRDA:		if(self->trans.mtu > 0 && self->mtu_tx > self->trans.mtu)		{			tx_left -= self->mtu_tx%self->trans.mtu;		}		break;#endif /*HAVE_IRDA*/	default:		break;	}	/* Reuse transmit buffer */	txmsg = g_netbuf_recycle(self->tx_msg);		/* Reserve space for common header */	g_netbuf_reserve(txmsg, sizeof(obex_common_hdr_t));	/* Add nonheader-data first if any (SETPATH, CONNECT)*/	if(object->tx_nonhdr_data) {		DEBUG(4, "Adding %d bytes of non-headerdata\n", object->tx_nonhdr_data->len);		g_netbuf_put_data(txmsg, object->tx_nonhdr_data->data, object->tx_nonhdr_data->len);				g_netbuf_free(object->tx_nonhdr_data);		object->tx_nonhdr_data = NULL;	}	DEBUG(4, "4\n");		/* Take headers from the tx queue and try to stuff as

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99在线精品一区二区三区| 久久久久久久精| 久久久久久亚洲综合影院红桃 | 国产.欧美.日韩| 欧美疯狂性受xxxxx喷水图片| 日本不卡在线视频| 99久久精品国产网站| 久久九九全国免费| 日本一区中文字幕| 欧美日韩成人一区| 亚洲乱码国产乱码精品精小说| 国产高清成人在线| 精品国产乱码久久久久久影片| 亚洲成人自拍网| 一本一本久久a久久精品综合麻豆| 久久久91精品国产一区二区三区| 麻豆视频观看网址久久| 欧美日韩一级黄| 亚洲成人免费在线观看| 色综合天天狠狠| 中文字幕日韩欧美一区二区三区| 成人性生交大片免费看中文网站| 精品精品欲导航| 青青草国产精品97视觉盛宴| 欧洲日韩一区二区三区| 亚洲一区二区三区在线看 | 久久国产夜色精品鲁鲁99| 欧美午夜精品理论片a级按摩| 亚洲人成网站影音先锋播放| fc2成人免费人成在线观看播放| 国产视频一区在线播放| 麻豆极品一区二区三区| 日韩欧美国产三级电影视频| 麻豆精品新av中文字幕| 欧美xingq一区二区| 久久99九九99精品| 国产午夜精品一区二区三区四区| 国产91精品欧美| 综合久久一区二区三区| 色诱视频网站一区| 亚洲一区二区三区美女| 91精品欧美综合在线观看最新| 蜜臀a∨国产成人精品| 国产亚洲自拍一区| 成人国产精品免费观看视频| 亚洲欧美日韩精品久久久久| 欧美视频在线一区| 美女www一区二区| 久久久精品黄色| 99re8在线精品视频免费播放| 亚洲一区二区四区蜜桃| 欧美一区二区免费视频| 国产一区二区三区视频在线播放| 中文字幕不卡在线观看| 色婷婷综合久久久中文一区二区 | 日韩区在线观看| 狠狠色狠狠色综合| 成人欧美一区二区三区视频网页| 欧美中文字幕一区| 另类小说视频一区二区| 国产欧美精品一区二区色综合 | 欧美亚州韩日在线看免费版国语版 | 亚洲成人免费看| 精品国产乱码久久久久久1区2区| 成人综合婷婷国产精品久久免费| 一区二区三区国产精华| 日韩免费高清av| 91麻豆精品在线观看| 日本欧美在线观看| 亚洲欧美日韩久久精品| 亚洲精品在线观| 色婷婷久久久久swag精品| 久久不见久久见中文字幕免费| 国产精品毛片久久久久久久| 7777女厕盗摄久久久| 成人做爰69片免费看网站| 午夜精品视频在线观看| 国产精品乱人伦| 日韩欧美一区电影| 欧美亚洲综合另类| 国产成a人无v码亚洲福利| 三级一区在线视频先锋 | 成人三级在线视频| 日韩不卡一二三区| 亚洲免费大片在线观看| 精品电影一区二区三区| 久久综合九色综合97婷婷| 欧美伊人精品成人久久综合97| 国产成人免费视频一区| 奇米精品一区二区三区在线观看一| 中文字幕一区二区三区在线播放| 欧美成人精品福利| 欧美一区二区三区在| 欧美性受xxxx黑人xyx性爽| 99精品桃花视频在线观看| 国产精品资源在线看| 美女在线一区二区| 日本成人超碰在线观看| 亚洲一区在线免费观看| 国产精品女主播av| 久久精品日产第一区二区三区高清版| 欧美一区欧美二区| 制服.丝袜.亚洲.中文.综合| 欧美欧美欧美欧美| 欧美日韩综合色| 精品污污网站免费看| 在线视频亚洲一区| 91国产免费看| 欧美亚洲综合网| 欧美日韩一区中文字幕| 欧美喷潮久久久xxxxx| 91麻豆精品国产91久久久 | 一本久久a久久精品亚洲| www.成人在线| 91网页版在线| 日本伦理一区二区| 欧美在线免费视屏| 欧美日韩一级片网站| 91精品国产91久久久久久一区二区 | 午夜亚洲福利老司机| 婷婷丁香久久五月婷婷| 日韩二区三区在线观看| 免费av成人在线| 狠狠色2019综合网| 国产成人免费视频一区| 99re6这里只有精品视频在线观看| 91小宝寻花一区二区三区| 99v久久综合狠狠综合久久| 在线精品视频免费播放| 8x福利精品第一导航| 欧美一区二区三区播放老司机| 2021久久国产精品不只是精品| 国产色产综合色产在线视频| 国产精品天天看| 亚洲最大成人网4388xx| 青娱乐精品视频| 国产98色在线|日韩| 91豆麻精品91久久久久久| 欧美一级理论片| 国产日韩v精品一区二区| 亚洲精品免费视频| 蜜桃一区二区三区在线| 成人综合婷婷国产精品久久蜜臀| 在线亚洲人成电影网站色www| 欧美日韩精品二区第二页| 久久欧美一区二区| 中文字幕 久热精品 视频在线| 亚洲人妖av一区二区| 午夜免费欧美电影| 国产**成人网毛片九色 | 国产夜色精品一区二区av| 樱桃国产成人精品视频| 麻豆久久一区二区| 9i在线看片成人免费| 制服.丝袜.亚洲.另类.中文| 亚洲国产精品精华液2区45| 亚洲成人激情社区| 国产乱子伦一区二区三区国色天香| 91论坛在线播放| 2020日本不卡一区二区视频| 亚洲综合丁香婷婷六月香| 国产精品香蕉一区二区三区| 精品视频资源站| 国产精品日韩成人| 国产自产高清不卡| 欧美色图免费看| 中文字幕一区二区三| 蜜桃一区二区三区在线| 欧美日韩中文一区| 专区另类欧美日韩| 国产麻豆一精品一av一免费| 91精品麻豆日日躁夜夜躁| 亚洲精品ww久久久久久p站 | 久久精品噜噜噜成人av农村| 色婷婷综合久久久久中文一区二区| 久久亚洲影视婷婷| 麻豆国产欧美日韩综合精品二区| 91国产精品成人| 亚洲色图视频网| 成人午夜激情片| 欧美精品一区二| 免费成人av在线| 91精品国产一区二区三区| 一区二区三区视频在线看| 成人午夜av电影| 国产亚洲成av人在线观看导航| 免费视频一区二区| 欧美精品乱码久久久久久按摩 | 欧美精品色综合| 亚洲小说欧美激情另类| 91久久精品一区二区三| 亚洲三级理论片| 9久草视频在线视频精品| 国产精品第五页| 91丨九色丨国产丨porny| 中文字幕一区二区三区色视频| 成人爱爱电影网址| 国产亚洲精品bt天堂精选| 国产伦精品一区二区三区在线观看| 精品福利在线导航|