Add scripts/markdown.lua script. Based on forum-dwarves.lua but exports to markdown (obviously for reddit)
parent
7bf46b1584
commit
e62b6e9dc8
@ -0,0 +1,111 @@
|
||||
-- scripts/forum-dwarves.lua
|
||||
-- Save a copy of a text screen in markdown (for reddit among others). Use 'markdownexport help' for more details.
|
||||
-- This is a derivatiwe work based upon scripts/forum-dwarves.lua by Caldfir and expwnent
|
||||
-- Adapted for markdown by Mchl https://github.com/Mchl
|
||||
|
||||
local args = {...}
|
||||
|
||||
if args[1] == 'help' then
|
||||
print([[
|
||||
description:
|
||||
This script will attempt to read the current df-screen, and if it is a
|
||||
text-viewscreen (such as the dwarf 'thoughts' screen or an item / creature
|
||||
'description') then append a marked-down version of this text to the
|
||||
target file (for easy pasting on reddit for example).
|
||||
Previous entries in the file are not overwritten, so you
|
||||
may use the 'markdown' command multiple times to create a single
|
||||
document containing the text from multiple screens (eg: text screens
|
||||
from several dwarves, or text screens from multiple artifacts/items,
|
||||
or some combination).
|
||||
known screens:
|
||||
The screens which have been tested and known to function properly with
|
||||
this script are:
|
||||
1: dwarf/unit 'thoughts' screen
|
||||
2: item/art 'description' screen
|
||||
3: individual 'historical item/figure' screens
|
||||
There may be other screens to which the script applies. It should be
|
||||
safe to attempt running the script with any screen active, with an
|
||||
error message to inform you when the selected screen is not appropriate
|
||||
for this script.
|
||||
target file:
|
||||
The target file's name is 'markdownexport.txt'. A remider to this effect
|
||||
will be displayed if the script is successful.
|
||||
character encoding:
|
||||
The text will likely be using system-default encoding, and as such
|
||||
will likely NOT display special characters (eg:é,õ,ç) correctly. To
|
||||
fix this, you need to modify the character set that you are reading
|
||||
the document with. 'Notepad++' is a freely available program which
|
||||
can do this using the following steps:
|
||||
1: open the document in Notepad++
|
||||
2: in the menu-bar, select
|
||||
Encoding->Character Sets->Western European->OEM-US
|
||||
3: copy the text normally to wherever you want to use it
|
||||
]])
|
||||
return
|
||||
end
|
||||
local utils = require 'utils'
|
||||
local gui = require 'gui'
|
||||
local dialog = require 'gui.dialogs'
|
||||
|
||||
local scrn = dfhack.gui.getCurViewscreen()
|
||||
local flerb = dfhack.gui.getFocusString(scrn)
|
||||
|
||||
|
||||
local function reformat(strin)
|
||||
local strout = strin
|
||||
|
||||
-- [P] tags seem to indicate a new paragraph
|
||||
local newline_idx = string.find(strout, '[P]', 1, true)
|
||||
while newline_idx ~= nil do
|
||||
strout = string.sub(strout, 1, newline_idx - 1) .. '\n***\n\n' .. string.sub(strout, newline_idx + 3)
|
||||
newline_idx = string.find(strout, '[P]', 1, true)
|
||||
end
|
||||
|
||||
-- [R] tags seem to indicate a new 'section'. Let's mark it with a horizontal line.
|
||||
newline_idx = string.find(strout, '[R]', 1, true)
|
||||
while newline_idx ~= nil do
|
||||
strout = string.sub(strout, 1, newline_idx - 1) .. '\n***\n\n' .. string.sub(strout,newline_idx + 3)
|
||||
newline_idx = string.find(strout, '[R]', 1, true)
|
||||
end
|
||||
|
||||
-- No idea what [B] tags might indicate. Just removing them seems to work fine
|
||||
newline_idx = string.find(strout, '[B]', 1, true)
|
||||
while newline_idx ~= nil do
|
||||
strout = string.sub(strout, 1, newline_idx - 1) .. string.sub(strout,newline_idx + 3)
|
||||
newline_idx = string.find(strout, '[B]', 1, true)
|
||||
end
|
||||
|
||||
-- Reddit doesn't support custom colors in markdown. We need to remove all color information :(
|
||||
local color_idx = string.find(strout, '[C:', 1, true)
|
||||
while color_idx ~= nil do
|
||||
strout = string.sub(strout, 1, color_idx - 1) .. string.sub(strout, color_idx + 9)
|
||||
color_idx = string.find(strout, '[C:', 1, true)
|
||||
end
|
||||
|
||||
return strout
|
||||
end
|
||||
|
||||
if flerb == 'textviewer' then
|
||||
|
||||
local lines = scrn.src_text
|
||||
|
||||
if lines ~= nil then
|
||||
|
||||
local log = io.open('markdownexport.txt', 'a')
|
||||
log:write('### ' .. scrn.title .. '\n')
|
||||
|
||||
print('Exporting ' .. scrn.title .. '\n')
|
||||
|
||||
for n,x in ipairs(lines) do
|
||||
log:write(reformat(x.value).." ")
|
||||
-- debug output
|
||||
-- print(x.value)
|
||||
end
|
||||
|
||||
log:write('\n***\n\n')
|
||||
log:close()
|
||||
end
|
||||
print 'Data exported to "markdownexport.txt"'
|
||||
else
|
||||
print 'This is not a textview screen. Can\'t export data, sorry.'
|
||||
end
|
Loading…
Reference in New Issue