Alltså, bäst jag inleder med att säga: dom som kör windows, mac, android eller iphone göre sig icke besvär. Emacs, pandoc, sqlite, zenity, lua, zsh m.fl. kommer avhandlas nedan.
Till att börja med har jag en pandoc writer för wrnu så jag kan skriva inläggen i markdown. Jag lägger in features efter hand jag behöver dom (enligt YAGNI-principen) ex vis kommer jag väl lägga in tabeller förr eller senare. Jag utgår från ett skrälle jag hittade på hubben:
(Ni får byta ut ordet "abborre" mot "code" :D tydligen går det inte att ha en kod i koden :D)
Jag har skickat upp dom patches jag kände för, såsom vis LineBlock, andra ändringar har jag inte brytt mig om. Ex vis lade dom in en massa extra drälliga linebreaks i och runt quote och list som jag har tagit bort. Funderar på att skicka upp det med för dom linebreaksen är såvittjagvet semantiska i BBcode/VBcode och ger en fulare output. Men det kan jag ha fått om bakfoten därför att orka.
För att inifrån emacs kunna göra om regions från markdown till wrnu (att det är på region-basis är ibland väldigt smidigt, även om jag ofta tar hela buffern) har jag gjort en enkel liten snutt. (Skickar med den som är till S-G också, där behövdes ingen custom writer eftersom dom använder html):
Pathen till writern får ni ju ändra såklart!
Det som gör markdown så bra är samma sak som det får kritik från av dom som inte fattat: att man kan skriva saker i orginalspråket också. Markdown är inte som Textile att det är en all-ersättande lösning. Det är bara som en liten genväg eller hjälp för dom som ibland tycker det är lättare att skriva *bold* än [*b]bold[*/b] och ibland inte tycker det. Ex vis om man skriver html kan man blanda html och markdown i samma fil, om man skriver wrnu-forum-kod kan man blanda det och markdown i samma fil. Så för att göra länkar har jag skrivit dom på vanlig forumsyntax, har aldrig riktigt vant mig vid markdowns länksyntax. Men… jag är uppenbarligen inte van vid wrnu:s syntax heller för det är fortfarande bland dom vanligaste felen i mina inlägg, att jag mablat till URL-syntaxen. Så idag har jag pillat till en lösning på det.
Jag brukar bara köra wrnu och sg från M-x. Men md-link mappade jag till C-c C-l.
Programmet som gör om söksträng till färdigformaterad link är inte en självklarhet (speciellt om ni inte heter “sandra” och inte har era skalskript i “skami/sh”), jag slängde ihop ett skalskript med zenity och sqlite3 som söker igenom min firefox browsing history för att hitta länken.
Så jag kan till exempel trycka på C-c C-l, skriva in preppar hörna, och få upp en lång lista med länkar, välja en av dom, skriva in en ny titel på den (eller ändra/nöja mig med den hemsidans title-tag), och så klistras det in i markdownformat i buffern. Även om jag inte riktigt är van vid markdowns länksyntax kanske detta kan få mig att bli mer van + det kommer funka till S-G också om jag nu nån gång kommer tillbaka dit efter min välförtjänta och totalt rättvisa och inte alls oproportionerliga rage quit.♥
Till att börja med har jag en pandoc writer för wrnu så jag kan skriva inläggen i markdown. Jag lägger in features efter hand jag behöver dom (enligt YAGNI-principen) ex vis kommer jag väl lägga in tabeller förr eller senare. Jag utgår från ett skrälle jag hittade på hubben:
Kod:
--[[ ****************************************************************************** * * * Pandoc 2 BBCode for phpBB * * * ****************************************************************************** "bbcode_phpbb.lua" v1.1 (2016-12-20) adapted by Tristano Ajmone (@tajmone): -- https://github.com/tajmone/2bbcode ------------------------------------------------------------------------------ This code was forked by Tristano Ajmone from @lilydjwg's `2bbcode.lua`: -- https://github.com/lilydjwg/2bbcode Copyright (c) 2016, @lilydjwg (依云), all rights reserved. Released under BSD 3-Clause License: -- https://github.com/lilydjwg/2bbcode/blob/master/LICENSE ============================================================================== BSD 3-Clause License ============================================================================== Copyright (c) 2016, 依云 All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. * Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ==============================================================================]] -- Invoke with: pandoc -t bbcode_phpbb.lua -- Blocksep is used to separate block elements. function Blocksep() return "\n\n" end -- This function is called once for the whole document. Parameters: -- body, title, date are strings; authors is an array of strings; -- variables is a table. One could use some kind of templating -- system here; this just gives you a simple standalone HTML file. function Doc(body, title, authors, date, variables) return body .. '\n' end -- The functions that follow render corresponding pandoc elements. -- s is always a string, attr is always a table of attributes, and -- items is always an array of strings (the items in a list). -- Comments indicate the types of other variables. function Str(s) return s end function Space() return " " end function LineBreak() return "\n" end -- CHANGES BY @tajmone: Emphasis -- * Convert to Italic [i] instead of Emphasis [em] function Emph(s) return "" .. s .. "" end function Strong(s) return "" .. s .. "" end function Subscript(s) error("Subscript isn't supported") end function Superscript(s) return s end function SmallCaps(s) error("SmallCaps isn't supported") end -- CHANGES BY @tajmone: Strikeout -- * Convert to Underline [u] instead of Strikeout/Strikethrough [del] function Strikeout(s) return '' .. s .. '' end function Link(s, src, tit) local ret = '[url' if s then ret = ret .. '=' .. src else s = src end ret = ret .. "]" .. s .. "[/url]" return ret end -- CHANGES BY @tajmone: CaptionedImage -- * Added CaptionedImage function (missing in original) -- Caused error for GFM images with Alt text (even if Alt was empty) function CaptionedImage(src, tit, caption, attr) return "[img]" .. src .. "[/img]" end function Image(s, src, tit) return "[img=" .. tit .. "]" .. src .. "[/img]" end function Code(s, attr) return "" .. s .. "" end function InlineMath(s) error("InlineMath isn't supported") end function DisplayMath(s) error("DisplayMath isn't supported") end function Note(s) error("Note isn't supported") end function Plain(s) return s end function Para(s) return s end -- CHANGES BY @tajmone: Headers 1-6 -- * Don't use [h] (unsupported in phpBB) -- * Convert to different sizes and colors, always bold. -- * Higher order headers have bigger font size and more contrasting color. -- lev is an integer, the header level. function Header(lev, s, attr) if lev == 1 then return "" .. s .. "" elseif lev == 2 then return "" .. s .. "" elseif lev == 3 then return "" .. s .. "" elseif lev == 4 then return "" .. s .. "" elseif lev == 5 then return "" .. s .. "" else return "" .. s .. "" end end function BlockQuote(s) return "" end function HorizontalRule() return "--------------------------------------------------------------------------------" end function LineBlock(ls) return table.concat(ls, '\n') end function CodeBlock(s, attr) return "[abborre]\n" .. s .. '\n[/abborre]' end function BulletList(items) local buffer = {} for _, item in ipairs(items) do table.insert(buffer, "[*]" .. item) end return "" .. s .. "
- " .. table.concat(buffer, "\n") .. "
- " .. table.concat(buffer, "\n") .. "
Jag har skickat upp dom patches jag kände för, såsom vis LineBlock, andra ändringar har jag inte brytt mig om. Ex vis lade dom in en massa extra drälliga linebreaks i och runt quote och list som jag har tagit bort. Funderar på att skicka upp det med för dom linebreaksen är såvittjagvet semantiska i BBcode/VBcode och ger en fulare output. Men det kan jag ha fått om bakfoten därför att orka.
För att inifrån emacs kunna göra om regions från markdown till wrnu (att det är på region-basis är ibland väldigt smidigt, även om jag ofta tar hela buffern) har jag gjort en enkel liten snutt. (Skickar med den som är till S-G också, där behövdes ingen custom writer eftersom dom använder html):
Kod:
(defun wrnu () (interactive) (shell-command-on-region (mark) (point) "pandoc -St ~/.pandoc/data/wrnu.lua" nil t)) (defun sg () (interactive) (shell-command-on-region (mark) (point) "pandoc -S" nil t))
Det som gör markdown så bra är samma sak som det får kritik från av dom som inte fattat: att man kan skriva saker i orginalspråket också. Markdown är inte som Textile att det är en all-ersättande lösning. Det är bara som en liten genväg eller hjälp för dom som ibland tycker det är lättare att skriva *bold* än [*b]bold[*/b] och ibland inte tycker det. Ex vis om man skriver html kan man blanda html och markdown i samma fil, om man skriver wrnu-forum-kod kan man blanda det och markdown i samma fil. Så för att göra länkar har jag skrivit dom på vanlig forumsyntax, har aldrig riktigt vant mig vid markdowns länksyntax. Men… jag är uppenbarligen inte van vid wrnu:s syntax heller för det är fortfarande bland dom vanligaste felen i mina inlägg, att jag mablat till URL-syntaxen. Så idag har jag pillat till en lösning på det.
Kod:
(defun md-link () (interactive) (shell-command (concat "/home/sandra/skami/sh/md_link.sh '" (read-from-minibuffer "Link peps: ") "'") t) (forward-sexp 2)) (global-set-key (kbd "C-c C-l") 'md-link)
Programmet som gör om söksträng till färdigformaterad link är inte en självklarhet (speciellt om ni inte heter “sandra” och inte har era skalskript i “skami/sh”), jag slängde ihop ett skalskript med zenity och sqlite3 som söker igenom min firefox browsing history för att hitta länken.
Kod:
#!/usr/bin/zsh exec 2>/dev/null match=$(echo "$*"|sed -e 's/ /%/g' -e 's/^/%/g' -e 's/$/%/g') get_new_title(){ echo -n $(zenity --entry --entry-text="$(echo "$*" |sed 's/|.*//')") } title_fixer() { echo -n '['$(get_new_title "$*")']('$(echo "$*"|sed 's/.*|//')')' } title_fixer $(sqlite3 /home/sandra/.mozilla/firefox/*default/places.sqlite "select title, url from moz_places where url like '${match}' or title like '${match}';"|zenity --list --column Places|head -1)
Kommentera