⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.45
Server IP:
185.238.29.86
Server:
Linux server2 6.8.12-6-pve #1 SMP PREEMPT_DYNAMIC PMX 6.8.12-6 (2024-12-19T19:05Z) x86_64
Server Software:
nginx/1.18.0
PHP Version:
8.1.31
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
var
/
www
/
invoice
/
vendor
/
dompdf
/
dompdf
/
src
/
Frame
/
View File Name :
FrameTreeIterator.php
<?php namespace Dompdf\Frame; use Iterator; use Dompdf\Frame; /** * Pre-order Iterator * * Returns frames in preorder traversal order (parent then children) * * @access private * @package dompdf */ class FrameTreeIterator implements Iterator { /** * @var Frame */ protected $_root; /** * @var Frame[] */ protected $_stack = []; /** * @var int */ protected $_num; /** * @param Frame $root */ public function __construct(Frame $root) { $this->_stack[] = $this->_root = $root; $this->_num = 0; } public function rewind(): void { $this->_stack = [$this->_root]; $this->_num = 0; } /** * @return bool */ public function valid(): bool { return count($this->_stack) > 0; } /** * @return int */ public function key(): int { return $this->_num; } /** * @return Frame */ public function current(): Frame { return end($this->_stack); } public function next(): void { $b = end($this->_stack); // Pop last element unset($this->_stack[key($this->_stack)]); $this->_num++; // Push all children onto the stack in reverse order if ($c = $b->get_last_child()) { $this->_stack[] = $c; while ($c = $c->get_prev_sibling()) { $this->_stack[] = $c; } } } }