diff --git a/Michelf/Markdown.php b/Michelf/Markdown.php index 088b7cdd..834069df 100644 --- a/Michelf/Markdown.php +++ b/Michelf/Markdown.php @@ -2512,21 +2512,23 @@ protected function doTables($text) { # $text = preg_replace_callback(' { - ^ # Start of a line - [ ]{0,'.$less_than_tab.'} # Allowed whitespace. - [|] # Optional leading pipe (present) - (.+) \n # $1: Header row (at least one pipe) + ^ # Start of a line + [ ]{0,'.$less_than_tab.'} # Allowed whitespace. + [|] # Optional leading pipe (present) + (.+?) # $1: Header row (at least one pipe) + (?:'.$this->id_class_attr_catch_re.')? # $2: Extra table attributes + [ ]*\n # Allowed whitespace and newline. - [ ]{0,'.$less_than_tab.'} # Allowed whitespace. - [|] ([ ]*[-:]+[-| :]*) \n # $2: Header underline + [ ]{0,'.$less_than_tab.'} # Allowed whitespace. + [|] ([ ]*[-:]+[-| :]*) \n # $3: Header underline - ( # $3: Cells + ( # $4: Cells (?> - [ ]* # Allowed whitespace. - [|] .* \n # Row content. + [ ]* # Allowed whitespace. + [|] .* \n # Row content. )* ) - (?=\n|\Z) # Stop at final double newline. + (?=\n|\Z) # Stop at final double newline. }xm', array(&$this, '_doTable_leadingPipe_callback'), $text); @@ -2540,19 +2542,21 @@ protected function doTables($text) { # $text = preg_replace_callback(' { - ^ # Start of a line - [ ]{0,'.$less_than_tab.'} # Allowed whitespace. - (\S.*[|].*) \n # $1: Header row (at least one pipe) + ^ # Start of a line + [ ]{0,'.$less_than_tab.'} # Allowed whitespace. + (\S.*[|].*?) # $1: Header row (at least one pipe) + (?:'.$this->id_class_attr_catch_re.')? # $2: Extra table attributes + [ ]*\n # Allowed whitespace and newline. - [ ]{0,'.$less_than_tab.'} # Allowed whitespace. - ([-:]+[ ]*[|][-| :]*) \n # $2: Header underline + [ ]{0,'.$less_than_tab.'} # Allowed whitespace. + ([-:]+[ ]*[|][-| :]*) \n # $3: Header underline - ( # $3: Cells + ( # $4: Cells (?> - .* [|] .* \n # Row content + .* [|] .* \n # Row content )* ) - (?=\n|\Z) # Stop at final double newline. + (?=\n|\Z) # Stop at final double newline. }xm', array(&$this, '_DoTable_callback'), $text); @@ -2560,13 +2564,14 @@ protected function doTables($text) { } protected function _doTable_leadingPipe_callback($matches) { $head = $matches[1]; - $underline = $matches[2]; - $content = $matches[3]; + $tableAttrs = $matches[2]; + $underline = $matches[3]; + $content = $matches[4]; # Remove leading pipe for each row. $content = preg_replace('/^ *[|]/m', '', $content); - return $this->_doTable_callback(array($matches[0], $head, $underline, $content)); + return $this->_doTable_callback(array($matches[0], $head, $tableAttrs, $underline, $content)); } protected function _doTable_makeAlignAttr($alignname) { @@ -2578,9 +2583,10 @@ protected function _doTable_makeAlignAttr($alignname) } protected function _doTable_callback($matches) { $head = $matches[1]; - $underline = $matches[2]; - $content = $matches[3]; - + $tableAttrs = $matches[2]; + $underline = $matches[3]; + $content = $matches[4]; + # Remove any tailing pipes for each line. $head = preg_replace('/[|] *$/m', '', $head); $underline = preg_replace('/[|] *$/m', '', $underline); @@ -2606,8 +2612,11 @@ protected function _doTable_callback($matches) { $col_count = count($headers); $attr = array_pad($attr, $col_count, ''); + # Process extra table attributes + $tableAttrStr = $this->doExtraAttributes(null, $tableAttrs); + # Write column headers. - $text = "\n"; + $text = "\n"; $text .= "\n"; $text .= "\n"; foreach ($headers as $n => $header)