Code generation for controller classes using the UriPattern
system from
hhvm/hack-router
This currently supports generating:
- Request routing maps
- Hack request routing classes for your site
For now, looking at the unit tests is the best way to learn how to use it.
<?hh
use \Facebook\HackRouter\Codegen;
final class UpdateCodegen {
public function main(): void {
Codegen::forTree(
__DIR__.'/../src/',
shape(
'controllerBase' => WebController::class,
'router' => shape(
'abstract' => false,
'file' => __DIR__.'/../codegen/Router.php',
'class' => 'Router',
),
),
)->build;
}
}
This will generate a class called 'Router', complete with an automatically-generated route map, based on the URI patterns in your controllers.
WebController
is the root controller for your site, and must implement
Facebook\HackRouter\IncludeInUriMap
, which in turn requires
Facebook\HackRouter\HasUriPattern
- for example:
public static function getUriPattern(): UriPattern {
return (new UriPattern())
->literal('/')
->string('MyString')
->literal('/')
->int('MyInt')
->literal('/')
->enum(MyEnum::class, 'MyEnum');
}
This is unusual advice, but it's the best approach for Hack code as you otherwise have a circular dependency:
- HHVM will not execute hack code if there are references to undefined classes
- Once you use the codegen, you reference the codegen classes
- ... so you can't build them if you don't already have them
We welcome GitHub issues and pull requests - please see CONTRIBUTING.md for details.
hack-router-codegen is MIT-licensed.