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

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

?? asui.cxx

?? 這些文件包括藍牙虛擬串口與打印機程序實例
?? CXX
?? 第 1 頁 / 共 3 頁
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
/**
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND,
EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED 
WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR PURPOSE.


Abstract:
	Windows CE Bluetooth application sample

**/
#include <windows.h>
#include <windev.h>
#include <stdio.h>

#include <winsock2.h>

#include <ras.h>
#include <notify.h>

#include <bt_api.h>
#include <bthapi.h>
#include <initguid.h>
#include <bt_sdp.h>


#include <svsutil.hxx>
#include "..\sdpcommon\sdpcommon.h"

#include "resource.h"

#define APPNAME		L"BluetoothASUI"

#define MAX_NAME	248
#define MAX_BA		20

#define DO_NOTHING	0
#define DO_INQUIRY	1
#define DO_NAMERES	2
#define DO_SDP		3
#define DO_STOP		4
#define DO_OPTIONS	5
#define DO_SYNC		6

#define DEFAULT_AS_PORT L"COM6:"
#define RAS_NAME_BLUETOOTH	L"`Bluetooth"

struct InquiryResult {
	InquiryResult	*pNext;

	BT_ADDR			b;					// Address of the item

	unsigned int	fHaveSDP  : 1;		// Do we have SDP record for it?

	unsigned char	channel;

	InquiryResult (void) {
		memset (this, 0, sizeof(*this));
	}
};

struct Global : public SVSSynch {
	int					fState;
	HINSTANCE			hInst;
	HWND				hWnd;
	HWND				hWndHidden;

	HANDLE				hDevice;

	InquiryResult		*pDev;

	Global (void) {
		fState = DO_NOTHING;
		hInst  = NULL;
		hWnd   = NULL;
		hWndHidden = NULL;
		pDev   = NULL;
		hDevice = NULL;
	}
};

static Global *g_pState = NULL;

int		g_fHaveSav = FALSE;

#define CHECK_STOP	\
	{													\
		if ((g_pState->fState == DO_STOP) ||			\
					(! g_pState->hWnd)) {				\
			g_pState->fState = DO_NOTHING;				\
			g_pState->Unlock ();						\
														\
			SetWindowText (hWndButton, L"Inquiry");		\
			SetWindowText (hWnd, L"Bluetooth ActiveSync");			\
														\
			return 0;									\
		}												\
	}

//
//	SDP parsing is better illustrated in sdp sample
//
static HRESULT ServiceAndAttributeSearch(
    UCHAR *szResponse,             // in - response returned from SDP ServiceAttribute query
    DWORD cbResponse,            // in - length of response
    ISdpRecord ***pppSdpRecords, // out - array of pSdpRecords
    ULONG *pNumRecords           // out - number of elements in pSdpRecords
    )
{
    *pppSdpRecords = NULL;
    *pNumRecords = 0;

    ISdpStream *pIStream = NULL;

    HRESULT hres = CoCreateInstance(__uuidof(SdpStream),NULL,CLSCTX_INPROC_SERVER,
                            __uuidof(ISdpStream),(LPVOID *) &pIStream);

    if (FAILED(hres))
        return hres;  

	ULONG ulError;

    hres = pIStream->Validate (szResponse,cbResponse,&ulError);

    if (SUCCEEDED(hres)) {
        hres = pIStream->VerifySequenceOf(szResponse,cbResponse,
                                          SDP_TYPE_SEQUENCE,NULL,pNumRecords);

        if (SUCCEEDED(hres) && *pNumRecords > 0) {
            *pppSdpRecords = (ISdpRecord **) CoTaskMemAlloc(sizeof(ISdpRecord*) * (*pNumRecords));

            if (pppSdpRecords != NULL) {
                hres = pIStream->RetrieveRecords(szResponse,cbResponse,*pppSdpRecords,pNumRecords);

                if (!SUCCEEDED(hres)) {
                    CoTaskMemFree(*pppSdpRecords);
                    *pppSdpRecords = NULL;
                    *pNumRecords = 0;
                }
            }
            else {
                hres = E_OUTOFMEMORY;
            }
        }
    }

    if (pIStream != NULL) {
        pIStream->Release();
        pIStream = NULL;
    }

	return hres;
}

static int IsRfcommUuid(NodeData *pNode)  {
	if (pNode->type != SDP_TYPE_UUID)
		return FALSE;

	if (pNode->specificType == SDP_ST_UUID16)
		return (pNode->u.uuid16 == RFCOMM_PROTOCOL_UUID16);
	else if (pNode->specificType == SDP_ST_UUID32)
		return (pNode->u.uuid32 == RFCOMM_PROTOCOL_UUID16);
	else if (pNode->specificType == SDP_ST_UUID128)
		return (0 == memcmp(&RFCOMM_PROTOCOL_UUID,&pNode->u.uuid128,sizeof(GUID)));

	return FALSE;
}

static int GetChannel (NodeData *pChannelNode) {
	if (pChannelNode->specificType == SDP_ST_UINT8)
		return pChannelNode->u.uint8;
	else if (pChannelNode->specificType == SDP_ST_INT8)
		return pChannelNode->u.int8;
	else if (pChannelNode->specificType == SDP_ST_UINT16)
		return pChannelNode->u.uint16;
	else if (pChannelNode->specificType == SDP_ST_INT16)
		return pChannelNode->u.int16;
	else if (pChannelNode->specificType == SDP_ST_UINT32)
		return pChannelNode->u.uint32;
	else if (pChannelNode->specificType == SDP_ST_INT32)
		return pChannelNode->u.int32;

	return 0;
}

static HRESULT FindRFCOMMChannel (unsigned char *pStream, int cStream, unsigned char *pChann) {
	ISdpRecord **pRecordArg;
	int cRecordArg = 0;

	*pChann = 0;

	HRESULT hr = ServiceAndAttributeSearch (pStream, cStream, &pRecordArg, (ULONG *)&cRecordArg);

	if (FAILED(hr))
		return hr;

	for (int i = 0; (! *pChann) && (i < cRecordArg); i++) {
	    ISdpRecord *pRecord = pRecordArg[i];    // particular record to examine in this loop
	    CNodeDataFreeString protocolList;     // contains SDP_ATTRIB_PROTOCOL_DESCRIPTOR_LIST data, if available

		if (ERROR_SUCCESS != pRecord->GetAttribute(SDP_ATTRIB_PROTOCOL_DESCRIPTOR_LIST,&protocolList) ||
		    (protocolList.type != SDP_TYPE_CONTAINER))
			continue;

		ISdpNodeContainer *pRecordContainer = protocolList.u.container;
		int cProtocols = 0;
		NodeData protocolDescriptor; // information about a specific protocol (i.e. L2CAP, RFCOMM, ...)

		pRecordContainer->GetNodeCount((DWORD *)&cProtocols);
		for (int j = 0; (! *pChann) && (j < cProtocols); j++) {
			pRecordContainer->GetNode(j,&protocolDescriptor);

			if (protocolDescriptor.type != SDP_TYPE_CONTAINER)
				continue;

			ISdpNodeContainer *pProtocolContainer = protocolDescriptor.u.container;
			int cProtocolAtoms = 0;
			pProtocolContainer->GetNodeCount((DWORD *)&cProtocolAtoms);

			for (int k = 0; (! *pChann) && (k < cProtocolAtoms); k++) {
				NodeData nodeAtom;  // individual data element, such as what protocol this is or RFCOMM channel id.

				pProtocolContainer->GetNode(k,&nodeAtom);

				if (IsRfcommUuid(&nodeAtom))  {
					if (k+1 == cProtocolAtoms) {
						// misformatted response.  Channel ID should follow RFCOMM uuid
						break;
					}

					NodeData channelID;
					pProtocolContainer->GetNode(k+1,&channelID);

					*pChann = (unsigned char)GetChannel(&channelID);
					break; // formatting error
				}
			}
		}
	}

    for (i = 0; i < cRecordArg; i++) 
		pRecordArg[i]->Release();

    CoTaskMemFree(pRecordArg);

	return (*pChann != 0) ? NO_ERROR : E_FAIL;
}

static void CleanInquiryData (void) {
	while (g_pState->pDev) {
		InquiryResult *pNext = g_pState->pDev->pNext;
		delete g_pState->pDev;
		g_pState->pDev = pNext;
	}
}

static DWORD PerformInquiry(HWND hWndDevList, int fDoNames, HANDLE *phLookup) {
	int iRet = ERROR_SUCCESS;

	WSAQUERYSET		wsaq;
	memset (&wsaq, 0, sizeof(wsaq));
	wsaq.dwSize      = sizeof(wsaq);
	wsaq.dwNameSpace = NS_BTH;
	wsaq.lpcsaBuffer = NULL;

	if (!fDoNames) {
		// perform initial device inquiry
		iRet = BthNsLookupServiceBegin (&wsaq, LUP_CONTAINERS, phLookup);
	} else {
		// reset iterator to front of list to find names
		DWORD dwUnused;
		iRet = BthNsLookupServiceNext (*phLookup, BTHNS_LUP_RESET_ITERATOR, &dwUnused, NULL);
	}
	
	if (iRet != ERROR_SUCCESS)
		return iRet;

	HANDLE hLookup = *phLookup;


	while ((iRet == ERROR_SUCCESS) && (g_pState->fState == DO_INQUIRY) && g_pState->hWnd) {
		union {
			CHAR buf[5000];
			SOCKADDR_BTH	__unused;	// properly align buffer to BT_ADDR requirements
		};

		LPWSAQUERYSET pwsaResults = (LPWSAQUERYSET) buf;
		DWORD dwSize  = sizeof(buf);

		memset(pwsaResults,0,sizeof(WSAQUERYSET));
		pwsaResults->dwSize      = sizeof(WSAQUERYSET);
		pwsaResults->dwNameSpace = NS_BTH;
		pwsaResults->lpBlob      = NULL;

		iRet = BthNsLookupServiceNext (hLookup, (fDoNames ? LUP_RETURN_NAME : 0) | LUP_RETURN_ADDR, &dwSize, pwsaResults);

		if (iRet == ERROR_SUCCESS) {

			InquiryResult *pRes = NULL;
			g_pState->Lock();
	
			if (fDoNames) {
				pRes = g_pState->pDev;
				while (pRes && (pRes->b != ((SOCKADDR_BTH *)pwsaResults->lpcsaBuffer->RemoteAddr.lpSockaddr)->btAddr))
					pRes = pRes->pNext;
			} else {
				pRes = new InquiryResult;
				if (pRes) {
					pRes->b = ((SOCKADDR_BTH *)pwsaResults->lpcsaBuffer->RemoteAddr.lpSockaddr)->btAddr;
					pRes->pNext = g_pState->pDev;
					g_pState->pDev = pRes;
				}
			}
			g_pState->Unlock ();

			if (! pRes)
				continue;


			int fHaveName = fDoNames && (pwsaResults->lpszServiceInstanceName && *(pwsaResults->lpszServiceInstanceName));

			WCHAR szDevice[MAX_NAME+25];
			wsprintf (szDevice, L"%s%s%04x%08x%s", fHaveName ? pwsaResults->lpszServiceInstanceName : L"", 
				fHaveName ? L"(" : L"", GET_NAP(pRes->b), GET_SAP(pRes->b), fHaveName ? L")" : L"");

			if (fDoNames) {
				if (fHaveName) {
					for (int i = 0 ; ; ++i) {
						int iData = SendMessage (hWndDevList, LB_GETITEMDATA, (WPARAM)i, (LPARAM)0);
						if (iData == LB_ERR)
							break;

						if (iData == (int)pRes) {
							if (SendMessage(hWndDevList, LB_GETTEXTLEN, (WPARAM)i, (LPARAM)0) <= (MAX_NAME + 64)) {
								SendMessage (hWndDevList, LB_DELETESTRING, (WPARAM)i, (LPARAM)0);
								SendMessage (hWndDevList, LB_INSERTSTRING, (WPARAM)i, (LPARAM)szDevice);
								SendMessage (hWndDevList, LB_SETITEMDATA,  (WPARAM)i, (LPARAM)pRes);
							}

							break;
						}
					}
				}
			} else {
				int iNdx = SendMessage (hWndDevList, LB_ADDSTRING, 0, (LPARAM)szDevice);
				if (iNdx >= LB_OKAY)
					SendMessage (hWndDevList, LB_SETITEMDATA, (WPARAM)iNdx, (LPARAM)pRes);
			}
		} else	//BthNsLookupServiceNext returns SOCKET_ERROR and sets last error
			iRet = GetLastError();
	}

	return ((iRet == WSA_E_NO_MORE) ? ERROR_SUCCESS : iRet);
}

static int DoSDP (BT_ADDR *pb) {
	CoInitializeEx (0, COINIT_MULTITHREADED);

	int iResult = 0;

	BTHNS_RESTRICTIONBLOB RBlob;

	memset (&RBlob, 0, sizeof(RBlob));

	RBlob.type = SDP_SERVICE_SEARCH_ATTRIBUTE_REQUEST;
	RBlob.numRange = 1;
	RBlob.pRange[0].minAttribute = SDP_ATTRIB_PROTOCOL_DESCRIPTOR_LIST;
	RBlob.pRange[0].maxAttribute = SDP_ATTRIB_PROTOCOL_DESCRIPTOR_LIST;
	RBlob.uuids[0].uuidType = SDP_ST_UUID16;
	RBlob.uuids[0].u.uuid16 = SerialPortServiceClassID_UUID16;

	BLOB blob;
	blob.cbSize = sizeof(RBlob);
	blob.pBlobData = (BYTE *)&RBlob;

	SOCKADDR_BTH	sa;

	memset (&sa, 0, sizeof(sa));

	*(BT_ADDR *)(&sa.btAddr) = *pb;
	sa.addressFamily = AF_BT;

	CSADDR_INFO		csai;

	memset (&csai, 0, sizeof(csai));
	csai.RemoteAddr.lpSockaddr = (sockaddr *)&sa;
	csai.RemoteAddr.iSockaddrLength = sizeof(sa);

	WSAQUERYSET		wsaq;

	memset (&wsaq, 0, sizeof(wsaq));
	wsaq.dwSize      = sizeof(wsaq);
	wsaq.dwNameSpace = NS_BTH;
	wsaq.lpBlob      = &blob;
	wsaq.lpcsaBuffer = &csai;

	HANDLE hLookup;
	int iRet = BthNsLookupServiceBegin (&wsaq, 0, &hLookup);

	if (ERROR_SUCCESS == iRet) {
		CHAR buf[5000];
		LPWSAQUERYSET pwsaResults = (LPWSAQUERYSET) buf;
		DWORD dwSize  = sizeof(buf);

		memset(pwsaResults,0,sizeof(WSAQUERYSET));
		pwsaResults->dwSize      = sizeof(WSAQUERYSET);
		pwsaResults->dwNameSpace = NS_BTH;
		pwsaResults->lpBlob      = NULL;

		iRet = BthNsLookupServiceNext (hLookup, 0, &dwSize, pwsaResults);
		if (iRet == ERROR_SUCCESS) {	// Success - got the stream
			unsigned char cChannel = 0;
			if (ERROR_SUCCESS == FindRFCOMMChannel (pwsaResults->lpBlob->pBlobData,
					pwsaResults->lpBlob->cbSize, &cChannel))
				iResult = cChannel;
		}

		BthNsLookupServiceEnd(hLookup);
	}

	CoUninitialize ();
	return iResult;
}

static DWORD WINAPI DoInquiry (LPVOID lpUnused) {
	g_pState->Lock ();

	HWND hWnd        = g_pState->hWnd;

	if ((! g_pState->hWnd) || (g_pState->fState == DO_STOP)) {
		g_pState->Unlock ();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产丝袜欧美中文另类| 久久久久久电影| 91国在线观看| 成人午夜精品一区二区三区| 国产一区二区不卡| 国产美女精品在线| 国产最新精品免费| 国产一区91精品张津瑜| 国产自产视频一区二区三区| 精品一区二区三区免费播放| 蜜桃视频在线观看一区二区| 美女任你摸久久 | 免费观看成人av| 日韩国产成人精品| 日本vs亚洲vs韩国一区三区| 免费成人美女在线观看| 久久99国产精品免费网站| 国产精品综合一区二区| 高清不卡一区二区在线| www.亚洲在线| 日本乱码高清不卡字幕| 777奇米四色成人影色区| 日韩美女主播在线视频一区二区三区| 精品国产一区二区三区av性色| 久久日一线二线三线suv| 欧美国产日韩亚洲一区| 一区二区三区日韩精品视频| 性欧美疯狂xxxxbbbb| 久久国产视频网| 成人激情免费网站| 欧美三级蜜桃2在线观看| 欧美一区二区视频在线观看| 久久久不卡影院| 亚洲精品国产a| 久久成人综合网| 91浏览器入口在线观看| 欧美在线|欧美| 韩国理伦片一区二区三区在线播放| 粉嫩蜜臀av国产精品网站| 在线观看视频一区| 久久综合网色—综合色88| 国产精品久久久久久久久免费樱桃| 亚洲综合av网| 国产一区二区三区综合| 91天堂素人约啪| 日韩午夜在线影院| 自拍偷拍亚洲综合| 蜜臀av亚洲一区中文字幕| 成人精品视频一区| 精品婷婷伊人一区三区三| 久久免费电影网| 亚洲成人av电影在线| 国产精品1024久久| 欧美日韩国产高清一区二区| 国产欧美一区视频| 丝袜美腿亚洲综合| 成人激情视频网站| 精品日韩一区二区三区| 一区二区三区四区亚洲| 精品伊人久久久久7777人| 欧美在线一二三| 国产精品午夜久久| 久久精品国产亚洲高清剧情介绍| 色av一区二区| 国产欧美日本一区视频| 日本在线不卡视频| 欧美性xxxxxxxx| 国产精品狼人久久影院观看方式| 蜜桃一区二区三区在线| 欧美天天综合网| 亚洲国产精品精华液ab| 久久精品久久久精品美女| 欧美写真视频网站| 亚洲欧美日韩国产另类专区 | 成人污视频在线观看| 日韩欧美国产综合| 亚洲二区在线视频| 91丨九色porny丨蝌蚪| 国产肉丝袜一区二区| 麻豆精品视频在线观看视频| 欧美性色黄大片| 亚洲三级在线观看| 成人一区二区在线观看| 久久一日本道色综合| 免费成人深夜小野草| 884aa四虎影成人精品一区| 一级特黄大欧美久久久| 91在线观看下载| 国产精品第四页| 懂色av一区二区三区免费观看| 26uuu亚洲婷婷狠狠天堂| 久久精品国产亚洲一区二区三区| 欧美精品一卡两卡| 亚洲国产精品嫩草影院| 色天天综合色天天久久| 亚洲视频一二三| 92精品国产成人观看免费| 亚洲国产电影在线观看| 国产成人亚洲综合色影视| 久久精品亚洲精品国产欧美kt∨| 久久精品国产精品亚洲综合| 日韩欧美色电影| 久久疯狂做爰流白浆xx| 久久一区二区三区四区| 国产精品白丝jk黑袜喷水| 久久精品综合网| 国产精品亚洲专一区二区三区| 久久久久九九视频| 国产一区二区三区四区五区入口 | 欧美日韩精品免费| 亚洲大片免费看| 欧美精品自拍偷拍动漫精品| 日本女人一区二区三区| 欧美一级日韩一级| 极品美女销魂一区二区三区| 欧美精品一区二区三区视频| 国产精品一二三| 国产精品美女一区二区三区 | 欧美日韩成人综合| 日韩精品亚洲专区| 欧美大胆人体bbbb| 国产一区二区三区香蕉| 国产精品国产三级国产aⅴ原创| 成人精品高清在线| 亚洲美女屁股眼交| 欧美日韩综合不卡| 麻豆极品一区二区三区| 久久品道一品道久久精品| 风间由美一区二区av101| 综合分类小说区另类春色亚洲小说欧美| 91久久精品一区二区三区| 亚洲国产aⅴ天堂久久| 欧美电视剧在线观看完整版| 成人福利视频在线| 亚洲自拍偷拍综合| 日韩欧美在线不卡| 国产东北露脸精品视频| 亚洲女同ⅹxx女同tv| 欧美日韩高清一区二区不卡| 精品在线视频一区| 国产精品二三区| 91精品免费在线观看| 国产一区二区三区在线观看精品 | 国产精品色噜噜| 欧美伊人久久久久久久久影院| 日韩激情在线观看| 久久久久久久久岛国免费| 91福利在线观看| 久久电影网电视剧免费观看| 中文字幕综合网| 91精品视频网| 91香蕉视频黄| 精品一区二区免费看| 亚洲欧美日韩久久| 日韩免费观看高清完整版在线观看| 成人激情电影免费在线观看| 天堂久久一区二区三区| 国产喷白浆一区二区三区| 欧美丝袜丝交足nylons图片| 久久99国产精品久久99 | 不卡的电视剧免费网站有什么| 亚洲国产综合人成综合网站| 久久九九99视频| 欧美二区乱c少妇| 91啪亚洲精品| 激情综合色播激情啊| 一区二区三区在线播| 国产网站一区二区| 欧美高清视频不卡网| 99在线精品观看| 国产在线一区观看| 亚洲成人自拍一区| 国产精品婷婷午夜在线观看| 制服丝袜国产精品| 在线视频欧美区| 成人性生交大片免费看中文 | 丝袜美腿亚洲色图| 中文字幕一区二区三区色视频| 欧美电影免费观看完整版| 欧美色窝79yyyycom| 成人aaaa免费全部观看| 国产中文字幕精品| 蜜臀av一区二区| 午夜在线电影亚洲一区| 亚洲三级免费电影| 中文乱码免费一区二区| 精品日韩av一区二区| 欧美久久久一区| 在线免费观看日韩欧美| 99视频一区二区| 国产91在线观看| 国产精品一区在线观看乱码| 全国精品久久少妇| 亚洲国产日韩一级| 亚洲黄色小视频| 日韩毛片一二三区| 亚洲欧美综合另类在线卡通| 国产欧美一区二区精品性色超碰| 日韩精品专区在线影院观看| 51精品视频一区二区三区|