mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-05-31 17:55:29 +09:00
- 2022년 3월 개발팀 결정사항 적용 - 모듈 등 서드파티 자료 개발시 composer를 사용하면 상위 경로에 있는 코어의 composer.json을 수정하고, 코어의 vendor 디렉토리를 건드리는 것이 기본값임 - 이를 방지하기 위해 코어의 composer.json과 vendor를 common 디렉토리 안으로 이동하여, 모듈 경로에서 상위 폴더로 인식하지 않도록 함
86 lines
1.9 KiB
PHP
86 lines
1.9 KiB
PHP
<?php
|
|
|
|
namespace JBBCode;
|
|
|
|
/**
|
|
* A node within the document tree.
|
|
*
|
|
* Known subclasses: TextNode, ElementNode
|
|
*
|
|
* @author jbowens
|
|
*/
|
|
abstract class Node
|
|
{
|
|
/** @var Node Pointer to the parent node of this node */
|
|
protected $parent;
|
|
|
|
/**
|
|
* Returns this node's immediate parent.
|
|
*
|
|
* @return Node the node's parent
|
|
*/
|
|
public function getParent()
|
|
{
|
|
return $this->parent;
|
|
}
|
|
|
|
/**
|
|
* Determines if this node has a parent.
|
|
*
|
|
* @return boolean true if this node has a parent, false otherwise
|
|
*/
|
|
public function hasParent()
|
|
{
|
|
return $this->parent != null;
|
|
}
|
|
|
|
/**
|
|
* Returns true if this is a text node. Returns false otherwise.
|
|
* (Overridden by TextNode to return true)
|
|
*
|
|
* @return boolean true if this node is a text node
|
|
*/
|
|
public function isTextNode()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Accepts the given NodeVisitor. This is part of an implementation
|
|
* of the Visitor pattern.
|
|
*
|
|
* @param NodeVisitor $nodeVisitor the NodeVisitor traversing the graph
|
|
*/
|
|
abstract public function accept(NodeVisitor $nodeVisitor);
|
|
|
|
/**
|
|
* Returns this node as text (without any bbcode markup)
|
|
*
|
|
* @return string the plain text representation of this node
|
|
*/
|
|
abstract public function getAsText();
|
|
|
|
/**
|
|
* Returns this node as bbcode
|
|
*
|
|
* @return string the bbcode representation of this node
|
|
*/
|
|
abstract public function getAsBBCode();
|
|
|
|
/**
|
|
* Returns this node as HTML
|
|
*
|
|
* @return string the html representation of this node
|
|
*/
|
|
abstract public function getAsHTML();
|
|
|
|
/**
|
|
* Sets this node's parent to be the given node.
|
|
*
|
|
* @param Node $parent the node to set as this node's parent
|
|
*/
|
|
public function setParent(Node $parent)
|
|
{
|
|
$this->parent = $parent;
|
|
}
|
|
}
|