Мне нужно разобрать строку ^borrow$ ^\$500$
в список [borrow, $500]
. Грамматика, которую я написал до сих пор,
:- use_module(library(dcg/basics)).
write_list([]).
write_list([H|T]) :- atom_codes(S, H), write(S), nl, write_list(T).
% Grammar.
tags([Tag|Rest]) --> string(_), tag(Tag), tags(Rest).
tags([]) --> string(_).
tag(Tag) --> "^", tag_contents(Tag), "$".
tag_contents(Tag) --> string(Tag).
Что работает, когда у меня нет \$
внутри токена:
?- phrase(tags(T), "^pisica$ ^catel$"), write_list(T).
pisica
catel
?- phrase(tags(T), "^borrow$ ^\\$500$"), write_list(T).
borrow
\
Каков наилучший способ разбора таких экранированных последовательностей с помощью DCG Prolog?