From 78bde1b41e5cb692ea9ffbfff4d35edf3162dcdf Mon Sep 17 00:00:00 2001 From: Philipp Gesang Date: Fri, 6 Jul 2018 10:10:05 +0200 Subject: rem, common: handle string sanitization --- rem.lua | 49 +++++++++++++++++++++++++++++-------------------- 1 file changed, 29 insertions(+), 20 deletions(-) (limited to 'rem.lua') diff --git a/rem.lua b/rem.lua index e1fdc1f..ed3a355 100644 --- a/rem.lua +++ b/rem.lua @@ -6,30 +6,33 @@ local inspect = require "ext.inspect" -local pcall = pcall +local pcall = pcall -local io = require "io" -local iostdout = io.stdout +local io = require "io" +local iostdout = io.stdout -local math = require "math" -local mathfloor = math.floor +local math = require "math" +local mathfloor = math.floor -local os = os -local osdate = os.date -local ostime = os.time +local os = os +local osdate = os.date +local ostime = os.time -local string = require "string" -local stringformat = string.format -local stringsub = string.sub +local string = require "string" +local stringformat = string.format +local stringsub = string.sub +local stringgsub = string.gsub -local table = require "table" -local tableconcat = table.concat +local table = require "table" +local tableconcat = table.concat -local common = require "common" -local println = common.println -local errorln = common.errorln -local noiseln = common.noiseln -local debugln = common.debugln +local common = require "common" +local println = common.println +local errorln = common.errorln +local noiseln = common.noiseln +local debugln = common.debugln +local trim_whitespace = common.trim_whitespace +local unescape_string = common.unescape_string local seconds_of_time = function (t) return t % 60 @@ -245,7 +248,13 @@ local rem_of_vcalendars do end local msg_of_description = function (val) - return val.value + local sane = unescape_string (val.value) + + return trim_whitespace (sane) + end + + local msg_of_string = function (s) + return stringgsub (s, "\n", "^M") end local rem_of_vevent = function (ev) @@ -280,7 +289,7 @@ local rem_of_vcalendars do error ("could not derive message text from event values") end - return stringformat ("REM %s MSG %s", date, msg) + return stringformat ("REM %s MSG %s", date, msg_of_string (msg)) end local rem_of_vcalendar = function (vcal) -- cgit v1.2.3