Skip to content

Commit ce94ffa

Browse files
authored
Merge pull request #142 from php-school/improve-ui
Improve ui
2 parents dd9cee5 + e89cb1f commit ce94ffa

File tree

82 files changed

+3464
-1279
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

82 files changed

+3464
-1279
lines changed

.travis.yml

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -24,8 +24,7 @@ before_script:
2424

2525
script:
2626
- ./vendor/bin/phpunit --coverage-clover ./build/logs/clover.xml
27-
- ./vendor/bin/phpcs --standard=PSR2 ./src/
28-
- ./vendor/bin/phpcs --standard=PSR2 ./test/
27+
- composer cs
2928

3029
after_script:
3130
- bash <(curl -s https://codecov.io/bash)

app/config.php

Lines changed: 39 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -37,7 +37,23 @@
3737
use PhpSchool\PhpWorkshop\Output\OutputInterface;
3838
use PhpSchool\PhpWorkshop\Output\StdOutput;
3939
use PhpSchool\PhpWorkshop\Patch;
40+
use PhpSchool\PhpWorkshop\Result\Cgi\GenericFailure as CgiGenericFailure;
41+
use PhpSchool\PhpWorkshop\Result\Cgi\RequestFailure as CgiRequestFailure;
42+
use PhpSchool\PhpWorkshop\Result\Cgi\CgiResult;
43+
use PhpSchool\PhpWorkshop\Result\Cli\CliResult;
44+
use PhpSchool\PhpWorkshop\Result\Cli\GenericFailure as CliGenericFailure;
45+
use PhpSchool\PhpWorkshop\Result\Cli\RequestFailure as CliRequestFailure;
46+
use PhpSchool\PhpWorkshop\Result\Failure;
47+
use PhpSchool\PhpWorkshop\Result\FunctionRequirementsFailure;
48+
use PhpSchool\PhpWorkshop\Result\StdOutFailure;
4049
use PhpSchool\PhpWorkshop\ResultAggregator;
50+
use PhpSchool\PhpWorkshop\ResultRenderer\CgiResultRenderer;
51+
use PhpSchool\PhpWorkshop\ResultRenderer\CliResultRenderer;
52+
use PhpSchool\PhpWorkshop\ResultRenderer\FailureRenderer;
53+
use PhpSchool\PhpWorkshop\ResultRenderer\FunctionRequirementsFailureRenderer;
54+
use PhpSchool\PhpWorkshop\ResultRenderer\Cli\RequestFailureRenderer as CliRequestFailureRenderer;
55+
use PhpSchool\PhpWorkshop\ResultRenderer\Cgi\RequestFailureRenderer as CgiRequestFailureRenderer;
56+
use PhpSchool\PhpWorkshop\Utils\RequestRenderer;
4157
use PhpSchool\PSX\Factory as PsxFactory;
4258
use PhpSchool\PhpWorkshop\WorkshopType;
4359
use PhpSchool\PSX\SyntaxHighlighter;
@@ -125,7 +141,7 @@
125141
RunnerManager::class => function (ContainerInterface $c) {
126142
$manager = new RunnerManager;
127143
$manager->addFactory(new CliRunnerFactory($c->get(EventDispatcher::class)));
128-
$manager->addFactory(new CgiRunnerFactory($c->get(EventDispatcher::class)));
144+
$manager->addFactory(new CgiRunnerFactory($c->get(EventDispatcher::class), $c->get(RequestRenderer::class)));
129145
$manager->addFactory(new CustomVerifyingRunnerFactory);
130146
return $manager;
131147
},
@@ -231,6 +247,7 @@
231247
FakerGenerator::class => function () {
232248
return FakerFactory::create();
233249
},
250+
RequestRenderer::class => object(),
234251

235252
TerminalInterface::class => factory([TerminalFactory::class, 'fromSystem']),
236253
'menu' => factory(MenuFactory::class),
@@ -266,7 +283,26 @@
266283
ResetProgress::class => function (ContainerInterface $c) {
267284
return new ResetProgress($c->get(UserStateSerializer::class));
268285
},
269-
ResultRendererFactory::class => object(),
286+
ResultRendererFactory::class => function (ContainerInterface $c) {
287+
$factory = new ResultRendererFactory;
288+
$factory->registerRenderer(FunctionRequirementsFailure::class, FunctionRequirementsFailureRenderer::class);
289+
$factory->registerRenderer(Failure::class, FailureRenderer::class);
290+
$factory->registerRenderer(
291+
CgiResult::class,
292+
CgiResultRenderer::class,
293+
function (CgiResult $result) use ($c) {
294+
return new CgiResultRenderer($result, $c->get(RequestRenderer::class));
295+
}
296+
);
297+
$factory->registerRenderer(CgiGenericFailure::class, FailureRenderer::class);
298+
$factory->registerRenderer(CgiRequestFailure::class, CgiRequestFailureRenderer::class);
299+
300+
$factory->registerRenderer(CliResult::class, CliResultRenderer::class);
301+
$factory->registerRenderer(CliGenericFailure::class, FailureRenderer::class);
302+
$factory->registerRenderer(CliRequestFailure::class, CliRequestFailureRenderer::class);
303+
304+
return $factory;
305+
},
270306
ResultsRenderer::class => function (ContainerInterface $c) {
271307
return new ResultsRenderer(
272308
$c->get('appName'),
@@ -277,6 +313,7 @@
277313
$c->get(ResultRendererFactory::class)
278314
);
279315
},
316+
280317
'coreContributors' => [
281318
'@AydinHassan' => 'Aydin Hassan',
282319
'@mikeymike' => 'Michael Woodward',

composer.json

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -28,13 +28,13 @@
2828
"php-school/cli-menu": "^2.0",
2929
"beberlei/assert": "^2.4",
3030
"psr/http-message": "^1.0",
31-
"zendframework/zend-diactoros": "^1.1.3",
31+
"zendframework/zend-diactoros": "^1.3.6",
3232
"myclabs/php-enum": "^1.4",
3333
"nikic/php-parser": "^2.1"
3434
},
3535
"require-dev": {
3636
"composer/composer": "^1.2",
37-
"phpunit/phpunit": "^5.6",
37+
"phpunit/phpunit": "^5.7.2",
3838
"phpunit/phpunit-mock-objects": "^3.3",
3939
"squizlabs/php_codesniffer": "^2.4"
4040
},
@@ -43,7 +43,8 @@
4343
"PhpSchool\\PhpWorkshop\\": "src"
4444
},
4545
"files": [
46-
"src/Event/functions.php"
46+
"src/Event/functions.php",
47+
"src/functions.php"
4748
]
4849
},
4950
"autoload-dev": {
@@ -58,8 +59,8 @@
5859
},
5960
"scripts" : {
6061
"cs" : [
61-
"phpcs src --standard=PSR2",
62-
"phpcs test --standard=PSR2"
62+
"phpcs src --standard=PSR2 --encoding=UTF-8",
63+
"phpcs test --standard=PSR2 --encoding=UTF-8"
6364
]
6465
}
6566
}

0 commit comments

Comments
 (0)