flyokai/amp-mate 问题修复 & 功能扩展

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

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

flyokai/amp-mate

最新稳定版本:0.1.0

Composer 安装命令:

composer require flyokai/amp-mate

包简介

AMPHP helpers

README 文档

README

User docs → README.md · Agent quick-ref → CLAUDE.md · Agent deep dive → AGENTS.md

AMPHP filesystem helpers — safe wrappers, async file locking, and a bridge between AMPHP File objects and PHP resource handles.

Features

  • Safe / non-throwing variants of common filesystem operations
  • ampFlock() with exponential-backoff retry, cancellation-aware
  • findAmpFileHandle() — extracts the underlying resource from any AMPHP File driver
  • All functions auto-loaded via Composer

Installation

composer require flyokai/amp-mate

Functions

All live in src/functions/filesystem.php:

Function Returns Notes
findAmpFileHandle(File) resource|false Works with StatusCachingFile, UvFile, EioFile, BlockingFile
ampFlock($handle, int $op, ?Cancellation, float $baseLatency = 0.01, int $maxAttempts = 10) bool (throws TimeoutException on exhaust) Exponential backoff
ampOpenFile(string $path, string $mode) File|false Safe open
ampUnlink($file, bool $safe = true) bool
ampFileExists(string $path) bool isFile && exists
ampDirExists(string $path) bool isDirectory && exists
ampMkdir(string $path, int $mode = 0755, bool $safe = true) bool
ampChmod(string $path, int $mode, bool $safe = true) bool

Quick start

use Amp\File;
use function Flyokai\AmpMate\{ampOpenFile, ampFlock, findAmpFileHandle};

$file = ampOpenFile('/tmp/lock.txt', 'c+');

if ($file === false) {
    throw new RuntimeException('cannot open');
}

$handle = findAmpFileHandle($file);
ampFlock($handle, LOCK_EX);   // suspends with backoff until acquired

$file->write('hello');
flock($handle, LOCK_UN);
$file->close();

The safe pattern

Every operation that can fail accepts a $safe boolean:

  • $safe = true (default) — return false / bool on failure
  • $safe = false — throw the underlying exception
ampMkdir('/tmp/foo', 0755);          // returns false on collision
ampMkdir('/tmp/foo', 0755, false);   // throws on collision

Gotchas

  • ampFlock() uses Amp\delay() between attempts — cooperative, but if flock itself blocks the OS it still blocks.
  • Default $maxAttempts = 10 with exponential backoff can take up to ~10 seconds before throwing.
  • findAmpFileHandle() returns false silently for unsupported driver types.

See also

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-12-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固