summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn MacFarlane <fiddlosopher@gmail.com>2014-09-07 08:06:35 -0700
committerJohn MacFarlane <fiddlosopher@gmail.com>2014-09-07 08:06:35 -0700
commit2cf0750a7a507eded4cf3c9a48fd1f924d0ce538 (patch)
tree939702838c48343981e2ca6af7f19c2ed60b166d
parent3c89f2660280266d9d82cf398b2ff9ba5d693fff (diff)
Fixed #48.
- Fixed js and C code. - Added two test cases to spec.
-rwxr-xr-xjs/stmd.js11
-rw-r--r--spec.txt12
-rw-r--r--src/inlines.c10
3 files changed, 26 insertions, 7 deletions
diff --git a/js/stmd.js b/js/stmd.js
index 13bdbd6..15d7345 100755
--- a/js/stmd.js
+++ b/js/stmd.js
@@ -341,16 +341,15 @@ var parseEmphasis = function(inlines) {
res = this.scanDelims(c);
if (res.numdelims >= 1 && res.numdelims <= 3 && res.can_close &&
res.numdelims != first_close_delims) {
- if (res.numdelims === 3) {
- // If we opened with ***, then we interpret *** as ** followed by *
- // giving us <strong><em>
- res.numdelims = 1;
- }
- if (first_close_delims === 1) {
+ if (first_close_delims === 1 && numdelims > 2) {
res.numdelims = 2;
} else if (first_close_delims === 2) {
res.numdelims = 1;
+ } else if (res.numdelims === 3) {
+ // If we opened with ***, then we interpret *** as ** followed by *
+ // giving us <strong><em>
+ res.numdelims = 1;
}
this.pos += res.numdelims;
diff --git a/spec.txt b/spec.txt
index 0307df1..82ae0b6 100644
--- a/spec.txt
+++ b/spec.txt
@@ -4561,6 +4561,18 @@ similarly for `_` and `__`):
<p><strong>foo</strong>*</p>
.
+.
+***foo* bar***
+.
+<p><strong><em>foo</em> bar</strong>*</p>
+.
+
+.
+***foo** bar***
+.
+<p><em><strong>foo</strong> bar</em>**</p>
+.
+
The following contains no strong emphasis, because the opening
delimiter is closed by the first `*` before `bar`:
diff --git a/src/inlines.c b/src/inlines.c
index 9e35178..f75c846 100644
--- a/src/inlines.c
+++ b/src/inlines.c
@@ -425,9 +425,17 @@ static inl* handle_strong_emph(subject* subj, char c)
new = make_str(bmidstr(subj->buffer, subj->pos, numdelims));
append_inlines(*last, new);
*last = new;
- if (numdelims == 3) {
+
+ if (first_close_delims == 1 && numdelims > 2) {
+ numdelims = 2;
+ } else if (first_close_delims == 2) {
+ numdelims = 1;
+ } else if (numdelims == 3) {
+ // If we opened with ***, we interpret it as ** followed by *
+ // giving us <strong><em>
numdelims = 1;
}
+
subj->pos += numdelims;
if (first_close) {
first_head->tag = first_close_delims == 1 ? strong : emph;