From e9959a570e19fc1900969da65b5e009f8448b38f Mon Sep 17 00:00:00 2001 From: Bruce Hill Date: Fri, 18 Jan 2019 14:28:45 -0800 Subject: [PATCH] Fixed lists/dicts to autoformat with spacer lines when appropriate (same rules as for Blocks) --- nomsu_decompiler.lua | 10 ++++++++++ nomsu_decompiler.moon | 14 ++++++++++++++ 2 files changed, 24 insertions(+) diff --git a/nomsu_decompiler.lua b/nomsu_decompiler.lua index 164470f..f6552b8 100644 --- a/nomsu_decompiler.lua +++ b/nomsu_decompiler.lua @@ -566,6 +566,7 @@ tree_to_nomsu = function(tree) return nomsu end local sep = '' + local prev_item, needs_space = nil, { } for i, item in ipairs(tree) do local item_nomsu if item.type == 'MethodCall' then @@ -591,7 +592,16 @@ tree_to_nomsu = function(tree) end end nomsu:add(sep) + if sep == '\n' then + if tree[i - 1].type ~= "Comment" then + needs_space[i] = (item_nomsu:is_multiline() and prev_item:is_multiline()) + if tree[i].type == "Comment" or needs_space[i] or needs_space[i - 1] then + nomsu:add("\n") + end + end + end nomsu:add(item_nomsu) + prev_item = item_nomsu if item_nomsu:is_multiline() or item.type == 'Comment' or item.type == "Block" or nomsu:trailing_line_len() + #tostring(item_nomsu) >= MAX_LINE then sep = '\n' else diff --git a/nomsu_decompiler.moon b/nomsu_decompiler.moon index 297a518..4c733f5 100644 --- a/nomsu_decompiler.moon +++ b/nomsu_decompiler.moon @@ -427,11 +427,16 @@ tree_to_nomsu = (tree)-> nomsu\add "\\;" return NomsuCode\from(tree.source, '("\n ', nomsu, '\n")') + + + + when "List", "Dict" if #tree == 0 nomsu\add(tree.type == "List" and "[]" or "{}") return nomsu sep = '' + prev_item, needs_space = nil, {} for i, item in ipairs tree local item_nomsu if item.type == 'MethodCall' @@ -450,7 +455,16 @@ tree_to_nomsu = (tree)-> sep = '\n' if i > 1 item_nomsu = item.type == "Action" and tree_to_nomsu(item) or recurse(item) nomsu\add sep + if sep == '\n' + -- Rule of thumb: add a blank line between two lines if both are + -- multi-line non-comments, or if a comment comes after a non-comment, + -- or if the last line starts with ".." + if tree[i-1].type != "Comment" + needs_space[i] = (item_nomsu\is_multiline! and prev_item\is_multiline!) + if tree[i].type == "Comment" or needs_space[i] or needs_space[i-1] + nomsu\add "\n" nomsu\add item_nomsu + prev_item = item_nomsu if item_nomsu\is_multiline! or item.type == 'Comment' or item.type == "Block" or nomsu\trailing_line_len! + #tostring(item_nomsu) >= MAX_LINE sep = '\n'