Module:Alhatorah/sandbox explained

-- This module implements Template:Alhatorah. Based on Template:Bibleverselocal p =

--possible book inputs, based on Chicago Manuallocal book_aliases =

--these books only have one chapter, have to be handled differentlylocal no_chapters =

--changes to the version name to be used in urls, only if necessarylocal site_version_tbl =

local function trimArg(text) if type(text)

'string' then text = text:match('(%S.-)%s*$') --trimmed text or nil if empty end return textend

local function valueExists(tbl, value) for _, v in pairs(tbl) do if value

v then return true end end return falseend

local function titlecase(arg) -- http://grammar.yourdictionary.com/capitalization/rules-for-capitalization-in-titles.html -- recommended by The U.S. Government Printing Office Style Manual: -- 'Capitalize all words in titles of publications and documents, -- except a, an, the, at, by, for, in, of, on, to, up, and, as, but, or, and nor.' local alwayslower = local words = mw.text.split(mw.text.trim(arg or ), '_') for i, s in ipairs(words) do s = string.lower(s) if i > 1 then if not alwayslower[s] then s = mw.getContentLanguage:ucfirst(s) end else s = mw.getContentLanguage:ucfirst(s) end words[i] = s end return table.concat(words, '_')end

function p.main(frame) local targs = frame:getParent.args local args = for _, param in ipairs do args[param] = trimArg(targs[param]) end local default_version = 'nrsv' local input_book = local ref = local commentary = local text = local mainspace = mw.title.getCurrentTitle:inNamespaces(0) if args[1]

nil or args[2]

nil or tonumber(args[1]) ~= nil then -- first argument is a numeric prefix and second is book name input_book = trimArg((args[1] or ) .. ' ' .. (args[2] or )) or ref = args[3] or commentary = args[4] or text = args[5] or trimArg((commentary .. ' to ' .. input_book .. ' ' .. ref)) else -- first argument is the whole book name input_book = args[1] or ref = args[2] or commentary = args[3] or text = args[4] or (commentary .. ' to ' .. input_book .. ' ' .. ref) end if args.nobook

'yes' then text = ref end text = text:gsub('-', '–') --change hyphens to en dashes (3:2-5 → 3:2–5)

local book = input_book:gsub('%p', ):gsub(' ', '_') book = mw.ustring.lower(book)

local book_found = false local standard = book:gsub('_', ) for full_book, aliases in pairs(book_aliases) do if standard

full_book:gsub('_', ) or valueExists(aliases, standard) then book = full_book book_found = true break end end

local urlpat = 'https://mg.alhatorah.org/Dual/_commentary/_book/_schap._svers#m7e3n7'

local split_ref = mw.text.split(ref, '[-–—]') --split the ref into the part before and after the dash/hyphen local s_ref = mw.text.split(split_ref[1], '%p') --any punctuation can be used to separate chapter from verse local e_ref = split_ref[2] or split_ref[1] e_ref = mw.text.split(e_ref, '%p') for i, v in ipairs(s_ref) do s_ref[i] = v:gsub('%D', ) end --remove any non-numeric character (such as f) for i, v in ipairs(e_ref) do e_ref[i] = v:gsub('%D', ) end

local e_chap, e_vers, s_chap, s_vers local chapter_only = not s_ref[2] if no_chapters[book] then chapter_only = false s_chap = 1 s_vers = s_ref[2] or s_ref[1] or 1 --verse 3 can be specified as "3" or "1:3" e_chap = 1 e_vers = e_ref[2] or e_ref[1] or 1 else s_chap = s_ref[1] or 1 s_vers = s_ref[2] or 1 if e_ref[2] or not s_ref[2] then --chapter-chapter or chapter(:verse)?-chapter:verse e_chap = e_ref[1] or s_chap else --chapter:verse-verse e_chap = s_chap end e_vers = e_ref[2] or e_ref[1] or s_vers end book = titlecase(book) --title case looks better at oremus where they display the input

local v_range if chapter_only then if e_chap

s_chap then v_range = s_chap else v_range = s_chap .. '–' .. e_chap end else if e_chap

s_chap and e_vers

s_vers then v_range = s_chap ..':' .. s_vers elseif e_chap

s_chap then v_range = s_chap .. ':' .. s_vers .. '–' .. e_vers else v_range = s_chap .. ':' .. s_vers .. '–' .. e_chap .. ':' .. e_vers end end

local url = urlpat:gsub('_%l+',)

local fulllink fulllink = '[' .. url .. ' ' .. text .. ']' if mainspace then if not book_found then table.insert(errors, '

Template:Bibleverse with invalid book') end if version_num then table.insert(errors, '') end end return fulllink --.. table.concat(errors)end

return p