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

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

?? upd_item.cpp

?? 一個OPC服務器開發的源代碼。結構清晰
?? CPP
字號:
/**************************************************************************
 *                                                                        *
 * Light OPC Server development library                                   *
 *                                                                        *
 *   Copyright (c) 2000 by Timofei Bondarenko                             *
                                                                          *
 item updating routines
 **************************************************************************/
#include "privopc.h"
#include "nan.h"
#include <math.h>

/*********************************************************************************/

#if 0
#define R8_CLEAR(v) VariantClear(v)
#else
#define R8_CLEAR(v)
#endif

static int lo_compare_lastsent(LightOPCItem *item, loTagEntry *prim, double *deadband)
{
 VARIANT *pv = &prim->primValue;
 VARIANT var;

 if (loTF_NOCOMP & prim->attr.taFlags) return 1;

 if (VT_BSTR == V_VT(pv))
   {
    unsigned lastsent_len = item->lastsent? item->lastsent[0]: 0;
    unsigned len = loBSTR_SIZE(V_BSTR(pv));

    if (deadband &&
        len == lastsent_len &&
        !memcmp(V_BSTR(pv), &item->lastsent[1], len)) return 0;

    if (len <= lastsent_len && lastsent_len ||
        preallocX((void**)&item->lastsent, len + sizeof(item->lastsent[0])))
      {
       memcpy(&item->lastsent[1], V_BSTR(pv), item->lastsent[0] = len);
      }
    return 1;
   }
 VARIANTINIT(&var);

 if (V_ISARRAY(pv)) /* Under Wine the VarChangeType() does not detect arrays. */
   {
    void *ptr;
    HRESULT hr;
    SAFEARRAY *sa = V_ARRAY(pv);

    hr = loSA_AccessData(sa, &ptr);
    if (FAILED(hr))
      {
       UL_ERROR((LOGID, "%!l SafeArrayAccessData() FAILED", hr));
      }
    else
      {
       unsigned len = sa->cbElements * sa->rgsabound[0].cElements;
       unsigned lastsent_len = item->lastsent? item->lastsent[0]: 0;

       if (deadband &&
           len == lastsent_len &&
           !memcmp(ptr, item->lastsent + 1, len))
         {
          SafeArrayUnaccessData(sa); return 0;
         }
       if (len <= lastsent_len && lastsent_len ||
           preallocX((void**)&item->lastsent, len + sizeof(item->lastsent[0])))
         {
          memcpy(item->lastsent + 1, ptr, item->lastsent[0] = len);
         }
       SafeArrayUnaccessData(sa);
      }
   }
 else if (/*VT_EMPTY == (vt = V_VT(pv)) ||*/     
          S_OK == VariantChangeType(&var, pv, 0, VT_R8))
   {
    if (deadband)
      {
       if (!memcmp(&item->numeric, &V_R8(&var), sizeof(item->numeric)))
         {
          R8_CLEAR(&var); return 0;
         }
       if (
#if loTt_ZERORANGE
           !(prim->attr.taFlags & loTt_ZERORANGE) && *deadband &&
#else
           *deadband &&/***/ prim->attr.taRangecent /*OPC_ANALOG*/ &&
#endif
           !lo_IsNANd(V_R8(&var)) && !lo_IsNANd(item->numeric) &&
           fabs(V_R8(&var) - item->numeric) <= *deadband * prim->attr.taRangecent)
         {
          R8_CLEAR(&var); return 0;
         }
/*else UL_ERROR((LOGID, "Dead=%g range/100=%g abs=%g - %g = %g result:%g",
              *deadband,
              prim->attr.rangecent,
              V_R8(&var), item->numeric, fabs(V_R8(&var) - item->numeric),
              fabs(V_R8(&var) - item->numeric)/prim->attr.rangecent));*/
      }
    memcpy(&item->numeric, &V_R8(&var), sizeof(item->numeric));
    R8_CLEAR(&var);
   }
 else UL_INFO((LOGID, "lo_compare_lastent() Unknown VARTYPE 0x%X", V_VT(pv)));

 return 1;
}

static int lo_compare_dummy(LightOPCItem *item, loTagEntry *prim, double *deadband)
{
 return 1; /* Always different */
}

unsigned lo_refresh_items(loService *se, loUpdList *upl, LightOPCGroup *grp)
{
 int (*compare_item)(LightOPCItem *, loTagEntry *, double *);
 unsigned ii, count = grp->active_count;
 LightOPCItem **items = (LightOPCItem **)grp->itl.gl_list;
 double deadband = grp->Deadband;
 loTagEntry *tags = se->tags;

// UL_DEBUG((LOGID, "refresh_items() {..."));

 if (count > grp->itl.gl_count)
   {
    UL_ERROR((LOGID, "Group::active %u(%d) count %u mismatch",
              count, count, grp->itl.gl_count));
    count = grp->itl.gl_count;
   }

 compare_item = (se->driver.ldFlags & loDF_NOCOMP)
           ? lo_compare_dummy
           : lo_compare_lastsent;

 upl->used = 0;
 upl->master_err = S_OK;
 upl->master_qual = S_OK;
 if (lo_upl_grow(upl, count))
   {
    UL_ERROR((LOGID, "%ls refresh/grow(%u) FAILED",
                      loWnul(grp->name), grp->itl.gl_count));
    upl->master_err = E_OUTOFMEMORY;
    upl->master_qual = S_FALSE;
   }
 else
   {
    unsigned used = 0;
    loUpdList lup = *upl;
// lup.deadband = grp->Deadband;
// lup.tags = se->tags;

    count = grp->itl.gl_count;
    for(ii = 0; ii < count; ii++)
      {
       LightOPCItem *item;
       if ((item = items[ii]) && item->bActive)
         {
          HRESULT hr;
          WORD quality;
          loTagEntry *prim = &tags[item->tid];

#if 0 != LO_CHECK_RIGHTS
          if (!(OPC_READABLE & prim->attr.taRights)) continue;
#endif

          if (item->Quality == (quality = prim->prim.tsQuality))
            {
             if (item->last_changed == prim->primChanged)
               {
                if (0 == lup.trqid) continue;
               }
             else if (!compare_item(item, prim, &deadband))
               {
                item->last_changed = prim->primChanged;
                if (0 == lup.trqid) continue;
               }
            }
          else compare_item(item, prim, 0);
          item->last_changed = prim->primChanged;

          if (OPC_QUALITY_GOOD != (OPC_QUALITY_MASK & quality))
            lup.master_qual = S_FALSE;

#if 1 == LO_EV_TIMESTAMP
          if (!IsFILETIME(prim->prim.tsTime))
            lup.timestamp[used] = loFT_SUBST(prim->prim.tsTime, se->ts_prim);
          else
#endif
          lup.timestamp[used] = prim->prim.tsTime;
          lup.opchandle[used] = item->hClient;

          if (S_OK != (lup.errors[used] = prim->prim.tsError))
            lup.master_err = S_FALSE;
#ifdef VAR_CHANGETYPE
          hr = VAR_CHANGETYPE(&lup.variant[used], &prim->primValue,
                              item->vtRequestedDataType);
#else
          switch(item->convtype)
            {
          case loCONV_CHANGE:
             hr = VARIANTCHANGEt(&lup.variant[used], &prim->primValue,
                                 lup.rctx.cta, item->vtRequestedDataType);
             break;
          case loCONV_COPY:
             hr = VariantCopy(&lup.variant[used],
                              &prim->primValue);
             break;
          case loCONV_ASSIGN:
             lup.variant[used] = prim->primValue;
             goto SkipHR;
             hr = S_OK;
             break;
          case loCONV_CONVERT:
               {
                loTagPair tp;
                tp.tpTi = item->tid;
                tp.tpAP = item->AcPath;
                tp.tpRt = prim->attr.taRt;

                se->driver.ldConvertTags(&lup.rctx.cactx, 1, &tp,
                      &lup.variant[used], &quality, &lup.errors[used],
                      &lup.master_err, &lup.master_qual, &prim->primValue,
                      &item->vtRequestedDataType, grp->grLCID);
                goto SkipHR;
                hr = S_OK;
               }
             break;
            }
#endif
          if (S_OK != hr)
            {
             LO_E_BADTYPE_QUAL(hr, lup.errors[used], quality);
             lup.master_err = S_FALSE;
             lup.master_qual = S_FALSE;
//             item->Quality = lup.quality[used];
             //item->Quality = -1; /* try again next time?? */
//UL_WARNING((LOGID, "%!l upd_item(%ls)::CHNGETYPE",loWnul(prim->attr.taName), hr));
            }
SkipHR:   lup.quality[used] = quality;
          item->Quality = quality;
          used++;
 // if (V_VT(&upl->vars[used]) == VT_EMPTY) UL_ERROR((LOGID, "update_item"));
         }
      } /* end of for(;;) */

    if (used > grp->active_count)
      {
       UL_ERROR((LOGID, "Group::active %u used %u mismatch",
              grp->active_count, lup.used));
      }
//    if (S_OK == lup.master_err && !lup.used) lup.master_err = S_FALSE;
    upl->master_err = lup.master_err;
    upl->master_qual = lup.master_qual;
    upl->used = used;
#if 2 == LO_EV_TIMESTAMP
    if (IsFILETIME(*se->ts_prim))
      lo_check_ev_timestamp(used, upl->timestamp, se->ts_prim);
#endif
   }
// UL_DEBUG((LOGID, "refresh_items()...}"));
 return upl->used;
}

/* end of upd_item.cpp */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
9i看片成人免费高清| 欧美一区二区三区免费在线看| 日韩一区二区三| 亚洲v精品v日韩v欧美v专区| 欧美色成人综合| 日韩电影免费一区| 欧美不卡123| 国产成人在线视频免费播放| 国产精品久久久久久久岛一牛影视 | 久久99国产精品免费| 精品免费日韩av| 成人app网站| 亚洲影院在线观看| 日韩视频一区二区| 国产精品一区不卡| 亚洲精选视频免费看| 欧美日韩国产成人在线91| 蜜臀av一区二区在线观看| 久久亚洲一区二区三区四区| 99久久精品免费看| 午夜亚洲国产au精品一区二区| 欧美一区二区三区啪啪| 风间由美一区二区三区在线观看| 亚洲日本一区二区三区| 91精品国产色综合久久不卡蜜臀| 国产美女主播视频一区| 亚洲精品视频在线| 欧美va亚洲va在线观看蝴蝶网| 国v精品久久久网| 一二三区精品福利视频| 精品毛片乱码1区2区3区| 成人app在线| 久久99久久99| 一区二区三区精品久久久| 日韩欧美电影在线| 91视频在线观看免费| 美女在线视频一区| 亚洲精品免费一二三区| 日韩免费电影网站| 欧美日韩在线播放| 成人国产亚洲欧美成人综合网 | 亚洲不卡av一区二区三区| 久久综合久久综合亚洲| 欧美色精品在线视频| 成人午夜在线免费| 男女性色大片免费观看一区二区| 中文字幕一区二区三区av| 欧美α欧美αv大片| 日本电影亚洲天堂一区| 国产精品1024| 青青国产91久久久久久| 一区二区三区欧美亚洲| 国产亚洲精品aa| 日韩精品中文字幕在线不卡尤物| 欧美性感一区二区三区| 色综合中文字幕国产| 国产福利视频一区二区三区| 麻豆成人av在线| 亚洲国产成人av好男人在线观看| 日韩美女啊v在线免费观看| www国产精品av| 日韩免费高清视频| 91精品午夜视频| 欧美系列在线观看| 在线观看亚洲a| 99久久99久久免费精品蜜臀| 高潮精品一区videoshd| 国内精品伊人久久久久av影院| 免费在线观看一区| 偷窥少妇高潮呻吟av久久免费| 亚洲男同1069视频| 中文字幕一区二区三区在线播放| 国产亚洲一区二区三区四区| 久久久久国产一区二区三区四区| 精品三级在线看| 日韩欧美一二区| 精品久久久久一区| 日韩网站在线看片你懂的| 欧美日韩成人综合| 欧美日韩一区三区四区| 欧美在线色视频| 欧美日韩精品免费观看视频| 欧美中文字幕久久| 欧美人妇做爰xxxⅹ性高电影| 在线一区二区观看| 欧美在线不卡视频| 欧美日韩激情一区二区三区| 欧美高清一级片在线| 777亚洲妇女| 日韩限制级电影在线观看| 精品国产91久久久久久久妲己| 久久九九国产精品| 中文字幕日本不卡| 亚洲夂夂婷婷色拍ww47| 亚洲www啪成人一区二区麻豆| 美女网站一区二区| 国产精品77777竹菊影视小说| 成人中文字幕合集| 欧美视频一区二区三区在线观看| 欧美午夜精品久久久久久超碰 | 欧美国产日韩a欧美在线观看| 国产精品免费久久久久| 亚洲男人天堂av网| 视频一区在线播放| 国产一区视频在线看| 91色porny在线视频| 在线播放国产精品二区一二区四区 | 欧美一级理论性理论a| 精品国产乱码久久久久久浪潮| 久久久精品国产99久久精品芒果 | 一区二区三区欧美日| 天天综合网 天天综合色| 裸体歌舞表演一区二区| 99久久精品国产网站| 欧美夫妻性生活| 国产欧美一区二区三区网站| 一区二区三区四区高清精品免费观看 | 视频一区视频二区中文字幕| 国产乱子轮精品视频| 欧美性一二三区| 国产午夜精品美女毛片视频| 亚洲一区二区三区精品在线| 韩国成人精品a∨在线观看| 色综合欧美在线| 久久影音资源网| 一区二区三区日本| 丁香网亚洲国际| 欧美一级高清大全免费观看| 成人欧美一区二区三区白人| 蜜臀久久久99精品久久久久久| 99久久国产免费看| 2021国产精品久久精品| 亚洲午夜一区二区| 国产一区二区导航在线播放| 欧美片网站yy| 亚洲天堂2014| 国产精品性做久久久久久| 欧美乱妇15p| 亚洲一区二区视频| 成人av网在线| 欧美精品一区二区三区一线天视频| 亚洲精品亚洲人成人网在线播放| 韩国视频一区二区| 欧美女孩性生活视频| 亚洲欧洲综合另类| 粉嫩久久99精品久久久久久夜| 欧美一区日韩一区| 午夜在线成人av| 91啪亚洲精品| 国产精品久久久久久久久免费丝袜| 国内精品伊人久久久久影院对白| 欧美日韩不卡视频| 一区二区三区国产| 91蜜桃网址入口| 中文字幕一区二区三区不卡| 国产精品乡下勾搭老头1| 久久综合色8888| 精品一二三四在线| 精品少妇一区二区三区视频免付费| 日日摸夜夜添夜夜添国产精品| 色哟哟在线观看一区二区三区| 国产欧美日韩亚州综合| 黑人精品欧美一区二区蜜桃 | 麻豆精品在线观看| 欧美狂野另类xxxxoooo| 午夜精品视频在线观看| 欧美精品一区二区三区视频| 奇米精品一区二区三区在线观看| 欧美日韩国产美| 884aa四虎影成人精品一区| 国产另类ts人妖一区二区| 免费高清视频精品| 丁香五精品蜜臀久久久久99网站| 欧美日韩在线亚洲一区蜜芽| 亚洲综合一区在线| 欧美另类videos死尸| 麻豆91免费看| 精品久久久久久久久久久久久久久 | 国产尤物一区二区| 国产亚洲精品精华液| jvid福利写真一区二区三区| 一区视频在线播放| 91香蕉视频污在线| 亚洲国产精品久久久久婷婷884| 欧美日韩高清一区| 卡一卡二国产精品| 久久久精品免费免费| 99久久精品免费看国产| 亚洲一级二级三级在线免费观看| 91精品国产91久久久久久最新毛片| 久久99久国产精品黄毛片色诱| 久久久久久**毛片大全| 91热门视频在线观看| 性欧美大战久久久久久久久| 欧美成人三级在线| 99精品视频一区二区三区| 亚洲一区在线视频| 久久亚洲精精品中文字幕早川悠里| 成人激情开心网| 日韩电影在线免费看|