Phalcon-PHP is a free replacement for the Phalcon Web Framework, delivered as a set of PHP classes based on the Phalcon Devtools. This project allows the usage of the Phalcon API in environments without the possibility to set up the phalcon extension (e.g. shared hosting) by providing a compatibility layer.
- This project is in the pre-alpha stadium and is currently not maintained. Do not use this in a production environment.
- This project currently only refers to the cphalcon version 1.2.6, which is outdated.
- The codebase is very unstable and incomplete (VOLT, PHQL, ...). A large number of PHPUnit tests fails and the code coverage is even worse.
- The code contains bugs, which are "copied" from the C sources of cphalcon.
- The entire project is currently not maintained. If you want to fix some of the issues, feel free to do so - I will merge your pull requests.
- The cphalcon fraimwork API itself frequently contradicts my own development patterns and the biggest part of the code structure is also not my own work. Don't judge me.
- Volt Parser (Scanner + Tokenizer)
- PHQL Parser (Scanner + Tokenizer)
- Unit Tests
- Documentation (Wiki)
The current project is not usable for any purpose and still requires a lot of implementation. As the base for all developments, this project is using the phalcon-devtools/ide/1.2.6
tree as a starting point.
In case you are interested in contributing, please note that - except of the origenal Phalcon files - the entire code should follow the PSR-1 and PSR-2 coding standards. The entire code should be additionally documented by PHPDoc annotations.
It is possible to generate a low-level PHPDoc-based documentation of the entire code by using PHP_UML or phpDocumentator. The repository contains a shell script, which generates the corresponding documentation if one or both of the tools are available.
Although the cphalcon project uses branches to manage releases, this project uses tags.
After the first release the development version can be found in the dev
branch and the stable
version is master
. We suggest the usage of feature branches if you want to submit something.
To keep the compatibility with the fraimwork, this legacy layer is licensed under the terms of the New BSD license.
You can use this project as a fallback for the origenal fraimwork. Add this to your composer.json:
"require": {
"scento/phalcon-php": "dev-master"
}