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

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

?? opcdrvitem.cpp

?? 基于Intellution開發(fā)包的開發(fā)的OPC服務器
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
//	OPCDrvItem.cpp
//
//  This file contains the implementation of the Item Object.
//
//  Note that there is nothing in the Custom interface definition
//  that actually requires the creation of a COM based Item Object.
//  However doing so is consistant with the approach taken for the 
//  vendor specific Server and Group objects and, 
//  although not required, is certainly a reasonable approach.
//  In addition it will provide a convenient place to attach
//  the Item Automation interface.
//
//	(c) COPYRIGHT 1996-1998, INTELLUTION INC.
// ALL RIGHTS RESERVED
//
//
//	Functions defined in this module:
//
//			COPCDrvItem::COPCDrvItem()
//			COPCDrvItem::~COPCDrvItem()
//			COPCDrvItem::AddRef()
//			COPCDrvItem::Release()
//			COPCDrvItem::QueryInterface()
//			COPCDrvItem::Init()
//			COPCDrvItem::SetActive()
//			COPCDrvItem::GetActive()
//			COPCDrvItem::SetHandle()
//			COPCDrvItem::GetHandle()
//			COPCDrvItem::SetDatatype()
//			COPCDrvItem::GetDatatype()
//			COPCDrvItem::Clone()
//			COPCDrvItem::IAGet()
//			COPCDrvItem::GetValue()
//			COPCDrvItem::WriteValue()
//			COPCDrvItem::UpdateDataCache()
//			COPCDrvItem::ReadValue()
//			COPCDrvItem::CheckDeviceRead()
//			COPCDrvItem::CheckDeviceWrite()
//			COPCDrvItem::MarkAsChanged()
//			COPCDrvItem::Changed()
//			COPCDrvItem::ClearChanged()
//			COPCDrvItem::DidDataChange()
//			COPCDrvItem::GetDataSize()
//			COPCDrvItem::GetIoDataFromVariant()
//			COPCDrvItem::SetupIoData()
//			COPCDrvItem::ParseItemIDOptions()
//			COPCDrvItem::GetNIOBlockType()
//
//
//
// Modification Log:
//	Vers	Date		By		Notes
//	----	--------	---		-----
//	1.0		08/26/97	jra		Created
//	1.3		03/10/98	jra		Modified to be wizard generated and driver specific.
//	7.11	01/22/99	jra		Added checks to operator=() and IAGet() to make sure we
//								have good pointers before cloning the strings.
//

#define WIN32_LEAN_AND_MEAN

#include "OpcStdAfx.h"
#include <math.h>
#include <afxconv.h>	// used for ATL conversion functions

#include "OPC.h"
#include "OPCError.h"
#include "OPCVariantPack.h"
#include "NioFuncs.h"
#include <DrvSignal.h>	// Used for Fix error codes returned by nio

////////////////////////////////////////////////////////////////
// External global variables
//
extern BOOL		g_bAutoStart;
extern WORD		g_wStringLength;
extern TCHAR	g_tszAcronym[];


////////////////////////////////////////////////////////////////
// Seperators used to parse out the Item definition
////////////////////////////////////////////////////////////////
const char		*g_psDrvNameFromAddressSeparator		= ":";
const char		*g_psAddressFromSignalCondSeperator		= "|";
const char		*g_psSignalCondParameterSeperator		= ",";
const char		*g_psDecimalPoint						= ".";


////////////////////////////////////////////////////////////////
// External default values for Item parameters obtained from 
// the registry.
////////////////////////////////////////////////////////////////
extern CString	g_strDefaultSignalConditioning;
extern CString	g_strDefaultHiEGU;
extern CString	g_strDefaultLoEGU;
extern CString	g_strDefaultHardwareOptions;


////////////////////////////////////////////////////////////////
// COPCDrvItem()
// 
// Constructor for the Item.
//
////////////////////////////////////////////////////////////////
COPCDrvItem::COPCDrvItem(COPCDrvGroup *pUnkOuter)
{
	m_lRefCount			= 0;

	// Record Parent Group
	//
	m_pParentGroup		= pUnkOuter;

	// init pointers
	//
	m_szItemID			= NULL;
	m_szAccessPath		= NULL;
	m_pTempBuff			= NULL;

	// Init data stuff
	VariantInit(&m_vReturnedData);
	m_vtCanonical		= VT_EMPTY;
	m_wQuality			= WORD_QUALITY_BAD;
	m_bLastKnown		= FALSE;

	m_AsyncMask			= 0;

	m_IodName.dhandle	= 0;
    strncpy(m_IodName.dname, "", 9);
	m_IovSpec.dcb = &m_IodName;
	_tcscpy(m_IovSpec.dcb->dname, g_tszAcronym);

    memset(&m_IoRec, 0, sizeof(IOREC));
    strncpy(m_IoRec.addr_string, "", 10);
	m_IovSpec.iorec = &m_IoRec;

    memset(&m_IoRec2, 0, sizeof(IOREC2));
    strncpy(m_IoRec2.device_name, "", 10);
    strncpy(m_IoRec2.aux_info, "", 127);
	m_IovSpec.iorec2 = &m_IoRec2;

	m_AEguRec.span		= 65535.0;
	m_AEguRec.lo		= 0.0;
	m_AEguRec.ef		= 0;
    strncpy(m_AEguRec.etag, "", 4);

	strncpy(m_DEguRec.open, "OPEN", 4);
	strncpy(m_DEguRec.close, "CLOSE", 5);

	m_EguRec.type		= EGU_A;
	m_EguRec.dd			= EGU_IN;
	m_EguRec.AREC		= m_AEguRec;

	memset(&m_IoStat, 0, sizeof(IOSTAT));

	InitializeCriticalSection(&this->m_Lock);
}


////////////////////////////////////////////////////////////////
// ~COPCDrvItem()
// 
// Destructor for the OPC Item.
//
////////////////////////////////////////////////////////////////
COPCDrvItem::~COPCDrvItem(void)
{
	this->Lock();

	// Free memory associated with the Item
	//
	if (m_szItemID) 
	{
		delete [] m_szItemID;
	}
	if (m_szAccessPath)
	{
		delete [] m_szAccessPath;
	}
	if (m_pTempBuff)
	{
		delete [] m_pTempBuff;
	}

	this->UnLock();

	DeleteCriticalSection(&this->m_Lock);
}


/////////////////////////////////////////////////////////////////////////////
// IUnknown functions
//

////////////////////////////////////////////////////////////////
// IUnknown::AddRef()
//
// Standard IUnknown implementation
//
////////////////////////////////////////////////////////////////
STDMETHODIMP_(ULONG) COPCDrvItem::AddRef(void)
{
	return InterlockedIncrement(&m_lRefCount);
}


////////////////////////////////////////////////////////////////
// IUnknown::Release()
// 
// Standard IUnknown implementation
//
////////////////////////////////////////////////////////////////
STDMETHODIMP_(ULONG) COPCDrvItem::Release(void)
{
	ASSERT(0 != m_lRefCount);

	ULONG currentCount = InterlockedDecrement(&m_lRefCount);

	// If no references left for this Item
	if (currentCount == 0)
	{
		// Then delete this Item.
		delete this;
	}
	return currentCount;
}


////////////////////////////////////////////////////////////////
// IUnknown::QueryInterface()
//
// Standard IUnknown implementation
//
////////////////////////////////////////////////////////////////
STDMETHODIMP COPCDrvItem::QueryInterface(REFIID		iid, 
										 LPVOID		*ppInterface)
{
	// Make sure that we got a good pointer.
	//
	if (NULL == ppInterface)
	{
		return E_INVALIDARG;
	}

	// IUnknown
	if (iid == IID_IUnknown)
	{
		*ppInterface = (IUnknown *)this;
	}
	// No interface ava1lable
	else
	{
		*ppInterface = NULL;
	}
	
	if (NULL == *ppInterface)
	{
		return E_NOINTERFACE;
	}

	((LPUNKNOWN)*ppInterface)->AddRef();
	return S_OK;
}


/////////////////////////////////////////////////////////////////////////////
// Member functions
//


////////////////////////////////////////////////////////////////
// operator=()
//
// Overloaded operator=
//
// Sets an OPCDrvItem members equal to another OPCDrvItem's members
//
// Returns:
//	a reference to the object
//
////////////////////////////////////////////////////////////////
COPCDrvItem & COPCDrvItem::operator= (const COPCDrvItem	&OtherItem)
{
	// jra 012299
	// Verify that the pointers are good before cloning
	if (this->m_szItemID)
	{
		this->m_szItemID = WSTRClone(OtherItem.m_szItemID, NULL);
	}

	if (this->m_szAccessPath)
	{
		this->m_szAccessPath = WSTRClone(OtherItem.m_szAccessPath, NULL);
	}

	this->m_hClientItemHandle	= OtherItem.m_hClientItemHandle;
	this->m_vtRequested			= OtherItem.m_vtRequested;
	this->m_vtCanonical			= OtherItem.m_vtCanonical;
	this->m_wNumElements		= OtherItem.m_wNumElements;
	this->m_AsyncMask			= OtherItem.m_AsyncMask;

	this->m_IodName.dhandle		= OtherItem.m_IodName.dhandle;
	
	this->m_AEguRec.span		= OtherItem.m_AEguRec.span;
	this->m_AEguRec.lo			= OtherItem.m_AEguRec.lo;
	this->m_AEguRec.ef			= OtherItem.m_AEguRec.ef;

	this->m_EguRec.type			= OtherItem.m_EguRec.type;
	this->m_EguRec.dd			= OtherItem.m_EguRec.dd;
	this->m_EguRec.AREC			= OtherItem.m_EguRec.AREC;

	strcpy(this->m_IodName.dname, OtherItem.m_IodName.dname);
    strcpy(this->m_IoRec.addr_string, OtherItem.m_IoRec.addr_string);
    strcpy(this->m_IoRec2.device_name, OtherItem.m_IoRec2.device_name);
    strcpy(this->m_IoRec2.aux_info, OtherItem.m_IoRec2.aux_info);
	strcpy(this->m_AEguRec.etag, OtherItem.m_AEguRec.etag);

	return *this;
}


////////////////////////////////////////////////////////////////
// Init()
//
// Initialize the ITEM per the OPCITEMDEF
//
// This function will parse out the supplied ItemID buffer and 
// extract all of the needed data. It will then call the proper 
// NIO functions to pass the data down to the driver for 
// validation.
//
// Returns:
//	HRESULT	-	S_OK if the function was successful.
//			-	OPC_E_INVALIDITEMID if the string is not in a 
//				valid format.
//			-	E_OUTOFMEMORY if a memory allocator failed.
//
////////////////////////////////////////////////////////////////
HRESULT COPCDrvItem::Init(int				OPCHandle, 
						  OPCITEMDEF		*pItemDef, 
						  OPCITEMRESULT		*pItemResult)
{
	HRESULT			hr;
	
	SYSTEMTIME		SystemTime;
	
	IOSTAT			IoStat;
	
	CString			szAddr;
	
	int				nIndex = -1;

	CString			strSignalCond;
	CString			strLowEGU;
	CString			strHighEGU;
	CString			strHardwareOptions;
	CString			strStringLength;
	CString			strItemID;
	CString			strTmpID;
	CString			strMsg;


    memset(&IoStat, 0, sizeof(IOSTAT));
	memset(pItemResult, 0, sizeof(OPCITEMRESULT));
	
	// Initialize data values
	//
	GetSystemTime(&SystemTime);								// Get current UTC Time
	SystemTimeToFileTime(&SystemTime, &m_ftLastWriteTime);	// and store it

	// Free memory associated with the Temp Item
	// This is done because this function is used by ValidateItems() as well.
	//
	if (this->m_szItemID) 
	{
		delete [] m_szItemID;
	}
	if (this->m_szAccessPath)
	{
		delete [] m_szAccessPath;
	}

	//
	// Copy the ItemID and Accesspath
	// Make sure that both the passed pointers are not NULL.
	//
	if (pItemDef->szItemID)
	{
		m_szItemID = WSTRClone(pItemDef->szItemID, NULL);
		if (NULL == m_szItemID)
		{
			return E_OUTOFMEMORY;
		}
	}
	else
	{
		strMsg.Format("OPC DLL: Item id passed as NULL");
		m_pParentGroup->m_pParentServer->SendMessageToDriver(strMsg, MSG_DEBUG);

		return OPC_E_INVALIDITEMID;
	}

	if (pItemDef->szAccessPath)
	{
		m_szAccessPath = WSTRClone(pItemDef->szAccessPath, NULL);
		if (NULL == m_szAccessPath)
		{
			return E_OUTOFMEMORY;
		}
	}
	else
	{
		m_szAccessPath = NULL;
	}

	strItemID = pItemDef->szItemID;
	strItemID.MakeUpper();
	if (strItemID.IsEmpty())
	{
		strMsg = "OPC DLL: Empty Item ID passed";
		m_pParentGroup->m_pParentServer->SendMessageToDriver(strMsg, MSG_DEBUG);

		// The item id is not syntactically valid, so return an error
		return OPC_E_INVALIDITEMID;
	}

	strItemID.TrimLeft();
	strItemID.TrimRight();


	// Validate the requested datatype
	//
	if(FAILED(hr = SetDatatype(pItemDef->vtRequestedDataType, TRUE)))
	{
		strMsg.Format("OPC DLL: Invalid requested datatype (%d)", pItemDef->vtRequestedDataType);
		m_pParentGroup->m_pParentServer->SendMessageToDriver(strMsg, MSG_DEBUG);

		return hr;
	}


	//////////////////////////////////////////////////////////////////////
	//
	// Format of ItemID
	//
	// For analog and digital data:
	//	DEVICENAME:ADDRESS|SIGNALCONDITIONING,LOWEGU,HIGHEGU,HARDWAREOPTIONS
	//
	// For ASCII data:
	//	DEVICENAME:ADDRESS|NUMBEROFCHARACTERS
	//
	//////////////////////////////////////////////////////////////////////
	

	//////////////////////////////////////////////////////////////////////
	//
	// Get 'I/O ADDRESS' portion of ItemID
	//
	//////////////////////////////////////////////////////////////////////
	nIndex = strItemID.FindOneOf(g_psAddressFromSignalCondSeperator);

	if (nIndex > 0)
	{
		szAddr = strItemID.Left(nIndex);
		strTmpID = strItemID.Mid(nIndex + 1);
		if (szAddr.IsEmpty())
		{
			strMsg.Format("OPC DLL: Empty I/O address passed");
			m_pParentGroup->m_pParentServer->SendMessageToDriver(strMsg, MSG_DEBUG);

			// The item id is not syntactically valid, so return an error
			return OPC_E_INVALIDITEMID;
		}
	}
	else
	{
		szAddr = strItemID;
		strTmpID.Empty();
	}

	// Validate I/O Address through NIO
	//
	memset(&IoStat, 0, sizeof(IOSTAT));
	nio_paddr(&IoStat, &m_IovSpec, &m_EguRec, (char *)LPCTSTR(szAddr));

	if(IoStat.iostatus != FE_OK)
	{
		strMsg.Format("OPC DLL: Invalid item id passed to nio_paddr() (%s)", szAddr);
		m_pParentGroup->m_pParentServer->SendMessageToDriver(strMsg, MSG_DEBUG);

		// The item id is not syntactically valid, so return an error
		return OPC_E_INVALIDITEMID;
	}


	//////////////////////////////////////////////////////////////////////
	//
	// Get the "SIGNAL_COND,LO_EGU,HI_EGU,HARDWARE_OPTS" portion of ItemID
	//
	//////////////////////////////////////////////////////////////////////
	if (!strTmpID.IsEmpty())
	{
		// Signal Conditioning options.
		// If should be in the following format:
		//		SIGNAL_COND,LO_EGU,HI_EGU,HARDWARE_OPTIONS
		// where an example could be:
		//		LIN,0,100,UInt

		if (EGU_X == m_EguRec.type)	// Ascii data
		{
			//
			// Get the number of characters to read
			//

			if((nIndex = strTmpID.FindOneOf(g_psSignalCondParameterSeperator)) == -1)
			{
				strStringLength = strTmpID;
			}
			else
			{
				strStringLength = strTmpID.Left(nIndex);
			}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜电影一区二区三区| 国产亚洲一区二区在线观看| 亚洲国产你懂的| 欧美亚洲日本国产| 免费视频最近日韩| 久久久久国产免费免费| 波多野结衣中文字幕一区 | 欧美系列日韩一区| 婷婷久久综合九色综合伊人色| 欧美男女性生活在线直播观看| 男女男精品网站| 久久久激情视频| 色综合天天在线| 午夜国产精品一区| 国产午夜三级一区二区三| 96av麻豆蜜桃一区二区| 天天影视网天天综合色在线播放| 精品日韩在线一区| 9人人澡人人爽人人精品| 亚洲第一福利一区| 色一区在线观看| 一区二区三区欧美在线观看| 制服丝袜一区二区三区| 国产乱一区二区| 伊人夜夜躁av伊人久久| 欧美成人精品1314www| 不卡的av电影在线观看| 日韩不卡一二三区| 日韩美女视频19| 精品黑人一区二区三区久久| voyeur盗摄精品| 美女爽到高潮91| 一级日本不卡的影视| 精品动漫一区二区三区在线观看| 成人黄色大片在线观看| 美腿丝袜亚洲三区| 亚洲最大成人网4388xx| 久久久精品中文字幕麻豆发布| 日本电影欧美片| 国产一区 二区| 亚洲福利国产精品| 国产精品精品国产色婷婷| 日韩欧美一二三四区| 91成人在线免费观看| 国产91对白在线观看九色| 美女视频黄 久久| 亚洲一二三区在线观看| 亚洲国产精品高清| 精品久久久久久久久久久久久久久久久| 92精品国产成人观看免费| 国产乱子轮精品视频| 日本在线不卡一区| 一区二区三区高清不卡| 中文字幕一区二区三区蜜月| 久久久不卡网国产精品二区| 日韩一区二区影院| 欧美在线你懂的| 91美女片黄在线观看91美女| 国产精品系列在线观看| 国产综合色在线视频区| 日韩精品电影在线观看| 亚洲成av人影院| 亚洲一区二区三区中文字幕| 亚洲蜜臀av乱码久久精品蜜桃| 国产精品视频一二三| 久久久综合精品| 精品精品欲导航| 日韩欧美亚洲一区二区| 91精品国产免费| 91精品国产黑色紧身裤美女| 欧美日韩电影在线播放| 欧美日韩精品一区二区三区蜜桃| 91福利视频网站| 在线观看亚洲一区| 欧美在线不卡一区| 欧美色网站导航| 欧美人xxxx| 制服丝袜亚洲色图| 日韩你懂的在线播放| 欧美一级免费观看| 精品美女一区二区| 久久综合狠狠综合久久综合88 | 久久综合九色综合97_久久久| 欧美一级二级在线观看| 日韩一区二区免费在线观看| 日韩欧美在线影院| 久久这里只有精品6| 国产精品丝袜在线| 一区二区在线免费观看| 天堂久久久久va久久久久| 日本在线不卡视频| 国产精品一区二区91| 成人av第一页| 欧美日韩色一区| 欧美刺激午夜性久久久久久久 | av成人动漫在线观看| 色综合一区二区| 欧美乱妇23p| xfplay精品久久| 中文字幕在线观看一区| 亚洲国产一区二区三区| 蜜臀av性久久久久蜜臀av麻豆| 狠狠v欧美v日韩v亚洲ⅴ| 不卡av电影在线播放| 欧美日韩一区二区三区四区五区 | 欧美区一区二区三区| 欧美成人艳星乳罩| 欧美国产1区2区| 夜夜夜精品看看| 久久超碰97中文字幕| 成人性生交大片免费看中文网站 | 337p亚洲精品色噜噜狠狠| 久久嫩草精品久久久精品一| 1024成人网| 久久综合综合久久综合| bt欧美亚洲午夜电影天堂| 69堂国产成人免费视频| 亚洲国产精品黑人久久久| 亚洲成a人片综合在线| 粉嫩嫩av羞羞动漫久久久| 在线观看视频一区二区| 国产视频一区不卡| 午夜久久久久久| 91女神在线视频| 精品国产免费一区二区三区香蕉| 亚洲精品久久7777| 国产一区二区在线观看免费| 欧美无乱码久久久免费午夜一区 | 亚洲超碰97人人做人人爱| 国产a久久麻豆| 欧美男女性生活在线直播观看| 国产精品人妖ts系列视频| 免费欧美在线视频| 色婷婷久久99综合精品jk白丝| 久久久久久亚洲综合影院红桃 | 极品少妇xxxx偷拍精品少妇| 在线观看精品一区| 中文字幕欧美日韩一区| 麻豆精品在线观看| 欧美日韩亚州综合| 中文字幕一区二区5566日韩| 九色porny丨国产精品| 7777精品伊人久久久大香线蕉超级流畅| 国产精品丝袜一区| 国产成人免费av在线| 日韩精品综合一本久道在线视频| 有坂深雪av一区二区精品| 成人禁用看黄a在线| 国产午夜精品久久久久久久| 免费亚洲电影在线| 在线综合亚洲欧美在线视频| 一区二区在线观看免费视频播放| 国产99久久久国产精品潘金网站| 欧美一区二区三区喷汁尤物| 亚洲第一主播视频| 欧美在线一区二区| 亚洲午夜在线观看视频在线| 99精品国产99久久久久久白柏| 国产日韩v精品一区二区| 国产一区二区电影| 久久久国产一区二区三区四区小说 | 色婷婷激情综合| 亚洲人成网站精品片在线观看| 成人av先锋影音| 中文字幕一区免费在线观看| a美女胸又www黄视频久久| 久久免费偷拍视频| 国产寡妇亲子伦一区二区| 国产女主播一区| 成人性生交大片免费看中文网站| 中文字幕va一区二区三区| 成人手机在线视频| |精品福利一区二区三区| 色94色欧美sute亚洲线路一ni| 一区二区成人在线观看| 欧美日韩中文国产| 日本欧美肥老太交大片| 日韩欧美国产成人一区二区| 国产乱子伦视频一区二区三区| 国产欧美久久久精品影院| 91在线国产观看| 亚洲一级在线观看| 日韩三级av在线播放| 国产一区二区视频在线播放| 国产亚洲一区二区三区四区| av福利精品导航| 亚洲v精品v日韩v欧美v专区 | 欧美偷拍一区二区| 乱一区二区av| 成人欧美一区二区三区| 在线欧美日韩国产| 日本成人在线不卡视频| 国产欧美日韩卡一| 欧美写真视频网站| 国产一区二区三区最好精华液| 亚洲情趣在线观看| 日韩欧美在线观看一区二区三区| 国产激情91久久精品导航| 亚洲综合图片区| 精品国产乱码久久久久久牛牛|