HTMLPurifier/AttrDef/Integer.php Quellcode

Integer.php
gehe zur Dokumentation dieser Datei
1 <?php
2 
11 {
12 
17  protected $negative = true;
18 
23  protected $zero = true;
24 
29  protected $positive = true;
30 
36  public function __construct($negative = true, $zero = true, $positive = true)
37  {
38  $this->negative = $negative;
39  $this->zero = $zero;
40  $this->positive = $positive;
41  }
42 
49  public function validate($integer, $config, $context)
50  {
51  $integer = $this->parseCDATA($integer);
52  if ($integer === '') {
53  return false;
54  }
55 
56  // we could possibly simply typecast it to integer, but there are
57  // certain fringe cases that must not return an integer.
58 
59  // clip leading sign
60  if ($this->negative && $integer[0] === '-') {
61  $digits = substr($integer, 1);
62  if ($digits === '0') {
63  $integer = '0';
64  } // rm minus sign for zero
65  } elseif ($this->positive && $integer[0] === '+') {
66  $digits = $integer = substr($integer, 1); // rm unnecessary plus
67  } else {
68  $digits = $integer;
69  }
70 
71  // test if it's numeric
72  if (!ctype_digit($digits)) {
73  return false;
74  }
75 
76  // perform scope tests
77  if (!$this->zero && $integer == 0) {
78  return false;
79  }
80  if (!$this->positive && $integer > 0) {
81  return false;
82  }
83  if (!$this->negative && $integer < 0) {
84  return false;
85  }
86 
87  return $integer;
88  }
89 }
90 
91 // vim: et sw=4 sts=4




Korrekturen, Hinweise und Ergänzungen

Bitte scheuen Sie sich nicht und melden Sie, was auf dieser Seite sachlich falsch oder irreführend ist, was ergänzt werden sollte, was fehlt usw. Dazu bitte oben aus dem Menü Seite den Eintrag Support Forum wählen. Es ist eine kostenlose Anmeldung erforderlich, um Anmerkungen zu posten. Unpassende Postings, Spam usw. werden kommentarlos entfernt.