Skip to content

Commit

Permalink
Tests
Browse files Browse the repository at this point in the history
  • Loading branch information
Spomky committed Sep 14, 2021
1 parent 1430e1a commit 5d4fb88
Show file tree
Hide file tree
Showing 10 changed files with 287 additions and 236 deletions.
4 changes: 2 additions & 2 deletions src/Decoder.php
Original file line number Diff line number Diff line change
Expand Up @@ -71,9 +71,9 @@ private function processFinite(Stream $stream, int $mt, int $ai, ?string $val):
{
switch ($mt) {
case 0b000: //0
return UnsignedIntegerObject::createObjectForValue($ai, $val);
return PositiveIntegerObject::createObjectForValue($ai, $val);
case 0b001: //1
return SignedIntegerObject::createObjectForValue($ai, $val);
return NegativeIntegerObject::createObjectForValue($ai, $val);
case 0b010: //2
$length = null === $val ? $ai : Utils::binToInt($val);

Expand Down
123 changes: 123 additions & 0 deletions src/NegativeIntegerObject.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@
<?php

declare(strict_types=1);

/*
* The MIT License (MIT)
*
* Copyright (c) 2018-2020 Spomky-Labs
*
* This software may be modified and distributed under the terms
* of the MIT license. See the LICENSE file for details.
*/

namespace CBOR;

use Brick\Math\BigInteger;
use InvalidArgumentException;

/**
* @final
*/
class NegativeIntegerObject extends AbstractCBORObject
{
private const MAJOR_TYPE = 0b001;

/**
* @var string|null
*/
private $data;

public function __construct(int $additionalInformation, ?string $data)
{
parent::__construct(self::MAJOR_TYPE, $additionalInformation);
$this->data = $data;
}

public function __toString(): string
{
$result = parent::__toString();
if (null !== $this->data) {
$result .= $this->data;
}

return $result;
}

public static function createObjectForValue(int $additionalInformation, ?string $data): self
{
return new self($additionalInformation, $data);
}

public static function create(int $value): self
{
return self::createFromString((string) $value);
}

public static function createFromString(string $value): self
{
$integer = BigInteger::of($value);

return self::createBigInteger($integer);
}

public function getValue(): string
{
return $this->getNormalizedData();
}

public function getNormalizedData(bool $ignoreTags = false): string
{
if (null === $this->data) {
return (string) (-1 - $this->additionalInformation);
}

$result = Utils::binToBigInteger($this->data);
$minusOne = BigInteger::of(-1);

return $minusOne->minus($result)->toBase(10);
}

private static function createBigInteger(BigInteger $integer): self
{
if ($integer->isGreaterThanOrEqualTo(BigInteger::zero())) {
throw new InvalidArgumentException('The value must be a negative integer.');
}

$minusOne = BigInteger::of(-1);
$computed_value = $minusOne->minus($integer);

switch (true) {
case $computed_value->isLessThan(BigInteger::of(24)):
$ai = $computed_value->toInt();
$data = null;
break;
case $computed_value->isLessThan(BigInteger::fromBase('FF', 16)):
$ai = 24;
$data = self::hex2bin(str_pad($computed_value->toBase(16), 2, '0', STR_PAD_LEFT));
break;
case $computed_value->isLessThan(BigInteger::fromBase('FFFF', 16)):
$ai = 25;
$data = self::hex2bin(str_pad($computed_value->toBase(16), 4, '0', STR_PAD_LEFT));
break;
case $computed_value->isLessThan(BigInteger::fromBase('FFFFFFFF', 16)):
$ai = 26;
$data = self::hex2bin(str_pad($computed_value->toBase(16), 8, '0', STR_PAD_LEFT));
break;
default:
throw new InvalidArgumentException('Out of range. Please use NegativeBigIntegerTag tag with ByteStringObject object instead.');
}

return new self($ai, $data);
}

private static function hex2bin(string $data): string
{
$result = hex2bin($data);
if (false === $result) {
throw new InvalidArgumentException('Unable to convert the data');
}

return $result;
}
}
131 changes: 131 additions & 0 deletions src/PositiveIntegerObject.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,131 @@
<?php

declare(strict_types=1);

/*
* The MIT License (MIT)
*
* Copyright (c) 2018-2020 Spomky-Labs
*
* This software may be modified and distributed under the terms
* of the MIT license. See the LICENSE file for details.
*/

namespace CBOR;

use Brick\Math\BigInteger;
use InvalidArgumentException;

/**
* @final
*/
class PositiveIntegerObject extends AbstractCBORObject
{
private const MAJOR_TYPE = 0b000;

/**
* @var string|null
*/
private $data;

public function __construct(int $additionalInformation, ?string $data)
{
parent::__construct(self::MAJOR_TYPE, $additionalInformation);
$this->data = $data;
}

public function __toString(): string
{
$result = parent::__toString();
if (null !== $this->data) {
$result .= $this->data;
}

return $result;
}

public static function createObjectForValue(int $additionalInformation, ?string $data): self
{
return new self($additionalInformation, $data);
}

public static function create(int $value): self
{
return self::createFromString((string) $value);
}

public static function createFromHex(string $value): self
{
$integer = BigInteger::fromBase($value, 16);

return self::createBigInteger($integer);
}

public static function createFromString(string $value): self
{
$integer = BigInteger::of($value);

return self::createBigInteger($integer);
}

public function getMajorType(): int
{
return self::MAJOR_TYPE;
}

public function getValue(): string
{
return $this->getNormalizedData();
}

public function getNormalizedData(bool $ignoreTags = false): string
{
if (null === $this->data) {
return (string) $this->additionalInformation;
}

$integer = BigInteger::fromBase(bin2hex($this->data), 16);

return $integer->toBase(10);
}

private static function createBigInteger(BigInteger $integer): self
{
if ($integer->isLessThan(BigInteger::zero())) {
throw new InvalidArgumentException('The value must be a positive integer.');
}

switch (true) {
case $integer->isLessThan(BigInteger::of(24)):
$ai = $integer->toInt();
$data = null;
break;
case $integer->isLessThan(BigInteger::fromBase('FF', 16)):
$ai = 24;
$data = self::hex2bin(str_pad($integer->toBase(16), 2, '0', STR_PAD_LEFT));
break;
case $integer->isLessThan(BigInteger::fromBase('FFFF', 16)):
$ai = 25;
$data = self::hex2bin(str_pad($integer->toBase(16), 4, '0', STR_PAD_LEFT));
break;
case $integer->isLessThan(BigInteger::fromBase('FFFFFFFF', 16)):
$ai = 26;
$data = self::hex2bin(str_pad($integer->toBase(16), 8, '0', STR_PAD_LEFT));
break;
default:
throw new InvalidArgumentException('Out of range. Please use PositiveBigIntegerTag tag with ByteStringObject object instead.');
}

return new self($ai, $data);
}

private static function hex2bin(string $data): string
{
$result = hex2bin($data);
if (false === $result) {
throw new InvalidArgumentException('Unable to convert the data');
}

return $result;
}
}
104 changes: 4 additions & 100 deletions src/SignedIntegerObject.php
Original file line number Diff line number Diff line change
Expand Up @@ -16,105 +16,9 @@
use Brick\Math\BigInteger;
use InvalidArgumentException;

final class SignedIntegerObject extends AbstractCBORObject
/**
* @deprecated Will be removed in v3.0. Please use NegativeIntegerObject instead
*/
final class SignedIntegerObject extends NegativeIntegerObject
{
private const MAJOR_TYPE = 0b001;

/**
* @var string|null
*/
private $data;

public function __construct(int $additionalInformation, ?string $data)
{
parent::__construct(self::MAJOR_TYPE, $additionalInformation);
$this->data = $data;
}

public function __toString(): string
{
$result = parent::__toString();
if (null !== $this->data) {
$result .= $this->data;
}

return $result;
}

public static function createObjectForValue(int $additionalInformation, ?string $data): self
{
return new self($additionalInformation, $data);
}

public static function create(int $value): self
{
return self::createFromString((string) $value);
}

public static function createFromString(string $value): self
{
$integer = BigInteger::of($value);

return self::createBigInteger($integer);
}

public function getValue(): string
{
return $this->getNormalizedData();
}

public function getNormalizedData(bool $ignoreTags = false): string
{
if (null === $this->data) {
return (string) (-1 - $this->additionalInformation);
}

$result = Utils::binToBigInteger($this->data);
$minusOne = BigInteger::of(-1);

return $minusOne->minus($result)->toBase(10);
}

private static function createBigInteger(BigInteger $integer): self
{
if ($integer->isGreaterThanOrEqualTo(BigInteger::zero())) {
throw new InvalidArgumentException('The value must be a negative integer.');
}

$minusOne = BigInteger::of(-1);
$computed_value = $minusOne->minus($integer);

switch (true) {
case $computed_value->isLessThan(BigInteger::of(24)):
$ai = $computed_value->toInt();
$data = null;
break;
case $computed_value->isLessThan(BigInteger::fromBase('FF', 16)):
$ai = 24;
$data = self::hex2bin(str_pad($computed_value->toBase(16), 2, '0', STR_PAD_LEFT));
break;
case $computed_value->isLessThan(BigInteger::fromBase('FFFF', 16)):
$ai = 25;
$data = self::hex2bin(str_pad($computed_value->toBase(16), 4, '0', STR_PAD_LEFT));
break;
case $computed_value->isLessThan(BigInteger::fromBase('FFFFFFFF', 16)):
$ai = 26;
$data = self::hex2bin(str_pad($computed_value->toBase(16), 8, '0', STR_PAD_LEFT));
break;
default:
throw new InvalidArgumentException('Out of range. Please use NegativeBigIntegerTag tag with ByteStringObject object instead.');
}

return new self($ai, $data);
}

private static function hex2bin(string $data): string
{
$result = hex2bin($data);
if (false === $result) {
throw new InvalidArgumentException('Unable to convert the data');
}

return $result;
}
}
Loading

0 comments on commit 5d4fb88

Please sign in to comment.