Módulo:MARCimporter: mudanças entre as edições

Conteúdo deletado Conteúdo adicionado
m teste
Etiqueta: Revertido
fix formOfItem
 
(6 revisões intermediárias pelo mesmo usuário não estão sendo mostradas)
Linha 3:
-- um handler para registros em "MARC tags", uma configuração para registros
-- bibliográficos e uma configuração para registros de autoridade.
function p.record( frame )
-- recebe o registro, o terceiro argumento da Predefinição:MARCimporter
local record = frame.args[3] or ''
-- recebe o modo de normalização Unicode ("Sim" para ativar o modo NFD)
local isNFD = frame.args[2] or ''
-- inicializa as variáveis básicas do registro
local leader = ''
local baseAddressOfData = 0
local directory = 0''
local dataValuesGroup = ''
-- inicializa as variáveis auxiliares
local directoryEntry = 0''
local entryTag = 0''
local entryDataLength = 0''
local entryInitPosition = 0''
local dataField = {} -- Cada tabela que contém os dados dos campos. Formato:
-- { tag='', length='', initPosition='', data='', ind1='', ind2='' }
local dataFields = {} -- Tabela que contém cada tabela dataField. Formato:
-- { 1={}, 2={}, 3={}, 4={}, n={} }
local controlField001 = ''
local controlField003 = ''
local controlField006 = ''
local controlField007 = ''
local controlField008 = ''
local tag040 = ''
local firstTemplate = ''
local fieldTemplates = ''
local lastTemplate = '{{EndOfRecord}}</pre>'
local queryString = ''
local fieldQueryString = ''
local formLink = ''
local function normalizeData( data )
data = data
:gsub( '|(.)', ' $%1 ' ) -- substitui "|a" por " $a "
:gsub( '(%d)p%.', '%1 p.' ) -- // "1p." por "1 p."
:gsub( '(%d)cm', '%1 cm' ) -- // "1cm" por "1 cm"
:gsub( '(%d)ed%.', '%1 ed.' ) -- // "1ed." por "1 ed."
:gsub( '%.%s?%-$', '.' ) -- // ". -" por "."
:gsub( '(%$.*)(%$w.*)', '%2 %1' ) -- move o subcampo $w para a frente
:gsub( '(%s%$9%s.*)', '' ) -- remove o subcampo $9
:gsub( '(%$z.*)(%$u.*)', '%2 %1' ) -- move o subcampo $u para a frente
:gsub( '[\n\r]', '') -- remove line feed e carriage return
return data
end
if record:match( '^%d%d%d%d' )
then
-- == MARC ISO 2709 handler == --
-- O MediaWiki substitui caracteres de controle (RS, US, GS) pelo
-- caractere de "desconhecido" (losango com interrogação) e, aqui,
-- substituo esse caractere por um pipe (é necessário substituir
-- por um caractere da faixa ASCII).
record = record:gsub( '�', '|' )
-- verifica se a forma de normalização Unicode é a
-- Normalization Form Canonical Decomposition (NFD)
if isNFD == 'Sim'
then
record = mw.ustring.toNFD( record )
end
-- configuração das variáveis básicas do registro (via ISO 2709):
-- obtém o líder
leader = record:sub( 1, 24 ) or ''
--> 00898nam a2200277 a 4500
-- obtém o endereço base dos dados
baseAddressOfData = tonumber( leader:sub( 13, 17 ) ) or 0
--> 00277
-- obtém o diretório (-1 para não pegar RS)
directory = record:sub( 25, baseAddressOfData - 1 ) or 0''
--> 0010010000000050017000100080041000270200027000680400017000950...
-- obtém os dados dos campos em um único grupo
dataValuesGroup = record:sub( baseAddressOfData + 1 ) or ''
--> 278 até o final do registro
-- enquanto o tamanho do diretório for maior que 0...
while #directory > 0
do
directoryEntry = directory:sub( 1, 12 ) -- 245008100177
entryTag = directoryEntry:sub( 1, 3 ) -- 245
entryDataLength = directoryEntry:sub( 4, 7 ) -- 0081
entryInitPosition = directoryEntry:sub( 8, 12 ) -- 00177
-- cria uma tabela com os dados...
dataField = {
tag = entryTag,
length = entryDataLength,
initPosition = entryInitPosition
}
}
-- e insere cada tabela dataField na tabela dataFields
table.insert( dataFields, dataField )
-- esvazia o diretório de 12 em 12
directory = directory:sub( 13 )
end
-- para cada item da tabela dataFields...
for index, dataField in ipairs( dataFields )
do
-- configura as variáveis para uso na função string.sub( i, j )
-- (+1 porque em Lua se começa do 1, não do 0)
local i = dataFields[index].initPosition + 1
-- (-1 para não pegar RS)
local j = dataFields[index].initPosition + dataFields[index].length - 1
-- localiza o dado em dataValuesGroup, normaliza o dado
-- e armazena na tabela
dataFields[index].data = normalizeData( dataValuesGroup:sub( i, j ) )
-- armazena os campos de controle (00X) para posterior decomposição
if dataFields[index].tag == '006'
then
controlField006 = dataFields[index].data:gsub( '[|#$]', ' ' )
end
if dataFields[index].tag == '007'
then
controlField007 = dataFields[index].data:gsub( '[|#$\r]', ' ' )
end
if dataFields[index].tag == '008'
then
controlField008 = dataFields[index].data:gsub( '[|#$-]', ' ' )
end
end
else
-- == MARC tags handler == --
record = record
:gsub( ' ', ' ' ) -- LC bib handling (\t+\s)
:gsub( ' ', ' ' ) -- LC aut handling (\t)
:gsub( '    ', ' ' ) -- Pergamum handling (control fields) (non-breaking space)
:gsub( ' ', ' ' ) -- Pergamum handling (data fields) (non-breaking space)
record = record .. '\n'
if record:match( '^FMT' ) or record:match( '^LDR' ) -- Aleph handling
then
record = record:gsub( '\t', ' ' ) -- 1
:gsub( '^(FMT%s[A-Z].-\n)', '' ) -- 2
:gsub( 'LDR%s([0%s][0%s][0%s][0%s][0%s].-\n)', '000 %1' ) -- 3
:gsub( '\n(%d%d%d)%s(%$.%s)', '\n%1 %2' ) -- 4
:gsub( '\n(%d%d%d)(%d)', '\n%1 %2' ) -- 5
:gsub( '\n(%d%d%d%s%d%s)', '\n%1 ' ) -- 6 (manter essa ordem)
end
-- configuração das variáveis básicas do registro (via MARC tags):
-- obtém o líder
leader = record:match( '^000%s([%d%s][%d%s][%d%s][%d%s][%d%s].-)\n' ) or ''
leader = leader:gsub( '[|#$]', ' ' )
-- obtém os campos de controle
controlField001 = record:match( '\n001%s(.-)\n' ) or ''
controlField003 = record:match( '\n003%s(.-)\n' ) or ''
controlField003 = mw.text.trim( controlField003 )
controlField006 = record:match( '\n006%s([a-z].-)\n' ) or ''
controlField006 = controlField006:gsub( '[|#$]', ' ' )
controlField007 = record:match( '\n007%s([a-z].-)\n' ) or ''
controlField007 = controlField007:gsub( '[|#$\r]', ' ' )
controlField008 = record:match( '008%s([%d%s][%d%s][%d%s][%d%s][%d%s][%d%s].-)\n' ) or ''
controlField008 = controlField008:gsub( '[|#$-]', ' ' )
-- para cada linha do registro, identifica o campo e seu conteúdo
-- (o conteúdo inclui os indicadores)
for tagMatch, dataMatch in record:gmatch(
'([0-8]%d%d) ([0-9_%s][0-9_%s] [$|].-)\n' )
do
-- transforma o dado para o formato igual ao manipulado pelo
-- MARC ISO 2709 handler
dataMatch = dataMatch:gsub( '%s?|(.)%s', '|%1' )
-- normaliza o dado
dataMatch = normalizeData(dataMatch)
 
-- cria uma tabela com os dados...
dataField = {
tag = tagMatch,
data = dataMatch
}
}
-- e insere cada tabela dataField na tabela dataFields
table.insert( dataFields, dataField )
end
end
-- == Handler unificado == --
if leader:sub( 7, 7 ) == 'z' and (controlField003:lower():match( 'br') or controlField003:lower():match('br-rjbn'))
then
-- cria uma tabela com os dados...
dataField = {
tag = '670',
data = '## $a CA-BN ' .. os.date( '%Y' )
}
}
-- e insere a tabela dataField na tabela dataFields
table.insert( dataFields, dataField )
-- também mova o número de controle para o campo 035
dataField = {
tag = '035',
data = '## $a ' .. '(' .. controlField003 .. ')' .. controlField001
}
}
table.insert( dataFields, dataField )
end
-- função de ordenação dos campos
local function sortByTag ( a, b )
if ( a.tag < b.tag )
then
return true
elseif ( a.tag > b.tag )
then
return false
else
return a.originalOrder < b.originalOrder
end
end
-- para cada item da tabela dataFields...
for index, dataField in ipairs( dataFields )
do
-- verifica se a tag é a 040
if dataFields[index].tag == '040'
-- se for, adiciona o subcampo para a agência modificadora do registro
-- e marca como verdadeiro a presença deste campo
then
dataFields[index].data = dataFields[index].data .. ' $d BR-FlWIK'
tag040 = dataFields[index].data
end
-- verifica se a tag é uma das seguintes
if dataFields[index].tag == '092' or dataFields[index].tag == '595'
then
-- se for, exclua da tabela dataFields
table.remove( dataFields, index )
end
end
-- se o registro for da LC
if leader:sub( 7, 7 ) == 'z' and tag040:match('a 'DLC' )
then
-- cria uma tabela com os dados...
dataField = {
tag = '670',
data = '## $a CA-LC ' .. os.date( '%Y' )
}
}
-- e insere a tabela dataField na tabela dataFields
table.insert( dataFields, dataField )
end
-- se não há campo 040, então será criado agora
if tag040 == ''
then
-- cria uma tabela com os dados...
dataField = {
tag = '040',
data = '## $a BR-FlWIK $b por $c BR-FlWIK'
}
}
-- e insere a tabela dataField na tabela dataFields
table.insert( dataFields, dataField )
end
for index, dataField in ipairs( dataFields )
do
-- guarda a ordem original do campo para posterior inclusão de outros
-- campos (mantendo a ordem original)
dataFields[index].originalOrder = index
end
-- ordena os campos do registro
table.sort( dataFields, sortByTag )
for index, dataField in ipairs( dataFields )
do
-- se os campos forem maior que 009, então gerarão indicadores
if tonumber( dataFields[index].tag ) > 9
then
dataFields[index].ind1 =
dataFields[index].data:sub( 1, 1 ):gsub( '[ _]', '#' )
dataFields[index].ind2 =
dataFields[index].data:sub( 2, 2 ):gsub( '[ _]', '#' )
end
-- se, também, os campos estiverem entre 010 e 830 (com exceção para 856),
-- criará a query string do link para o formulário e a sintaxe da
-- Predefinição Field
if
tonumber( dataFields[index].tag ) == 10 or
tonumber( dataFields[index].tag ) > 12 and
tonumber( dataFields[index].tag ) < 831 or
tonumber( dataFields[index].tag ) == 856
then
-- query string maker (part 2), Predefinição Field
fieldQueryString = fieldQueryString ..
'&Field[' .. index .. '][tag]=' .. dataField.tag ..
'&Field[' .. index .. '][ind1]=' .. dataField.ind1 ..
'&Field[' .. index .. '][ind2]=' .. dataField.ind2 ..
'&Field[' .. index .. '][data]=' .. mw.uri.encode( dataField.data:sub( 4 ), 'PATH' )
-- template string maker (part 2), Predefinição Field
fieldTemplates = fieldTemplates .. '{{Field' ..
'\n|tag=' .. dataField.tag ..
'\n|ind1=' .. dataField.ind1 ..
'\n|ind2=' .. dataField.ind2 ..
'\n|data=' .. dataField.data:sub( 4 ) ..
'\n}}\n'
end
end
if frame.args[1] == 'bib' or frame.args[1] == ''
then
-- inicializa as variáveis derivadas (registro bibliográfico)
-- líder
local recordStatus = leader:sub( 6, 6 )
local typeOfRecord = leader:sub( 7, 7 )
local bibliographicLevel = leader:sub( 8, 8 )
local encodingLevel = leader:sub( 18, 18 )
if encodingLevel == ' '
then
encodingLevel = ''
end
local descriptiveCatalogingForm = leader:sub( 19, 19 )
if descriptiveCatalogingForm == ' '
then
descriptiveCatalogingForm = ''
end
local multipartResourceRecordLevel = leader:sub( 20, 20 )
if multipartResourceRecordLevel == ' '
then
multipartResourceRecordLevel = ''
end
-- control field 008
local dateEnteredOnFile = controlField008:sub( 1, 6 )
local typeOfDate = controlField008:sub( 7, 7 )
local date1 = controlField008:sub( 8, 11 )
local date2 = controlField008:sub( 12, 15 )
local placeOfPublication = controlField008:sub( 16, 18 )
local illustrations = controlField008:sub( 19, 19 )
if illustrations == ' '
then
illustrations = ''
end
local targetAudience = controlField008:sub( 23, 23 )
if targetAudience == ' '
then
targetAudience = ''
end
local formOfItem = controlField008:sub( 24, 24 )
if formOfItem == ' '
then
formOfItem = 'r'
end
local natureOfContents = controlField008:sub( 25, 25 )
if natureOfContents == ' '
then
natureOfContents = ''
end
local governmentPublication = controlField008:sub( 29, 29 )
if governmentPublication == ' ' or governmentPublication == '0'
then
governmentPublication = ''
end
local conferencePublication = controlField008:sub( 30, 30 )
if conferencePublication == '0'
then
conferencePublication = ''
end
local festschrift = controlField008:sub( 31, 31 )
if festschrift == '0 '
then
festschrift = ''
end
local index = controlField008:sub( 32, 32 )
if index == '0' or index == ' '
then
index = ''
end
local literaryForm = controlField008:sub( 34, 34 )
if literaryForm == '0' or literaryForm == ' '
then
literaryForm = ''
end
local biography = controlField008:sub( 35, 35 )
if biography == ' '
then
biography = ''
end
local language = controlField008:sub( 36, 38 )
local modifiedRecord = controlField008:sub( 39, 39 )
if modifiedRecord == ' ' or modifiedRecord:match( '\r' )
then
modifiedRecord = ''
end
local catalogingSource = controlField008:sub( 40, 40 )
if catalogingSource == ' '
then
catalogingSource = ''
end
-- query string maker (part 1), Predefinição BibRecord
queryString =
'BibRecord[dateEnteredOnFile]=' .. dateEnteredOnFile ..
'&BibRecord[recordStatus]=' .. recordStatus ..
'&BibRecord[typeOfRecord]=' .. typeOfRecord ..
'&BibRecord[bibliographicLevel]=' .. bibliographicLevel ..
'&BibRecord[encodingLevel]=' .. encodingLevel ..
'&BibRecord[descriptiveCatalogingForm]=' .. descriptiveCatalogingForm ..
'&BibRecord[multipartResourceRecordLevel]=' .. multipartResourceRecordLevel ..
'&BibRecord[controlField006]=' .. controlField006 ..
'&BibRecord[controlField007]=' .. controlField007 ..
'&BibRecord[typeOfDate]=' .. typeOfDate ..
'&BibRecord[date1]=' .. date1 ..
'&BibRecord[date2]=' .. date2 ..
'&BibRecord[placeOfPublication]=' .. placeOfPublication ..
'&BibRecord[illustrations]=' .. illustrations ..
'&BibRecord[targetAudience]=' .. targetAudience ..
'&BibRecord[formOfItem]=' .. formOfItem ..
'&BibRecord[natureOfContents]=' .. natureOfContents ..
'&BibRecord[governmentPublication]=' .. governmentPublication ..
'&BibRecord[conferencePublication]=' .. conferencePublication ..
'&BibRecord[festschrift]=' .. festschrift ..
'&BibRecord[index]=' .. index ..
'&BibRecord[literaryForm]=' .. literaryForm ..
'&BibRecord[biography]=' .. biography ..
'&BibRecord[language]=' .. language ..
'&BibRecord[modifiedRecord]=' .. modifiedRecord ..
'&BibRecord[catalogingSource]=' .. catalogingSource ..
fieldQueryString
-- template string maker (part 1), Predefinição BibRecord
firstTemplate = '<pre>{{BibRecord\n' ..
'|dateEnteredOnFile=' .. dateEnteredOnFile .. '\n' ..
'|recordStatus=' .. recordStatus .. '\n' ..
'|typeOfRecord=' .. typeOfRecord .. '\n' ..
'|bibliographicLevel=' .. bibliographicLevel .. '\n' ..
'|encodingLevel=' .. encodingLevel .. '\n' ..
'|descriptiveCatalogingForm=' .. descriptiveCatalogingForm .. '\n' ..
'|multipartResourceRecordLevel=' .. multipartResourceRecordLevel .. '\n' ..
'|controlField006=' .. controlField006 .. '\n' ..
'|controlField007=' .. controlField007 .. '\n' ..
'|typeOfDate=' .. typeOfDate .. '\n' ..
'|date1=' .. date1 .. '\n' ..
'|date2=' .. date2 .. '\n' ..
'|placeOfPublication=' .. placeOfPublication .. '\n' ..
'|illustrations=' .. illustrations .. '\n' ..
'|targetAudience=' .. targetAudience .. '\n' ..
'|formOfItem=' .. formOfItem .. '\n' ..
'|natureOfContents=' .. natureOfContents .. '\n' ..
'|governmentPublication=' .. governmentPublication .. '\n' ..
'|conferencePublication=' .. conferencePublication .. '\n' ..
'|festschrift=' .. festschrift .. '\n' ..
'|index=' .. index .. '\n' ..
'|literaryForm=' .. literaryForm .. '\n' ..
'|biography=' .. biography .. '\n' ..
'|language=' .. language .. '\n' ..
'|modifiedRecord=' .. modifiedRecord .. '\n' ..
'|catalogingSource=' .. catalogingSource ..
'\n}}\n'
-- cria o botão para a importação do registro
formLink = frame:callParserFunction { name = '#formlink',
args = { 'form=BibRecord', 'link text=Importar registro',
'link type=post button', 'query string=' .. queryString } }
else
-- inicializa as variáveis derivadas (registro de autoridade)
-- líder
local recordStatus = leader:sub( 6, 6 )
local encodingLevel = leader:sub( 18, 18 )
if encodingLevel == ' '
then
encodingLevel = ''
end
local punctuationPolicy = leader:sub( 19, 19 )
if punctuationPolicy == ' ' or punctuationPolicy == '4'
then
punctuationPolicy = ''
end
-- control field 008
local dateEnteredOnFile = controlField008:sub( 1, 6 )
local directOrIndirectGeogSubdiv = controlField008:sub( 7, 7 )
if directOrIndirectGeogSubdiv == ' '
then
directOrIndirectGeogSubdiv = ''
end
local romanizationScheme = controlField008:sub( 8, 8 )
local languageOfCatalog = controlField008:sub( 9, 9 )
if languageOfCatalog == ' '
then
languageOfCatalog = ''
end
local kindOfRecord = controlField008:sub( 10, 10 )
local descriptiveCatalogingRules = controlField008:sub( 11, 11 )
local subjectHeadingSystem = controlField008:sub( 12, 12 )
local typeOfSeries = controlField008:sub( 13, 13 )
local numberedOrUnnumberedSeries = controlField008:sub( 14, 14 )
if numberedOrUnnumberedSeries == ' '
then
numberedOrUnnumberedSeries = ''
end
local headingUseMainOrAddedEntry = controlField008:sub( 15, 15 )
local headingUseSubjectAddedEntry = controlField008:sub( 16, 16 )
if headingUseSubjectAddedEntry == ' '
then
headingUseSubjectAddedEntry = ''
end
local headingUseSeriesAddedEntry = controlField008:sub( 17, 17 )
if headingUseSeriesAddedEntry == ' '
local typeOfSubjectSubdivision = controlField008:sub( 18, 18 )
then
if typeOfSubjectSubdivision == ' '
headingUseSeriesAddedEntry = 'b'
then
end
typeOfSubjectSubdivision = ''
local typeOfSubjectSubdivision = controlField008:sub(18, 18)
end
if typeOfSubjectSubdivision == ' '
local typeOfGovernmentAgency = controlField008:sub( 29, 29 )
then
if typeOfGovernmentAgency == ' '
typeOfSubjectSubdivision = ''
then
end
typeOfGovernmentAgency = ''
local typeOfGovernmentAgency = controlField008:sub(29, 29)
end
if typeOfGovernmentAgency == ' '
local referenceEvaluation = controlField008:sub( 30, 30 )
then
if referenceEvaluation == ' '
typeOfGovernmentAgency = ''
then
end
referenceEvaluation = ''
local referenceEvaluation = controlField008:sub(30, 30)
end
if referenceEvaluation == ' '
local recordUpdateInProcess = controlField008:sub( 32, 32 )
then
local undifferentiatedPersonalName = controlField008:sub( 33, 33 )
referenceEvaluation = ''
if undifferentiatedPersonalName == ' '
end
then
local recordUpdateInProcess = controlField008:sub(32, 32)
undifferentiatedPersonalName = ''
local undifferentiatedPersonalName = controlField008:sub(33, 33)
end
if undifferentiatedPersonalName == ' '
local levelOfEstablishment = controlField008:sub( 34, 34 )
then
if levelOfEstablishment == ' '
undifferentiatedPersonalName = ''
then
end
levelOfEstablishment = ''
local levelOfEstablishment = controlField008:sub(34, 34)
end
if levelOfEstablishment == ' '
local modifiedRecord = controlField008:sub( 39, 39 )
then
if modifiedRecord == ' ' or modifiedRecord:match( '\r' )
levelOfEstablishment = ''
then
end
modifiedRecord = ''
local modifiedRecord = controlField008:sub(39, 39)
end
if modifiedRecord == ' ' or modifiedRecord:match('\r')
local catalogingSource = controlField008:sub( 40, 40 )
then
if catalogingSource == ' '
modifiedRecord = ''
then
end
catalogingSource = ''
local catalogingSource = controlField008:sub(40, 40)
end
if catalogingSource == ' '
-- query string maker (part 1), Predefinição AutRecord
then
queryString =
catalogingSource = ''
'AutRecord[dateEnteredOnFile]=' .. dateEnteredOnFile ..
end
'&AutRecord[recordStatus]=' .. recordStatus ..
-- query string maker (part 1), Predefinição AutRecord
'&AutRecord[encodingLevel]=' .. encodingLevel ..
queryString =
'&AutRecord[punctuationPolicy]=' .. punctuationPolicy ..
'&AutRecord[directOrIndirectGeogSubdivdateEnteredOnFile]=' .. directOrIndirectGeogSubdivdateEnteredOnFile ..
'&AutRecord[romanizationSchemerecordStatus]=' .. romanizationSchemerecordStatus ..
'&AutRecord[languageOfCatalogencodingLevel]=' .. languageOfCatalogencodingLevel ..
'&AutRecord[kindOfRecordpunctuationPolicy]=' .. kindOfRecordpunctuationPolicy ..
'&AutRecord[descriptiveCatalogingRulesdirectOrIndirectGeogSubdiv]=' .. descriptiveCatalogingRulesdirectOrIndirectGeogSubdiv ..
'&AutRecord[subjectHeadingSystemromanizationScheme]=' .. subjectHeadingSystemromanizationScheme ..
'&AutRecord[typeOfSerieslanguageOfCatalog]=' .. typeOfSerieslanguageOfCatalog ..
'&AutRecord[numberedOrUnnumberedSerieskindOfRecord]=' .. numberedOrUnnumberedSerieskindOfRecord ..
'&AutRecord[headingUseMainOrAddedEntrydescriptiveCatalogingRules]=' .. headingUseMainOrAddedEntrydescriptiveCatalogingRules ..
'&AutRecord[headingUseSubjectAddedEntrysubjectHeadingSystem]=' .. headingUseSubjectAddedEntrysubjectHeadingSystem ..
'&AutRecord[headingUseSeriesAddedEntrytypeOfSeries]=' .. headingUseSeriesAddedEntrytypeOfSeries ..
'&AutRecord[typeOfSubjectSubdivisionnumberedOrUnnumberedSeries]=' .. typeOfSubjectSubdivisionnumberedOrUnnumberedSeries ..
'&AutRecord[typeOfGovernmentAgencyheadingUseMainOrAddedEntry]=' .. typeOfGovernmentAgencyheadingUseMainOrAddedEntry ..
'&AutRecord[referenceEvaluationheadingUseSubjectAddedEntry]=' .. referenceEvaluationheadingUseSubjectAddedEntry ..
'&AutRecord[recordUpdateInProcessheadingUseSeriesAddedEntry]=' .. recordUpdateInProcessheadingUseSeriesAddedEntry ..
'&AutRecord[undifferentiatedPersonalNametypeOfSubjectSubdivision]=' .. undifferentiatedPersonalNametypeOfSubjectSubdivision ..
'&AutRecord[levelOfEstablishmenttypeOfGovernmentAgency]=' .. levelOfEstablishmenttypeOfGovernmentAgency ..
'&AutRecord[modifiedRecordreferenceEvaluation]=' .. modifiedRecordreferenceEvaluation ..
'&AutRecord[catalogingSourcerecordUpdateInProcess]=' .. catalogingSourcerecordUpdateInProcess ..
'&AutRecord[undifferentiatedPersonalName]=' .. undifferentiatedPersonalName ..
fieldQueryString
'&AutRecord[levelOfEstablishment]=' .. levelOfEstablishment ..
-- template string maker (part 1), Predefinição AutRecord
firstTemplate = '<pre>{{&AutRecord\n[modifiedRecord]=' .. modifiedRecord ..
'&AutRecord[catalogingSource]=' .. catalogingSource ..
'|dateEnteredOnFile=' .. dateEnteredOnFile .. '\n' ..
fieldQueryString
'|recordStatus=' .. recordStatus .. '\n' ..
-- template string maker (part 1), Predefinição AutRecord
'|encodingLevel=' .. encodingLevel .. '\n' ..
firstTemplate = '<pre>{{AutRecord\n' ..
'|punctuationPolicy=' .. punctuationPolicy .. '\n' ..
'|directOrIndirectGeogSubdivdateEnteredOnFile=' .. directOrIndirectGeogSubdivdateEnteredOnFile .. '\n' ..
'|romanizationSchemerecordStatus=' .. romanizationSchemerecordStatus .. '\n' ..
'|languageOfCatalogencodingLevel=' .. languageOfCatalogencodingLevel .. '\n' ..
'|kindOfRecordpunctuationPolicy=' .. kindOfRecordpunctuationPolicy .. '\n' ..
'|descriptiveCatalogingRulesdirectOrIndirectGeogSubdiv=' .. descriptiveCatalogingRulesdirectOrIndirectGeogSubdiv .. '\n' ..
'|subjectHeadingSystemromanizationScheme=' .. subjectHeadingSystemromanizationScheme .. '\n' ..
'|typeOfSerieslanguageOfCatalog=' .. typeOfSerieslanguageOfCatalog .. '\n' ..
'|numberedOrUnnumberedSerieskindOfRecord=' .. numberedOrUnnumberedSerieskindOfRecord .. '\n' ..
'|headingUseMainOrAddedEntrydescriptiveCatalogingRules=' .. headingUseMainOrAddedEntrydescriptiveCatalogingRules .. '\n' ..
'|headingUseSubjectAddedEntrysubjectHeadingSystem=' .. headingUseSubjectAddedEntrysubjectHeadingSystem .. '\n' ..
'|headingUseSeriesAddedEntrytypeOfSeries=' .. headingUseSeriesAddedEntrytypeOfSeries .. '\n' ..
'|typeOfSubjectSubdivisionnumberedOrUnnumberedSeries=' .. typeOfSubjectSubdivisionnumberedOrUnnumberedSeries .. '\n' ..
'|typeOfGovernmentAgencyheadingUseMainOrAddedEntry=' .. typeOfGovernmentAgencyheadingUseMainOrAddedEntry .. '\n' ..
'|referenceEvaluationheadingUseSubjectAddedEntry=' .. referenceEvaluationheadingUseSubjectAddedEntry .. '\n' ..
'|recordUpdateInProcessheadingUseSeriesAddedEntry=' .. recordUpdateInProcessheadingUseSeriesAddedEntry .. '\n' ..
'|undifferentiatedPersonalNametypeOfSubjectSubdivision=' .. undifferentiatedPersonalNametypeOfSubjectSubdivision .. '\n' ..
'|levelOfEstablishmenttypeOfGovernmentAgency=' .. levelOfEstablishmenttypeOfGovernmentAgency .. '\n' ..
'|modifiedRecordreferenceEvaluation=' .. modifiedRecordreferenceEvaluation .. '\n' ..
'|recordUpdateInProcess=' .. recordUpdateInProcess .. '\n' ..
'|catalogingSource=' .. catalogingSource ..
'|undifferentiatedPersonalName=' .. undifferentiatedPersonalName .. '\n' ..
'\n}}\n'
'|levelOfEstablishment=' .. levelOfEstablishment .. '\n' ..
-- cria o botão para a importação do registro
'|modifiedRecord=' .. modifiedRecord .. '\n' ..
formLink = frame:callParserFunction{ name = '#formlink',
'|catalogingSource=' .. catalogingSource ..
args = { 'form=AutRecord', 'link text=Importar registro',
'\n}}\n'
'link type=post button', 'query string=' .. queryString } }
-- cria o botão para a importação do registro
end
formLink = frame:callParserFunction { name = '#formlink',
-- retorna todos os valores para a predefinição {{MARCimporter}}
args = { 'form=AutRecord', 'link text=Importar registro',
return formLink, firstTemplate, fieldTemplates, lastTemplate
'link type=post button', 'query string=' .. queryString } }
end
-- retorna todos os valores para a predefinição {{MARCimporter}}
return formLink, firstTemplate, fieldTemplates, lastTemplate
end
 
return p