2019-05-11 11:17:56 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calculate CCITT-CRC16 checksum
|
|
|
|
*/
|
2023-06-27 19:39:11 +12:00
|
|
|
|
|
|
|
use Carbon\Carbon;
|
|
|
|
use Illuminate\Support\Collection;
|
|
|
|
|
2019-05-11 11:17:56 +10:00
|
|
|
if (! function_exists('crc16')) {
|
2023-06-27 19:39:11 +12:00
|
|
|
function crc16($data): int
|
|
|
|
{
|
|
|
|
$crc = 0x0000;
|
2023-11-18 16:57:30 +11:00
|
|
|
|
2023-06-27 19:39:11 +12:00
|
|
|
for ($i = 0; $i < strlen($data); $i++) {
|
|
|
|
$x = (($crc >> 8) ^ ord($data[$i])) & 0xFF;
|
|
|
|
$x ^= $x >> 4;
|
|
|
|
$crc = (($crc << 8) ^ ($x << 12) ^ ($x << 5) ^ $x) & 0xFFFF;
|
|
|
|
}
|
2023-11-18 16:57:30 +11:00
|
|
|
|
2023-06-27 19:39:11 +12:00
|
|
|
return $crc;
|
|
|
|
}
|
2019-05-11 11:17:56 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Dump out data into a hex dump
|
|
|
|
*/
|
|
|
|
if (! function_exists('hex_dump')) {
|
2022-02-13 10:24:31 +11:00
|
|
|
function hex_dump($data,$newline="\n",$width=16): string
|
2019-05-11 11:17:56 +10:00
|
|
|
{
|
|
|
|
$result = '';
|
|
|
|
|
|
|
|
$pad = '.'; # padding for non-visible characters
|
|
|
|
$to = $from = '';
|
|
|
|
|
2022-02-13 10:24:31 +11:00
|
|
|
for ($i=0; $i<=0xFF; $i++) {
|
2019-05-11 11:17:56 +10:00
|
|
|
$from .= chr($i);
|
|
|
|
$to .= ($i >= 0x20 && $i <= 0x7E) ? chr($i) : $pad;
|
|
|
|
}
|
|
|
|
|
|
|
|
$hex = str_split(bin2hex($data),$width*2);
|
|
|
|
$chars = str_split(strtr($data,$from,$to),$width);
|
|
|
|
|
|
|
|
$offset = 0;
|
2022-02-13 10:24:31 +11:00
|
|
|
foreach ($hex as $i => $line) {
|
2019-05-11 11:17:56 +10:00
|
|
|
$result .= sprintf('%08X: %-48s [%s]%s',
|
|
|
|
$offset,
|
|
|
|
substr_replace(implode(' ',str_split($line,2)),' ',8*3,0),
|
|
|
|
$chars[$i],
|
|
|
|
$newline);
|
|
|
|
|
|
|
|
$offset += $width;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
2019-05-20 17:18:18 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-07-21 20:52:17 +10:00
|
|
|
* Send a value has hex chars
|
2019-05-20 17:18:18 +10:00
|
|
|
*/
|
2021-07-21 20:52:17 +10:00
|
|
|
if (! function_exists('hexstr')) {
|
2022-02-13 10:24:31 +11:00
|
|
|
function hexstr(int $int): string
|
2019-05-20 17:18:18 +10:00
|
|
|
{
|
2021-07-21 20:52:17 +10:00
|
|
|
if ($int > 0xffff)
|
|
|
|
throw new Exception('Int too large for hexstr');
|
2019-05-20 17:18:18 +10:00
|
|
|
|
2021-07-21 20:52:17 +10:00
|
|
|
$hexdigitslower = '0123456789abcdef';
|
|
|
|
$x = '';
|
2019-05-20 17:18:18 +10:00
|
|
|
|
2021-07-21 20:52:17 +10:00
|
|
|
if ($int > 0xff) {
|
|
|
|
$x .= substr($hexdigitslower,($int&0xf000)>>12,1);
|
|
|
|
$x .= substr($hexdigitslower,($int&0x0f00)>>8,1);
|
|
|
|
}
|
2019-05-20 17:18:18 +10:00
|
|
|
|
2021-07-21 20:52:17 +10:00
|
|
|
$x .= substr($hexdigitslower,($int&0x00f0)>>4,1);
|
|
|
|
$x .= substr($hexdigitslower,($int&0x000f),1);
|
2019-05-20 17:18:18 +10:00
|
|
|
|
2021-07-21 20:52:17 +10:00
|
|
|
return $x;
|
2019-05-20 17:18:18 +10:00
|
|
|
}
|
2021-07-24 00:53:35 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
if (! function_exists('timew')) {
|
|
|
|
/**
|
|
|
|
* Convert a time into an 32 bit value. This is primarily used to create 8 character hex filenames that
|
|
|
|
* are unique using 1/10th second precision.
|
|
|
|
*
|
|
|
|
* Time is:
|
|
|
|
* + 02 bits unused
|
|
|
|
* + 04 bits Month
|
|
|
|
* + 05 bits Day
|
|
|
|
* + 05 bits Hour
|
|
|
|
* + 06 bits Min
|
|
|
|
* + 06 bits Sec
|
|
|
|
* + 04 bits 10th Sec
|
|
|
|
* = 32 (2 bits free)
|
|
|
|
*
|
2023-06-27 19:39:11 +12:00
|
|
|
* @param Carbon|null $time
|
2021-07-24 00:53:35 +10:00
|
|
|
* @return int
|
|
|
|
*/
|
2023-06-27 19:39:11 +12:00
|
|
|
function timew(Carbon $time=NULL): int
|
2021-07-24 00:53:35 +10:00
|
|
|
{
|
|
|
|
static $delay = 0;
|
|
|
|
|
|
|
|
// If we are not passed a time, we'll use the time now
|
|
|
|
if (! $time) {
|
|
|
|
// In case we are called twice, we'll delay 1/10th second so we have a unique result.
|
2023-06-27 19:39:11 +12:00
|
|
|
if (Carbon::now()->getPreciseTimestamp(1) === $delay)
|
2021-07-24 00:53:35 +10:00
|
|
|
usleep(100000);
|
|
|
|
|
2023-06-27 19:39:11 +12:00
|
|
|
$time = Carbon::now();
|
2021-07-24 00:53:35 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
$delay = $time->getPreciseTimestamp(1);
|
|
|
|
|
|
|
|
$t = ($time->month & 0xf) << 5;
|
|
|
|
$t = ($t | ($time->day & 0x1f)) << 5;
|
|
|
|
$t = ($t | ($time->hour & 0x1f)) << 6;
|
|
|
|
$t = ($t | ($time->minute & 0x3f)) << 6;
|
|
|
|
$t = ($t | ($time->second & 0x3f));
|
|
|
|
|
|
|
|
return hexdec(sprintf('%07x%1x',$t,(round($time->milli/100) & 0x7f)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-11-18 16:57:30 +11:00
|
|
|
if (! function_exists('wtime')) {
|
2021-07-24 00:53:35 +10:00
|
|
|
/**
|
|
|
|
* Convert a 40 bit integer into a time.
|
|
|
|
* @see timew()
|
|
|
|
*
|
|
|
|
* @param int $time
|
|
|
|
* @param int|null $year
|
2023-06-27 19:39:11 +12:00
|
|
|
* @return Carbon
|
2021-07-24 00:53:35 +10:00
|
|
|
*/
|
2023-06-27 19:39:11 +12:00
|
|
|
function wtime(int $time,int $year=NULL): Carbon
|
2021-07-24 00:53:35 +10:00
|
|
|
{
|
|
|
|
if (! $year)
|
2023-06-27 19:39:11 +12:00
|
|
|
$year = Carbon::now()->year;
|
2021-07-24 00:53:35 +10:00
|
|
|
|
|
|
|
// Does the time have milli seconds?
|
|
|
|
if ($time > pow(2,26)-1) {
|
|
|
|
$milli = ($time & 0xf);
|
|
|
|
$time = $time >> 4;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
$milli = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sec = ($time & 0x3f);
|
|
|
|
$time = $time >> 6;
|
|
|
|
|
|
|
|
$min = ($time & 0x3f);
|
|
|
|
$time = $time >> 6;
|
|
|
|
|
|
|
|
$hr = ($time & 0x1f);
|
|
|
|
$time = $time >> 5;
|
|
|
|
|
|
|
|
$day = ($time & 0x1f);
|
|
|
|
$time = $time >> 5;
|
|
|
|
|
|
|
|
$month = ($time & 0x1f);
|
|
|
|
|
2023-06-27 19:39:11 +12:00
|
|
|
return Carbon::create($year,$month,$day,$hr,$min,$sec+$milli/10);
|
2021-07-24 00:53:35 +10:00
|
|
|
}
|
2019-05-11 11:17:56 +10:00
|
|
|
}
|