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

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

?? opcdrvitem.cpp

?? 基于Intellution開發包的開發的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一区二区三区免费野_久草精品视频
国产亚洲美州欧州综合国| 久久久蜜桃精品| 91免费视频观看| 国产成人免费xxxxxxxx| 国产一区二区三区在线看麻豆| 热久久国产精品| 麻豆精品久久精品色综合| 久久超碰97中文字幕| 狠狠狠色丁香婷婷综合激情 | 成人动漫视频在线| 国产麻豆成人传媒免费观看| 国产剧情一区在线| 成人网在线免费视频| av电影在线观看不卡| 色综合激情五月| 欧美电影一区二区三区| 日韩精品专区在线影院重磅| 久久久久88色偷偷免费| 国产精品久久久久影视| 一级精品视频在线观看宜春院| 亚洲一区二区五区| 狠狠狠色丁香婷婷综合激情| 成人做爰69片免费看网站| 99免费精品视频| 欧美日韩一区二区在线观看 | 欧美日韩久久一区二区| 欧美一级日韩一级| 国产精品欧美久久久久无广告 | 国产日韩av一区| 成人免费在线视频| 青草av.久久免费一区| 国产成人综合亚洲网站| 在线观看国产91| 精品免费国产二区三区 | 在线区一区二视频| 91精品综合久久久久久| 亚洲国产精品av| 天天综合色天天综合| 国产精品一卡二卡在线观看| 欧美视频在线一区二区三区 | 亚洲自拍欧美精品| 国产一区二区福利视频| 欧美日韩一区二区电影| 国产精品色婷婷久久58| 蜜桃av一区二区三区电影| 在线亚洲欧美专区二区| 久久九九久精品国产免费直播| 天堂蜜桃一区二区三区| 99在线精品观看| 日韩午夜在线播放| 五月婷婷综合在线| 91蝌蚪porny九色| 久久久久久久精| 久久成人av少妇免费| 91精品黄色片免费大全| 亚洲激情网站免费观看| 不卡的av中国片| 亚洲一区免费在线观看| 91免费精品国自产拍在线不卡| 国产亚洲va综合人人澡精品| 人人超碰91尤物精品国产| 欧美日韩在线一区二区| 一区二区三区精品在线| 色素色在线综合| 中文字幕制服丝袜成人av| 国产一区欧美日韩| 欧美成人三级电影在线| 久久99深爱久久99精品| 日韩一区二区三区电影在线观看| 亚洲超丰满肉感bbw| 欧美色图一区二区三区| 一区二区三区四区av| 欧美性猛交xxxxxx富婆| 亚洲精品欧美专区| 91精彩视频在线| 午夜精品久久久久久久99樱桃 | 亚洲人成在线观看一区二区| 成人在线视频首页| 国产精品热久久久久夜色精品三区| 国产一区二区精品久久| 欧美国产禁国产网站cc| 99久久免费精品| 亚洲麻豆国产自偷在线| 欧美优质美女网站| 污片在线观看一区二区| 日韩欧美不卡在线观看视频| 国产精品中文有码| 一区精品在线播放| 欧美三区在线观看| 日韩福利电影在线| 久久久久久一级片| 91麻豆福利精品推荐| 五月激情综合网| 国产亚洲福利社区一区| 91在线精品一区二区三区| 亚洲福利电影网| 日韩情涩欧美日韩视频| 成熟亚洲日本毛茸茸凸凹| 亚洲激情图片qvod| 日韩精品一区二区三区老鸭窝| 国产成人在线免费| 亚洲成精国产精品女| 日韩欧美一二区| 99久久久久免费精品国产| 亚洲大片一区二区三区| 久久精品视频免费观看| 91精品福利在线| 精品一区二区三区欧美| 亚洲乱码日产精品bd| 日韩午夜精品电影| 色婷婷精品久久二区二区蜜臂av| 丝袜亚洲另类丝袜在线| 国产精品视频你懂的| 91精品国产91久久久久久一区二区| 国产精品自拍三区| 日韩精品久久久久久| 亚洲欧美综合色| 精品国产91久久久久久久妲己| 色婷婷综合久久| 国产剧情一区在线| 蜜臀a∨国产成人精品| 亚洲欧洲性图库| 久久久久久电影| 欧美电影影音先锋| 91极品美女在线| 成人福利视频在线看| 国产综合成人久久大片91| 婷婷夜色潮精品综合在线| 国产精品免费网站在线观看| 日韩一级完整毛片| 欧美日韩精品高清| 色婷婷久久久亚洲一区二区三区 | 亚洲欧美另类综合偷拍| 久久综合久久综合亚洲| 欧美日韩成人一区| 亚洲一区二区三区精品在线| 亚洲一区在线观看免费| 综合色天天鬼久久鬼色| 91捆绑美女网站| 久久国产综合精品| 亚洲精品网站在线观看| 成人黄色免费短视频| 8x福利精品第一导航| 色婷婷av一区二区三区之一色屋| 欧美三级乱人伦电影| 99国产精品国产精品久久| 国产精品18久久久久久久网站| 麻豆国产91在线播放| 蜜桃免费网站一区二区三区| 亚洲一区日韩精品中文字幕| 亚洲摸摸操操av| 国产精品久久久99| 亚洲欧美日韩国产综合| 一区二区三区.www| 日韩中文字幕av电影| 视频一区在线视频| 日韩中文字幕1| 蜜桃视频免费观看一区| 国产伦精品一区二区三区免费迷| 精品制服美女久久| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 国产中文字幕精品| 国产一区二区三区免费看| 国产精品18久久久久久vr| 国产成人综合亚洲网站| 成人爽a毛片一区二区免费| 暴力调教一区二区三区| 成人av免费在线播放| www.日韩在线| 在线欧美一区二区| 日韩一级成人av| 日本一区二区久久| 一区二区国产视频| 美女视频免费一区| 国产suv精品一区二区6| 成人av在线网站| 在线亚洲一区观看| 在线成人免费视频| 久久久精品国产免大香伊| 日韩一区日韩二区| 亚洲福利视频三区| 国产精品一二三| 色欧美片视频在线观看| 欧美xxx久久| 有码一区二区三区| 国产综合成人久久大片91| 色综合久久99| 久久网这里都是精品| 亚洲六月丁香色婷婷综合久久| 青青草原综合久久大伊人精品| 欧美日韩五月天| 久久精品久久久精品美女| 久久超碰97中文字幕| 99久久99久久久精品齐齐| 欧美一区二区福利在线| 综合久久给合久久狠狠狠97色| 免费在线观看日韩欧美| 91免费视频大全| 久久精品欧美日韩精品| 五月天激情综合网|