summaryrefslogtreecommitdiff
path: root/vendor/symfony/console/Question/ConfirmationQuestion.php
diff options
context:
space:
mode:
authorpolo <ordipolo@gmx.fr>2024-08-13 23:45:21 +0200
committerpolo <ordipolo@gmx.fr>2024-08-13 23:45:21 +0200
commitbf6655a534a6775d30cafa67bd801276bda1d98d (patch)
treec6381e3f6c81c33eab72508f410b165ba05f7e9c /vendor/symfony/console/Question/ConfirmationQuestion.php
parent94d67a4b51f8e62e7d518cce26a526ae1ec48278 (diff)
downloadAppliGestionPHP-bf6655a534a6775d30cafa67bd801276bda1d98d.zip
VERSION 0.2 doctrine ORM et entités
Diffstat (limited to 'vendor/symfony/console/Question/ConfirmationQuestion.php')
-rw-r--r--vendor/symfony/console/Question/ConfirmationQuestion.php57
1 files changed, 57 insertions, 0 deletions
diff --git a/vendor/symfony/console/Question/ConfirmationQuestion.php b/vendor/symfony/console/Question/ConfirmationQuestion.php
new file mode 100644
index 0000000..951d681
--- /dev/null
+++ b/vendor/symfony/console/Question/ConfirmationQuestion.php
@@ -0,0 +1,57 @@
1<?php
2
3/*
4 * This file is part of the Symfony package.
5 *
6 * (c) Fabien Potencier <fabien@symfony.com>
7 *
8 * For the full copyright and license information, please view the LICENSE
9 * file that was distributed with this source code.
10 */
11
12namespace Symfony\Component\Console\Question;
13
14/**
15 * Represents a yes/no question.
16 *
17 * @author Fabien Potencier <fabien@symfony.com>
18 */
19class ConfirmationQuestion extends Question
20{
21 /**
22 * @param string $question The question to ask to the user
23 * @param bool $default The default answer to return, true or false
24 * @param string $trueAnswerRegex A regex to match the "yes" answer
25 */
26 public function __construct(
27 string $question,
28 bool $default = true,
29 private string $trueAnswerRegex = '/^y/i',
30 ) {
31 parent::__construct($question, $default);
32
33 $this->setNormalizer($this->getDefaultNormalizer());
34 }
35
36 /**
37 * Returns the default answer normalizer.
38 */
39 private function getDefaultNormalizer(): callable
40 {
41 $default = $this->getDefault();
42 $regex = $this->trueAnswerRegex;
43
44 return function ($answer) use ($default, $regex) {
45 if (\is_bool($answer)) {
46 return $answer;
47 }
48
49 $answerIsTrue = (bool) preg_match($regex, $answer);
50 if (false === $default) {
51 return $answer && $answerIsTrue;
52 }
53
54 return '' === $answer || $answerIsTrue;
55 };
56 }
57}