5 A PhpWiki plugin that allows insertion of tables using the Wikicreole
9 * Copyright (C) 2008-2009 Alcatel-Lucent
11 * This file is part of PhpWiki.
13 * PhpWiki is free software; you can redistribute it and/or modify
14 * it under the terms of the GNU General Public License as published by
15 * the Free Software Foundation; either version 2 of the License, or
16 * (at your option) any later version.
18 * PhpWiki is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU General Public License for more details.
23 * You should have received a copy of the GNU General Public License
24 * along with PhpWiki; if not, write to the Free Software
25 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
29 * Standard Alcatel-Lucent disclaimer for contributing to open source
31 * "The WikicreoleTablePlugin ("Contribution") has not been tested and/or
32 * validated for release as or in products, combinations with products or
33 * other commercial use. Any use of the Contribution is entirely made at
34 * the user's own responsibility and the user can not rely on any features,
35 * functionalities or performances Alcatel-Lucent has attributed to the
38 * THE CONTRIBUTION BY ALCATEL-LUCENT IS PROVIDED AS IS, WITHOUT WARRANTY
39 * OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
40 * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, COMPLIANCE,
41 * NON-INTERFERENCE AND/OR INTERWORKING WITH THE SOFTWARE TO WHICH THE
42 * CONTRIBUTION HAS BEEN MADE, TITLE AND NON-INFRINGEMENT. IN NO EVENT SHALL
43 * ALCATEL-LUCENT BE LIABLE FOR ANY DAMAGES OR OTHER LIABLITY, WHETHER IN
44 * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
45 * CONTRIBUTION OR THE USE OR OTHER DEALINGS IN THE CONTRIBUTION, WHETHER
46 * TOGETHER WITH THE SOFTWARE TO WHICH THE CONTRIBUTION RELATES OR ON A STAND
50 class WikiPlugin_WikicreoleTable
54 return _("WikicreoleTable");
57 function getDescription() {
58 return _("Layout tables using the Wikicreole syntax.");
61 function getDefaultArguments() {
65 function getVersion() {
66 return preg_replace("/[Revision: $]/", '',
70 function handle_plugin_args_cruft($argstr, $args) {
74 function run($dbi, $argstr, &$request, $basepage) {
76 include_once('lib/InlineParser.php');
80 $lines = preg_split('/\s*?\n\s*/', $argstr);
82 foreach ($lines as $line) {
87 // If line ends with a '|', remove it
88 if ($line[strlen($line)-1] == '|') {
89 $line = substr($line, 0, -1);
91 if ($line[0] != '|') {
92 // trigger_error(sprintf(_("Line %s does not begin with a '|'."), $line), E_USER_WARNING);
94 $table[] = $this->_parse_row($line, $basepage);
98 $nbrows = sizeof($table);
99 $nbcols = sizeof($table[0]);
101 // If table is empty, do not generate table markup
103 return HTML::raw('');
106 for ($i=0; $i<$nbrows; $i++) {
107 for ($j=0; $j<$nbcols; $j++) {
108 if (preg_match('/@@/', $table[$i][$j])) {
109 $table[$i][$j] = compute_tablecell($table, $i, $j, $nbrows, $nbcols);
114 $htmltable = HTML::table(array('class' => "bordered"));
115 foreach ($table as $row) {
116 $htmlrow = HTML::tr();
117 foreach ($row as $cell) {
118 if ($cell && $cell[0] == '=') {
119 $cell = trim(substr($cell, 1));
120 $htmlrow->pushContent(HTML::th(TransformInline($cell, 2.0, $basepage)));
122 if (is_numeric($cell)) {
123 $htmlrow->pushContent(HTML::td(array('style' => "text-align:right"), $cell));
125 $htmlrow->pushContent(HTML::td(TransformInline($cell, 2.0, $basepage)));
129 $htmltable->pushContent($htmlrow);
134 function _parse_row ($line, $basepage) {
135 $brkt_link = "\\[ .*? [^]\s] .*? \\]";
136 $cell_content = "(?: [^[] | ".ESCAPE_CHAR."\\[ | $brkt_link )*?";
138 preg_match_all("/(\\|+) \s* ($cell_content) \s* (?=\\||\$)/x",
139 $line, $matches, PREG_SET_ORDER);
143 foreach ($matches as $m) {
157 // c-hanging-comment-ender-p: nil
158 // indent-tabs-mode: nil