Markdown to MediaWiki Conversion Guide

Revision as of 02:51, 15 December 2024 by Sac (talk | contribs) (added intellipedia section)

Convert Markdown to MediaWiki

Mediawiki syntax is a bit different from markdown syntax and GPT tends to prefer markdown syntax and defaults to it even when you ask it to convert to mediawiki.

This template is a guide to converting markdown to MediaWiki syntax using GPT and regex instructions to find and replace what is often missed by GPT.

Exporting to Intellipedia

Intellipedia at every enclave doesn't allow importing by default. It does, however allow you to create pages using the source editor (Edit Source).

On any pages you want on this wiki or even Wikipedia you can view source or edit source and copy the text and paste it into the source editor as a file with extension .txt.

Transfer that file over to your government computer securely, then open the file in Notepad or any other text editor and copy the text. Paste that text into the source editor on Intellipedia.

REGEX Instructions

VS Code

Title Find Replace Description
Bold \*\*(.*?)\*\* $1 Converts markdown bold to MediaWiki bold
Heading =(.*?)= ==$1== Adjusts heading level since MediaWiki doesn't support multiple h1 headers
Bullet ^ \* ** Converts indented bullets to MediaWiki double asterisk
Numbering ^\d(.?) # Converts numbered lists with digits to MediaWiki numbered list format
Italics \_(.*?)\_ $1 Converts markdown italics to MediaWiki italics
External Links \[(.*?)\]\((https?:\/\/.*?)\) [$2 $1] Converts markdown external links to MediaWiki format
Internal Links \[(.*?)\]\((.*?)\.md\) $1 Converts markdown internal links to MediaWiki format
Images !\[(.*?)\]\((.*?)\) $1 Converts markdown images to MediaWiki format
Code Blocks ```(.*?)``` <pre>$1</pre> Converts markdown code blocks to MediaWiki pre tags
Inline Code `(.*?)` $1 Converts markdown inline code to MediaWiki code tags
Horizontal Rule ^---$ ---- Converts markdown horizontal rule to MediaWiki format


SED

You can do this on a mac or linux machine with sed using the clipboard as input and pipe it through sed and awk commands to get the output using the find and replace commands. echo pbpaste | sed -E 's/\*\*(.*?)\*\*/$1/g' | sed -E 's/=(.*?)=/==$1==/g' | sed -E 's/^ \*/**/g' | sed -E 's/^\d(.?)/#/g'

Python

GPT Instructions

Please convert the following page into MediaWiki format, adhering to the following guidelines:

1. **General Formatting**:
* Remove any "---" separators, as they can interfere with formatting.
* Convert any code blocks to use `<pre>` tags for MediaWiki formatting.
* Replace Markdown bold (`**text**`) with MediaWiki bold (`'''text'''`).

2. **Links**:
* Convert Markdown external links `[Link Text](http://example.com)` to MediaWiki external links: `[http://example.com Link Text]` (add a space between the URL and the title).
* Convert Markdown internal links `[Link Text](/path/page_title.md)` to MediaWiki internal links: `[[page_title|Link Text]]`.
* Convert File Links from markddown `![Alt Text](http://example.com/image.jpg)` to MediaWiki syntax: `[[File:image.jpg|alt=Alt Text]]`.
* Remove .md from the end of any internallink.

3. **Images**:
* Replace Markdown image syntax `![Alt Text](http://example.com/image.jpg)` with MediaWiki syntax: `[[File:image.jpg|alt=Alt Text]]`.

4. **Lists**:
* Convert unordered lists:
- Replace Markdown `- item` or `* item` with MediaWiki list syntax:
** `* item`
** `** subitem`
** `*** sub-sub-item`
* Convert ordered lists:
- Replace Markdown `1. item` or `2. item` with MediaWiki list syntax:
** `# item`
** `## subitem`
** `### sub-sub-item`

5. **Tables**:
* Replace Markdown table syntax with MediaWiki table syntax:
- Example Markdown:
```
| Header 1 | Header 2 |
|----------|----------|
| Row 1    | Data 1   |
```
- Example MediaWiki:
```
{| class="wikitable"
! Header 1
! Header 2
|-
| Row 1
| Data 1
|}
```

6. **References**:
* Add references for any links used on the page. Include them as basic MediaWiki references and ensure a `<references />` tag is added at the bottom of the page.

7. **Special Characters**:
* Escape any special characters that may conflict with MediaWiki formatting by using `<nowiki>` tags where necessary.

8. **Categories**:
* Add appropriate categories to the page using MediaWiki category syntax: `[[Category:Category Name]]`.

9. **Preservation of Content**:
* Ensure all original content is preserved in meaning and context.
* Maintain the integrity of the original text during conversion.

10. **Headers**:
* Convert Markdown headers (`# Header`, `## Subheader`) to MediaWiki headers:
**`== Header ==`
**`=== Subheader ===`

Apply these instructions to the provided content, ensuring that the final output complies with MediaWiki standards and preserves readability and accuracy.