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

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

?? mylib.cpp

?? 一個modbus的編程庫
?? CPP
字號:
// mylib.cpp

#include "stdafx.h"

// ------------------------ CalcCRC (Local Generic) --------------------------------------
// PURPOSE: Calculates a CRC value.
// It is the responsibility of the caller of this routine to make sure
// that crc = 0xFFFF if a crc has to be calculated for a new buffer.
//
LONG CalcCRC( BYTE * crcStartPtr,   //  ->
              DWORD  buffLen,       //  ->
              WORD * crc            // <->
             )
{
BYTE * bufferTop = crcStartPtr + buffLen;
BYTE * crcBuffPtr = crcStartPtr;       // Get our own private copy of ptr
WORD  i;

   while(crcBuffPtr < bufferTop)
   {
      *crc = (WORD)(*crc & 0xff00) + (*(BYTE *)crcBuffPtr ^ LOBYTE(*crc));
      for(i=0 ; i<8 ; i++)
      {
         if( (*crc & 0x0001) == TRUE )
            *crc = (*crc >> 1) ^ 0xA001;
         else
            *crc = (*crc >> 1);
      }
      crcBuffPtr++;
   }
   return(SUCCESS);
} // CalcCRC


// ------------------------ CalcLRC (Local Generic) --------------------------------------
// PURPOSE: Calculates a CRC value.
// It is the responsibility of the caller of this routine to make sure
// that crc = 0xFFFF if a crc has to be calculated for a new buffer.
//
LONG CalcLRC(BYTE * lrcBuffPtr,    //  -> pointer to buffer at start of LRC
             DWORD  buffLen,       //  ->
             BOOL   calc2Comp,     //  -> Calculate 2's Complement also (last call)
             BYTE * lrc            // <->
            )
{
   // Allows us to keep calling CalcLRC for each part of the message
   // and only do 2's compliment when buffLen == 0
   // Add all bytes in buffer
   while(buffLen--)
   {
      *lrc += *lrcBuffPtr++;
   }
   if(calc2Comp)
      *lrc = ~(*lrc) + 1;  // 2's compliment
   return(SUCCESS);
} // CalcLRC


// --------------------------- EnumerateSerialPorts -----------------------------
// PURPOSE: Retrieve hardware configuration from registry instead of letting
//          the user guess what ports he has available.
//
LONG EnumerateSerialPorts (char *deviceName, DWORD maxLen, DWORD index)
{
CHAR     RegPath[MAX_PATH]  = "HARDWARE\\DEVICEMAP\\SERIALCOMM";
HKEY     hKey;
HKEY     hKeyRoot = HKEY_LOCAL_MACHINE;
DWORD    retCode;
CHAR     ClassName[MAX_PATH] = ""; // Buffer for class name.
DWORD    dwcClassLen = MAX_PATH;   // Length of class string.
DWORD    dwcSubKeys;               // Number of sub keys.
DWORD    dwcMaxSubKey;             // Longest sub key size.
DWORD    dwcMaxClass;              // Longest class string.
DWORD    dwcValues;                // Number of values for this key.
CHAR     valueName[MAX_VALUE_NAME] ;
DWORD    dwcValueName = MAX_VALUE_NAME;
DWORD    dwcMaxValueName;          // Longest Value name.
DWORD    dwcMaxValueData;          // Longest Value data.
DWORD    dwcSecDesc;               // Security descriptor.
FILETIME ftLastWriteTime;          // Last write time.
DWORD    dwType;
DWORD    retValue;
DWORD    cbData;


   // Use RegOpenKeyEx() with the new Registry path to get an open handle
   // to the child key you want to enumerate.
   retCode = RegOpenKeyEx (hKeyRoot,
                           RegPath,
                           0,
                           KEY_ENUMERATE_SUB_KEYS |
                           KEY_EXECUTE |
                           KEY_QUERY_VALUE,
                           &hKey);

   if (retCode != ERROR_SUCCESS)
      return(FAILED);


   // Get Class name, Value count.
   RegQueryInfoKey ( hKey,              // Key handle.
                     ClassName,         // Buffer for class name.
                     &dwcClassLen,      // Length of class string.
                     NULL,              // Reserved.
                     &dwcSubKeys,       // Number of sub keys.
                     &dwcMaxSubKey,     // Longest sub key size.
                     &dwcMaxClass,      // Longest class string.
                     &dwcValues,        // Number of values for this key.
                     &dwcMaxValueName,  // Longest Value name.
                     &dwcMaxValueData,  // Longest Value data.
                     &dwcSecDesc,       // Security descriptor.
                     &ftLastWriteTime); // Last write time.

   // Enumerate the Key Values
   cbData = maxLen ;
   dwcValueName = MAX_VALUE_NAME;
   valueName[0] = '\0';

   retValue = RegEnumValue (hKey, index, valueName,
                            &dwcValueName,
                            NULL,
                            &dwType,
                            (BYTE *)&deviceName[0],
                            &cbData);

   RegCloseKey (hKey);   // Close the key handle.
   if(dwType == REG_SZ && retValue == (DWORD)ERROR_SUCCESS)
      return(SUCCESS);
   else
      return(FAILED);
} // EnumerateSerialports



// ------------------------------ FillCharCBox ----------------------
void FillCharCBox(CComboBox * cBox, DWORD * table, char ** strTable,
                  WORD tableLen, DWORD currentsetting)
{
DWORD count;
CHAR ** strTablePtr = strTable;

   ASSERT(cBox->m_hWnd!=0);
   cBox->ResetContent();
   for (count = 0; count < tableLen; count++)
   {
      cBox->AddString(strTablePtr[count]);
      cBox->SetItemData(count,  *(table + count));
      if (*(table + count) == currentsetting)
         cBox->SetCurSel(count);
   }
} // FillCharCBox

// ----------------------------- FillSerialCBox -----------------------------
// the list box contains the strings that describe each serial comm port available
// the port names themselves are retrieved when destroying the combo box
void FillSerialCBox(CComboBox * cBox, LPCTSTR currentselection)
{
DWORD count;
LONG retCode;
CHAR portname[MAX_PORT_NAME];

   ASSERT(cBox->m_hWnd!=0);
   cBox->ResetContent();
   count = 0;
   while (TRUE)
   {
      retCode = EnumerateSerialPorts(portname, sizeof(portname), count);
      if( retCode != SUCCESS)
         break;
      cBox->AddString(portname);
      cBox->SetItemData(count, count);
      if (strcmp(portname,currentselection)==0)
         cBox->SetCurSel(count);
      count++;
   }
} // FillSerialCBox

// ----------------------------------- FixComPortName -----------------------
// fix com port names for port names above com9
// IN/OUT:  portName - user displayable name
//
// RETURN:  portName - is modified on return.
// NOTES: This function will accept a port name in the format "\\.\COMnn"
// without lengthening it in-correctly.
CHAR * FixComPortName(CHAR *portName)
{
CHAR tempPortName[MAX_PORT_NAME];

   if (strlen(portName) > strlen("COM1"))
   {
      if (0==strncmp(portName, "COM",3))
      {
         sprintf(tempPortName, "\\\\.\\%s", portName);
         strcpy(portName, tempPortName);
      }
   }
   return (portName);
} // FixComPortName


// ----------------------------------- GetLongComPortName --------------------
// return a port name that caters for com 10 and above
// IN     : portName - port name e.g. "COM10"
// IN/OUT : newName - port name "\\.\COM10"
// RETURNS: newName -
CHAR * GetLongComPortName(LPCTSTR portName, LPSTR newName)
{
   strcpy(newName,portName);
   return (FixComPortName(newName));
} // GetLongComPortName


// ---------------------------- PortInUse ------------------------------
// Returns whether the RS-232 port can currently be opened.
// It tests this by opening and closing the port.
BOOL PortInUse(LPCTSTR portName)
{
//CHAR * GetLongComPortName(LPCTSTR portName, LPSTR newName);
CHAR port[MAX_PORT_NAME];
HANDLE   hPort;

   GetLongComPortName(portName, port);
   hPort =  CreateFile( port,                    // PIP 1823-400-1997
                        GENERIC_READ | GENERIC_WRITE,
                        (DWORD)NULL,   // exclusive access
                        NULL,          // no security
                        OPEN_EXISTING,
                        FILE_ATTRIBUTE_NORMAL,
                        NULL           // hTemplate
                      );
   if (INVALID_HANDLE_VALUE != hPort)
   {
      CloseHandle(hPort);
      return (FALSE);
   }
   return (TRUE);
} // PortInUse

// --------------------------- FillSerialCBoxUsedResources ------------------
// Calls the function FillSerialCBox(), and then puts a '*' next to all used
// ports.
void FillSerialCBoxUsedResources(CComboBox * cBox, LPCTSTR currentselection)
{
DWORD index, count;
LONG selection;
CString selectionText;
   FillSerialCBox(cBox, currentselection);
   count = cBox->GetCount();
   selection = cBox->GetCurSel();
   index = 0;
   while (index < count)
   {
      cBox->GetLBText(index, selectionText);
      if (PortInUse(selectionText))
      {
         cBox->DeleteString(index);
         selectionText = selectionText + PORT_INUSESTR;  // " *"
         cBox->InsertString(index, selectionText);
         cBox->SetItemData(index, index);
      }
      index++;
   }
   cBox->SetCurSel(selection);
} // FillSerialCBoxUsedResources

// ---------------------------- ClearPortUseMark -------------------------
// Removes the '*' mark from a port name if present.
// Use this function to tread the LB contents if U used FillSerialCBoxUsedResources()
void ClearPortUseMark(LPSTR name)
{
   if (strtok(name, PORT_INUSESTR))
   {  // empty statement, since strtok modifies the string.
   }
} // ClearPortUseMark



// pip 1512-400-1997 added
// ------------------------ Round -----------------------------------------
// PURPOSE : Rounds a precision floating point value, to allow casting to an
// integer value. This is because the Casting of 2.9999999999999999999999999
// actually gives us 2, not 3 like expected.
double Round(double val)
{
   double r = fmod(val,1);
   if (r>=0.5)
      return ceil(val);
   return floor(val);
} // Round
// pip 1512-400-1997 added


// ---------------- SwopBytes (Global Generic) -----------------------------
// PURPOSE : Converts WORD from large indian to little indian
// (and back if called again)
LONG SwopBytes(WORD * x)
{
WORD loByte;
WORD hiByte;

  loByte = LOBYTE(*x);
  hiByte = HIBYTE(*x);
  *x = (WORD)((loByte<<8) + hiByte);
  return(SUCCESS);
} // SwopBytes


// --------------- SwopWords (Global Generic) --------------------------------
// PURPOSE : Converts DWORD from large endian to small endian
// (and back if called again)
LONG SwopWords(DWORD * x)
{
DWORD loWord;
DWORD hiWord;

  loWord = LOWORD(*x);
  hiWord = HIWORD(*x);
  *x = (loWord<<16) + hiWord ;
  return(SUCCESS);
} // SwopWords


// ----------------- SwopDWords (Global Generic) --------------------------------
// PURPOSE : Converts DWORD from large endian to small endian
// (and back if called again)
LONG SwopDWords(DWORD * x)
{
DWORD loWordLoByte;     // Byte 0
DWORD loWordHiByte;     // Byte 1
DWORD hiWordLoByte;     // Byte 2
DWORD hiWordHiByte;     // Byte 3

   loWordLoByte = LOBYTE(LOWORD(*x));   // Byte 0
   loWordHiByte = HIBYTE(LOWORD(*x));   // Byte 1
   hiWordLoByte = LOBYTE(HIWORD(*x));   // Byte 2
   hiWordHiByte = HIBYTE(HIWORD(*x));   // Byte 3
   //   byte 0                byte 1             byte 2            byte 3
   *x = (loWordLoByte<<24) | (loWordHiByte<<16) | (hiWordLoByte<<8) | (hiWordHiByte);
   //   byte 3                byte 2             byte 1            byte 0
   *x = (hiWordLoByte<<24) | (hiWordHiByte<<16) | (loWordLoByte<<8) | (loWordHiByte);
   return(SUCCESS);
} // SwopDWords


// ------------------ BCDtoLONG (Global Generic) --------------------------------
// PURPOSE : Converts BCD (1 to 8 digit) to LONG
// Support a max of 8 digits BCD
LONG BCDtoLONG( DWORD bcdValue,
                DWORD bcdDigits,
                PLONG longValue
              )
{
DWORD multiplier = 1;
DWORD i;
   *longValue = 0;

   if(bcdDigits > 8)
      return(FAILED);
   for(i=0 ; i < bcdDigits ; i++)
   {
      if( (bcdValue & 0x0000000F) > 9 )
         return(FAILED);
      *longValue  += (bcdValue & 0x0000000F) * multiplier;
      bcdValue = bcdValue >> 4;
      multiplier = multiplier * 10;
   }
   return(SUCCESS);
} // BCDtoLONG


// ------------------- LONGtoBCD (Global Generic) ----------------------
// PURPOSE : Converts LONG to BCD (1 to 8 digit)
// Support a max of 8 digits BCD
LONG LONGtoBCD( LONG   longValue,
                DWORD  bcdDigits,
                DWORD *bcdValue
              )
{
DWORD i;
CHAR  longValueStr[9];
PCHAR strPtr = longValueStr;

   if(bcdDigits > 8)
      return(FAILED);

   *bcdValue = 0;
   sprintf(strPtr, "%08ld", longValue);

   for(i=8 ; i > (8-bcdDigits) ; i--)
   {
      *bcdValue += (* (strPtr + i - 1) - 48) << ((8-i) * 4);
   }
   return(SUCCESS);
} // LONGtoBCD


// --------------------------- FillDWordCBox --------------------------
void FillDWordCBox(CComboBox * cBox, DWORD * table, WORD tableLen,
                   DWORD currentsetting)
{
DWORD count;
CHAR temp[256];

   ASSERT(cBox->m_hWnd!=0);
   cBox->ResetContent();
   for (count = 0; count < tableLen; count++)
   {
      sprintf(temp,"%ld",(DWORD *)table[count]);
      cBox->AddString(temp);  //strTablePtr[count]);
      cBox->SetItemData(count,  *(table + count));
      if (*(table + count) == currentsetting)
         cBox->SetCurSel(count);
   }
} // FillDWordCBox

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品久久久久久久91蜜桃| 色综合久久久久综合体桃花网| 国产精品美女久久久久久2018| 欧美美女激情18p| 日本二三区不卡| 精品视频在线免费| 99久久精品免费| 成人精品免费网站| 99视频精品全部免费在线| 成人国产精品免费观看视频| 粉嫩av一区二区三区| 国产福利91精品| 从欧美一区二区三区| hitomi一区二区三区精品| www.日韩大片| 在线亚洲高清视频| 欧美高清一级片在线| 日韩欧美精品三级| 久久久久久久久蜜桃| 中文字幕一区二区三| 亚洲激情校园春色| 午夜一区二区三区在线观看| 日韩电影在线一区| 美女视频免费一区| 国产成人免费在线| 色综合中文字幕国产| 91女厕偷拍女厕偷拍高清| 在线精品视频免费播放| 91麻豆精品国产91久久久使用方法 | ...av二区三区久久精品| 亚洲色图.com| 奇米影视在线99精品| 国产成人午夜99999| 色综合天天综合网天天狠天天| 欧美猛男超大videosgay| 精品福利一区二区三区免费视频| 亚洲国产精品99久久久久久久久| 一区二区三区欧美久久| 久久精品噜噜噜成人88aⅴ| 色狠狠一区二区| 在线播放欧美女士性生活| 久久综合色播五月| 亚洲视频一区在线观看| 蜜臀av性久久久久av蜜臀妖精| 高清不卡在线观看| 91精品国产色综合久久| 亚洲欧美综合另类在线卡通| 日韩电影在线一区二区| 91在线你懂得| ww亚洲ww在线观看国产| 五月婷婷久久丁香| 99精品久久久久久| 精品不卡在线视频| 午夜精品福利久久久| 成人美女视频在线看| 欧美成人r级一区二区三区| 亚洲欧美激情视频在线观看一区二区三区| 奇米影视一区二区三区| 日本二三区不卡| 国产精品美女久久久久久| 精品综合免费视频观看| 欧美精品视频www在线观看| 中文字幕亚洲一区二区va在线| 久久精品国产久精国产爱| 91福利国产精品| 1024成人网色www| 国产成都精品91一区二区三| 欧美一区二区三区思思人| 亚洲午夜一二三区视频| 一本色道**综合亚洲精品蜜桃冫| 国产日韩欧美精品综合| 精品伊人久久久久7777人| 欧美一区二区女人| 日韩专区一卡二卡| 欧美精品久久天天躁| 亚洲成av人片一区二区三区| 91激情在线视频| 亚洲激情五月婷婷| 在线免费观看视频一区| 亚洲美女视频一区| 欧美一区二区视频网站| 亚洲va国产天堂va久久en| 欧美午夜一区二区三区免费大片| 自拍偷自拍亚洲精品播放| 91在线小视频| 一区二区三区日本| 欧美片网站yy| 蜜臀91精品一区二区三区| 精品处破学生在线二十三| 国产在线国偷精品产拍免费yy| 久久色中文字幕| 成人小视频在线观看| 亚洲色图在线看| 欧美日韩在线播放| 日本一不卡视频| 精品国产电影一区二区| 国产成人在线视频免费播放| 中文字幕一区二区三区视频| 91小视频在线免费看| 性久久久久久久| 精品福利一二区| 99久久久无码国产精品| 亚洲地区一二三色| 精品入口麻豆88视频| 成人深夜福利app| 亚洲第一二三四区| 26uuu国产电影一区二区| av资源网一区| 日韩成人免费电影| 久久久久久一二三区| 91年精品国产| 免费成人av资源网| 国产精品卡一卡二| 91精品国产综合久久精品| 国产凹凸在线观看一区二区| 亚洲欧美日韩国产综合在线| 欧美精品国产精品| 福利91精品一区二区三区| 天天av天天翘天天综合网色鬼国产| 久久综合九色综合欧美亚洲| 色国产综合视频| 韩国av一区二区| 亚洲成人av资源| 国产免费久久精品| 欧美一区二区私人影院日本| av一本久道久久综合久久鬼色| 日韩av不卡在线观看| 日韩毛片视频在线看| 久久婷婷综合激情| 制服丝袜亚洲播放| 一本高清dvd不卡在线观看| 国产综合久久久久久久久久久久| 夜夜爽夜夜爽精品视频| 欧美激情一区二区三区全黄| 日韩免费高清电影| 欧美四级电影网| av高清不卡在线| 国产乱人伦偷精品视频不卡| 天堂蜜桃一区二区三区 | 欧美系列在线观看| av一区二区三区在线| 狠狠色丁香久久婷婷综| 亚洲成人动漫精品| 亚洲自拍偷拍九九九| 中文字幕人成不卡一区| 国产拍欧美日韩视频二区| 精品国产一区久久| 4438x成人网最大色成网站| 欧美亚洲丝袜传媒另类| 日本韩国欧美一区| 一本大道久久a久久综合| 97精品超碰一区二区三区| 高清不卡一区二区在线| 国产激情一区二区三区四区 | 亚洲欧美日韩一区二区| 国产精品理伦片| 亚洲欧洲日本在线| 中文字幕一区二区三| 亚洲日本一区二区三区| 国产精品久久久久影院| 国产精品久久久久久久久快鸭 | 成人毛片老司机大片| 国产宾馆实践打屁股91| 成人午夜视频在线观看| www.激情成人| 91官网在线观看| 欧美日韩国产综合视频在线观看| 欧美日韩国产精选| 欧美一区二区女人| 久久久久综合网| 亚洲欧美在线另类| 亚洲一区二区三区在线看| 日韩黄色片在线观看| 久久国产综合精品| 成人短视频下载| 日本韩国精品一区二区在线观看| 欧美人牲a欧美精品| 日韩欧美123| 国产精品私房写真福利视频| 亚洲激情欧美激情| 日韩—二三区免费观看av| 国产盗摄精品一区二区三区在线| 99精品欧美一区二区三区小说| 色老头久久综合| 欧美tickle裸体挠脚心vk| 国产精品青草久久| 婷婷丁香久久五月婷婷| 狠狠色丁香久久婷婷综合丁香| 99久久精品免费看国产免费软件| 欧美在线免费视屏| 2021国产精品久久精品| 综合中文字幕亚洲| 麻豆精品视频在线| 91啪亚洲精品| 欧美精品一区视频| 一区二区三区成人在线视频| 国产乱一区二区| 欧美群妇大交群中文字幕| 欧美激情中文字幕一区二区| 天堂久久一区二区三区|