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@
|
|
25
|
+
uses: actions/checkout@v6
|
|
26
26
|
with:
|
|
27
27
|
repository: ether/etherpad-lite
|
|
28
28
|
path: etherpad-lite
|
|
29
|
-
- uses: pnpm/action-setup@
|
|
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@
|
|
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@
|
|
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@
|
|
15
|
+
uses: actions/checkout@v6
|
|
16
16
|
with:
|
|
17
17
|
repository: ether/etherpad-lite
|
|
18
|
-
- uses: pnpm/action-setup@
|
|
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@
|
|
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@
|
|
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@
|
|
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
|
-
|
|
67
|
-
|
|
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
|
-
|
|
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
|
-
//
|
|
233
|
-
|
|
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.
|
|
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.
|
|
28
|
-
"typescript": "^6.0.
|
|
27
|
+
"eslint-config-etherpad": "^4.0.5",
|
|
28
|
+
"typescript": "^6.0.3"
|
|
29
29
|
},
|
|
30
30
|
"scripts": {
|
|
31
31
|
"lint": "eslint .",
|