ep_markdown 11.0.13 → 11.0.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -22,11 +22,11 @@ jobs:
22
22
  version: 1.0
23
23
  -
24
24
  name: Install etherpad core
25
- uses: actions/checkout@v4
25
+ uses: actions/checkout@v6
26
26
  with:
27
27
  repository: ether/etherpad-lite
28
28
  path: etherpad-lite
29
- - uses: pnpm/action-setup@v3
29
+ - uses: pnpm/action-setup@v6
30
30
  name: Install pnpm
31
31
  with:
32
32
  version: 10
@@ -35,7 +35,7 @@ jobs:
35
35
  shell: bash
36
36
  run: |
37
37
  echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
38
- - uses: actions/cache@v4
38
+ - uses: actions/cache@v5
39
39
  name: Setup pnpm cache
40
40
  with:
41
41
  path: ${{ env.STORE_PATH }}
@@ -44,7 +44,7 @@ jobs:
44
44
  ${{ runner.os }}-pnpm-store-
45
45
  -
46
46
  name: Checkout plugin repository
47
- uses: actions/checkout@v4
47
+ uses: actions/checkout@v6
48
48
  with:
49
49
  path: plugin
50
50
  - name: Remove tests
@@ -12,10 +12,10 @@ jobs:
12
12
  steps:
13
13
  -
14
14
  name: Check out Etherpad core
15
- uses: actions/checkout@v4
15
+ uses: actions/checkout@v6
16
16
  with:
17
17
  repository: ether/etherpad-lite
18
- - uses: pnpm/action-setup@v3
18
+ - uses: pnpm/action-setup@v6
19
19
  name: Install pnpm
20
20
  with:
21
21
  version: 10
@@ -24,7 +24,7 @@ jobs:
24
24
  shell: bash
25
25
  run: |
26
26
  echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
27
- - uses: actions/cache@v4
27
+ - uses: actions/cache@v5
28
28
  name: Setup pnpm cache
29
29
  with:
30
30
  path: ${{ env.STORE_PATH }}
@@ -33,7 +33,7 @@ jobs:
33
33
  ${{ runner.os }}-pnpm-store-
34
34
  -
35
35
  name: Check out the plugin
36
- uses: actions/checkout@v4
36
+ uses: actions/checkout@v6
37
37
  with:
38
38
  path: ./node_modules/__tmp
39
39
  -
@@ -31,7 +31,7 @@ jobs:
31
31
  uses: actions/checkout@v6
32
32
  with:
33
33
  repository: ether/etherpad-lite
34
- - uses: pnpm/action-setup@v5
34
+ - uses: pnpm/action-setup@v6
35
35
  name: Install pnpm
36
36
  with:
37
37
  version: 10
@@ -59,12 +59,20 @@ jobs:
59
59
  [ "${NEW_COMMITS}" -gt 0 ] || exit 0
60
60
  git config user.name 'github-actions[bot]'
61
61
  git config user.email '41898282+github-actions[bot]@users.noreply.github.com'
62
- pnpm i
62
+ pnpm i --frozen-lockfile
63
63
  # `pnpm version patch` bumps package.json, makes a commit, and creates
64
64
  # a `v<new-version>` tag. Capture the new tag name from package.json
65
65
  # rather than parsing pnpm's output, which has historically varied.
66
- pnpm version patch
67
- NEW_TAG="v$(node -p "require('./package.json').version")"
66
+ # Bump the patch component directly with Node. pnpm/action-setup@v6
67
+ # sometimes installs pnpm 11 pre-releases even when version: 10.x is
68
+ # requested (pnpm/action-setup#225); those pre-releases either skip
69
+ # the git commit/tag or reject --no-git-tag-version as unknown.
70
+ # Doing the bump in Node sidesteps both failure modes.
71
+ NEW_VERSION=$(node -e "const fs=require('fs');const p=require('./package.json');const v=p.version.split('.');v[2]=String(Number(v[2])+1);p.version=v.join('.');fs.writeFileSync('./package.json',JSON.stringify(p,null,2)+'\n');console.log(p.version);")
72
+ NEW_TAG="v${NEW_VERSION}"
73
+ git add package.json
74
+ git commit -m "${NEW_TAG}"
75
+ git tag -a "${NEW_TAG}" -m "${NEW_TAG}"
68
76
  # CRITICAL: use --atomic so the branch update and the tag update
69
77
  # succeed (or fail) as a single transaction on the server. The old
70
78
  # `git push --follow-tags` was non-atomic per ref: if a concurrent
package/README.md CHANGED
@@ -40,3 +40,20 @@ Requirements
40
40
  ============
41
41
 
42
42
  Etherpad 1.8.1
43
+
44
+ ## Installation
45
+
46
+ Install from the Etherpad admin UI (**Admin → Manage Plugins**,
47
+ search for `ep_markdown` and click *Install*), or from the Etherpad
48
+ root directory:
49
+
50
+ ```sh
51
+ pnpm run plugins install ep_markdown
52
+ ```
53
+
54
+ > ⚠️ Don't run `npm i` / `npm install` yourself from the Etherpad
55
+ > source tree — Etherpad tracks installed plugins through its own
56
+ > plugin-manager, and hand-editing `package.json` can leave the
57
+ > server unable to start.
58
+
59
+ After installing, restart Etherpad.
package/exportMarkdown.ts CHANGED
@@ -218,9 +218,27 @@ const getMarkdownFromAtext = (pad, atext) => {
218
218
  const url = urlData[1];
219
219
  const urlLength = url.length;
220
220
  processNextChars(startIndex - idx);
221
+ // Close any currently-open inline format tags (bold, italic, etc.)
222
+ // before writing the URL. If we don't, processing the URL's chars
223
+ // re-emits `**` / `*` markers *inside* the Markdown link token,
224
+ // producing broken output like `[url](**https://example.com**)`
225
+ // (regression for #156).
226
+ const reopen = [...openTags];
227
+ const tags2close = [...openTags];
228
+ orderdCloseTags(tags2close);
229
+ for (let i = 0; i < propVals.length; i++) { propVals[i] = false; }
221
230
  assem.append(`[${url}](`);
222
- processNextChars(urlLength);
231
+ // Emit the URL's chars as raw text — links in Markdown never
232
+ // contain inline formatting markers.
233
+ assem.append(taker.take(urlLength));
234
+ idx += urlLength;
223
235
  assem.append(')');
236
+ // Restore the formatting tags so any trailing same-line text picks
237
+ // them back up.
238
+ for (const i of reopen.slice().reverse()) {
239
+ emitOpenTag(i);
240
+ propVals[i] = true;
241
+ }
224
242
  });
225
243
  }
226
244
 
@@ -229,8 +247,15 @@ const getMarkdownFromAtext = (pad, atext) => {
229
247
  // replace &, _
230
248
  assem = assem.toString();
231
249
  assem = assem.replace(/&/g, '\\&');
232
- // this breaks Markdown math mode: $\sum_i^j$ becomes $\sum\_i^j$
233
- assem = assem.replace(/_/g, '\\_');
250
+ // Only escape underscores OUTSIDE code spans / code blocks. On a line
251
+ // with the `heading: 'code'` attribute (rendered with the 4-space
252
+ // block-code prefix) underscores should be preserved verbatim,
253
+ // otherwise `myVar_name` comes out as `myVar\_name` in the exported
254
+ // Markdown rendering (regression for #156). Math-mode ($...$) still
255
+ // has no special handling here — that is a separate concern.
256
+ if (heading !== headingtags[6]) {
257
+ assem = assem.replace(/_/g, '\\_');
258
+ }
234
259
 
235
260
  return assem;
236
261
  };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "ep_markdown",
3
3
  "description": "Edit and Export as Markdown in Etherpad",
4
- "version": "11.0.13",
4
+ "version": "11.0.15",
5
5
  "author": {
6
6
  "name": "John McLear",
7
7
  "email": "john@mclear.co.uk",
@@ -24,8 +24,8 @@
24
24
  "@types/mocha": "^10.0.10",
25
25
  "@types/node": "^25.6.0",
26
26
  "eslint": "^8.57.1",
27
- "eslint-config-etherpad": "^4.0.4",
28
- "typescript": "^6.0.2"
27
+ "eslint-config-etherpad": "^4.0.5",
28
+ "typescript": "^6.0.3"
29
29
  },
30
30
  "scripts": {
31
31
  "lint": "eslint .",