* lnsize is the value to convert SET PROCEDURE TO Con_int.prg ADDIVITIVE oConvert = CREATEOBJECT('ConvertInt') lcsize = oConvert.IntegerToString(lnsize) ? oConvert.StringToInteger(lcsize) DEFINE CLASS ConvertInt AS CUSTOM FUNCTION IntegerToString LPARAMETER pnInteger, pnbytes LOCAL lcresult, lnbytes, lnmask,; lninteger, lni, lnchar lcresult = "" IF PCOUNT() = 2 lnbytes = pnbytes ELSE * Default to DWORD lnbytes = 4 ENDIF lninteger = pnInteger lnmask = 255 FOR lni = 1 TO lnbytes lnchar = BITAND(lninteger, lnmask) lcresult = lcresult + CHR(lnchar) lninteger = BITRSHIFT(lninteger, 8) NEXT RETURN lcresult ENDFUNC FUNCTION StringToInteger LPARAMETER pcstring, plsigned LOCAL lnresult, lnlast, lni, llsigned,; lnmsb, lnmax lnresult = 0 lnlast = LEN(pcstring) * Return Signed Integer? IF PCOUNT() = 2 llsigned = plsigned ELSE llsigned = .F. ENDIF FOR lni = 1 TO lnlast lnresult = lnresult + ASC(SUBSTR(pcstring, lni, 1)) * (256 ^ (lni - 1)) NEXT IF llsigned lnmsb = (lnlast * 8) - 1 IF BITTEST(lnresult, lnmsb) lnmax = (2 ^ (lnmsb + 1)) lnresult = lnresult - lnmax ENDIF ENDIF RETURN lnresult ENDFUNC ENDDEFINE