S-выражения - один из удобных способов анализа и хранения данных.
Задача:Напишите простой читатель / парсер для S-Expressions, который обрабатывает строки с кавычками и без кавычек, целые числа и поплавки.
Функция должна читать одно, но вложенное S-выражение из строки и возвращать его как (вложенный) массив.
Новые строки и другие пробелы могут игнорироваться, если они не содержатся в цитируемой строке.
" () " Внутри цитируемых строк не интерпретируются, а рассматриваются как часть строки.
Обработка скрытых кавычек внутри строки необязательна; таким образом " (foo" bar) "может рассматриваться как строка" foo "bar " или как ошибка.
Для этого читатель не должен распознавать « \ » для экранирования, но должен, кроме того, распознавать номера, если язык имеет соответствующие типы данных.
Обратите внимание, что за исключением « (» « » (« \ », если поддерживается escaping) и пробелов нет специальных символов. Все остальное разрешено без кавычек.
Читатель должен уметь читать следующий ввод
((данные «котируемые данные» 123 4.5) (данные (! @ # (4.5) "(более" "данные)")))
и превратить его в родную структуру данных. (см. реализации Pike , Python и Ruby для примеров встроенных структур данных.)
((data "quoted data" 123 4.5) (data (!@# (4.5) "(more" "data)")))and turn it into a native data structure. (See the Pike, Python and Ruby implementations for examples of native data structures.)
parseSexpr
is a function.
testString: assert(typeof parseSexpr === 'function');
- text: parseSexpr('(data1 data2 data3)')
should return ['data1', 'data2', 'data3']
testString: assert.deepEqual(parseSexpr(simpleSExpr), simpleSolution);
- text: parseSexpr('(data1 data2 data3)')
should return an array with 3 elements.
testString: assert.deepEqual(parseSexpr(basicSExpr), basicSolution);
```