hoa/core
最新稳定版本:2.15.11.09
Composer 安装命令:
composer require hoa/core
包简介
The Hoa\Core library.
README 文档
README
Hoa is a modular, extensible and structured set of PHP libraries. Moreover, Hoa aims at being a bridge between industrial and research worlds.
Hoa\Core 
This library is the foundation —the core— of all libraries of Hoa. It provides fundamental algorithms, paradigms and mechanisms, organized as follows:
- Core: core of the core;
- Consistency: adds consistency to PHP (
from/import,xcallable,dnew,curryetc.); - Exception: homogenises exceptions and errors;
- Protocol: abstracts resources —and more— accesses (e.g.
hoa://Libraryorhoa://Application); - Parameter: manages parameters of libraries;
- Event: adds support of events and listeners;
- Data: adds support of polymorphic data with high performance.
Warning
This library is deprecated. It has been splitted into:
This library is no longer used.
Installation
The core can be placed where you want. We recommand /usr/local/lib/Hoa for
Unix-like systems and C:\Program Files\Hoa for Windows systems.
Then, you have to require Core.php and it is enough to use all libraries of
Hoa; thus:
<?php require '/usr/local/lib/Hoa/Core/Core.php'; var_dump(HOA); // bool(true)
With Composer, you do not need to require
Core.php, only vendor/autoload.php as usual.
Quick usage
We propose a quick overview of some layers of the core.
Exceptions and errors
Errors are unified to exceptions. Exceptions are of 3 kinds: idle, normal and error. They support formatted messages, auto-catch, dedicated event channel etc.
Protocol
hoa:// defines an abstraction for application ressources (with roots Data
and Application) and another abstraction for libraries resources (with root
Library). For example:
$conf = require 'hoa://Data/Etc/Configuration/Foo.php';
We can attach more than resources on this protocol. Example with the
Hoa\Registry
library:
Hoa\Registry\Registry::set('foo', 'bar'); echo resolve('hoa://Library/Registry#foo'); // bar
Events and listeners
Libraries can use events and listeners (which have some similarities). For example, if we attach a function to the channel of exceptions:
event('hoa://Event/Exception')->attach(function ($bucket) { $exception = $bucket->getData(); echo 'Exception: ', $exception->getMessage(), "\n"; }) throw new Hoa\Core\Exception('Hello %s!', 0, 'Gordon'); // Exception: Hello Gordon!
Some libraries define their own channels, such as the Hoa\Stream
library with, for
example, hoa://Event/Stream/<stream-name>:close-before, or
hoa://Event/Log/<channel> etc.
For listeners, we are closer to the emitter:
$websocket = new Hoa\Websocket\Server( new Hoa\Socket\Server('tcp://127.0.0.1:8889') ); $websocket->on('message', $callable); $websocket->run();
Documentation
Different documentations can be found on the website: http://hoa-project.net/.
License
Hoa is under the New BSD License (BSD-3-Clause). Please, see
LICENSE.
统计信息
- 总下载量: 953.61k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 38
- 点击次数: 1
- 依赖项目数: 3
- 推荐数: 0
其他信息
- 授权协议: BSD-3-Clause
- 更新时间: 2012-08-29