plook/type-guard 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

plook/type-guard

最新稳定版本:1.0.1

Composer 安装命令:

composer require plook/type-guard

包简介

Library to ensure correctness of types with a readable interface.

README 文档

README

codecov

A PHP library to ensure correctness of types providing a readable interface.

Installation

$ composer require plook/type-guard

Example

use function Plook\TypeGuard\asBool;
use function Plook\TypeGuard\asDateTimeImmutable;
use function Plook\TypeGuard\asFloat;
use function Plook\TypeGuard\asInt;
use function Plook\TypeGuard\asString;
use function Plook\TypeGuard\notNull;

$row = $this->fetchProjectRow(123);

$project = new Project(
     notNull(asInt($row['id'])),
     notNull(asString($row['name'])),
     notNull(asDateTimeImmutable($row['createdAt'])),
     notNull(asBool($row['is_assigned'])),
     asDateTimeImmutable($row['closedAt']),
     asFloat($row['rating']),
);

Provided helper functions

Ensure Types

  • asBool($value) Converts input value to a boolean, but passes null.
  • asFloat($value) Converts input value to a float, but passes null.
  • asInt($value) Converts input value to a int, but passes null.
  • asDateTimeImmutable($value) Converts input value to a DateTimeImmutable object, but passes null.
  • asDateTimeString($value) Converts input value to a date string including the timezone, but passes null.
  • asString($value) Converts input value to a string, but passes null.

Converters

  • blankAsNull($value) Converts input value to null, if it is a blank string ''.
  • falseAsNull($value) Converts input value to null, if it is a boolean false.
  • falsyAsNull($value) Converts input value to null, if it is a falsy value false, '', 0, ...
  • zeroAsNull($value) Converts input value to null, if it is a zero 0 or 0.0.

Assertions

  • notNull($value) Throws an exception if the value is null otherwise it passes the original value.

Configuration

Setting the default target time zone of DateTimeImmutable objects

use Plook\TypeGuard\TypeGuard;

TypeGuard::instance()->timeZone('Australia/Adelaide');
TypeGuard::instance()->timeZone(new DateTimeZone('Australia/Adelaide'));

Setting the default format of date time strings

use Plook\TypeGuard\TypeGuard;

TypeGuard::instance()->dateTimeFormat(DateTimeInterface::ATOM);

统计信息

  • 总下载量: 27.55k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: LGPL-2.1-or-later
  • 更新时间: 2024-02-16