Expressões S são uma maneira conveniente de analisar e armazenar dados.
Tarefa:Escreva um leitor / analisador simples para S-Expressions que lida com strings, inteiros e flutuantes entre aspas e sem aspas.
A função deve ler uma única S-Expression aninhada de uma string e retorná-la como uma matriz (aninhada).
As novas linhas e outros espaços em branco podem ser ignorados, a menos que estejam contidos em uma cadeia de caracteres entre aspas.
“ () ” Strings entre aspas não são interpretadas, mas tratadas como parte da string.
Manipular citações com escape dentro de uma string é opcional; assim, “ (foo bar) ” talvez tratada como uma string “ foo” bar ”, ou como um erro.
Para isso, o leitor não precisa reconhecer “ \ ” para escapar, mas deve, além disso, reconhecer números se a linguagem tiver tipos de dados apropriados.
Observe que, com a exceção de “ ()” ”(“ \ ”se houver suporte a escape) e espaço em branco, não há caracteres especiais, e qualquer outra coisa é permitida sem aspas.
O leitor deve poder ler a seguinte entrada
((dados "dados cotados" 123 4.5) (dados (! @ # (4.5) "(mais" "dados)")))
e transformá-lo em uma estrutura de dados nativa. (veja as implementações de Pike , Python e Ruby para exemplos de estruturas de dados nativas.)
parseSexpr
é uma função.
testString: 'assert(typeof parseSexpr === "function", "parseSexpr
is a function.");'
- text: 'parseSexpr("(data1 data2 data3)")
deve retornar ["data1", "data2", "data3"] ")'
testString: 'assert.deepEqual(parseSexpr(simpleSExpr), simpleSolution, "parseSexpr("(data1 data2 data3)")
should return ["data1", "data2", "data3"]");'
- text: 'parseSexpr('(data1 data2 data3)')
deve retornar um array com 3 elementos ")'
testString: 'assert.deepEqual(parseSexpr(basicSExpr), basicSolution, "parseSexpr("(data1 data2 data3)")
should return an array with 3 elements");'
```