summaryrefslogtreecommitdiff
path: root/lib/FormatInterface.php
blob: 68b0bd5901555fa74602b0b7b012d3301be4a07c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
<?php
/**
 * This file is part of RSS-Bridge, a PHP project capable of generating RSS and
 * Atom feeds for websites that don't have one.
 *
 * For the full license information, please view the UNLICENSE file distributed
 * with this source code.
 *
 * @package	Core
 * @license	http://unlicense.org/ UNLICENSE
 * @link	https://github.com/rss-bridge/rss-bridge
 */

/**
 * The format interface
 *
 * @todo Add missing function to the interface
 * @todo Explain parameters and return values in more detail
 * @todo Return self more often (to allow call chaining)
 */
interface FormatInterface {
	/**
	 * Generate a string representation of the current data
	 *
	 * @return string The string representation
	 */
	public function stringify();

	/**
	 * Display the current data to the user
	 *
	 * @return self The format object
	 */
	public function display();

	/**
	 * Set items
	 *
	 * @param array $bridges The items
	 * @return self The format object
	 *
	 * @todo Rename parameter `$bridges` to `$items`
	 */
	public function setItems(array $bridges);

	/**
	 * Return items
	 *
	 * @throws \LogicException if the items are not set
	 * @return array The items
	 */
	public function getItems();

	/**
	 * Set extra information
	 *
	 * @param array $infos Extra information
	 * @return self The format object
	 */
	public function setExtraInfos(array $infos);

	/**
	 * Return extra information
	 *
	 * @return array Extra information
	 */
	public function getExtraInfos();

	/**
	 * Set charset
	 *
	 * @param string $charset The charset
	 * @return self The format object
	 */
	public function setCharset($charset);

	/**
	 * Return current charset
	 *
	 * @return string The charset
	 */
	public function getCharset();
}