Вот и все (как разделить ваш список на правила):
getRules([], _Delimiter, []) :- !.
getRules(List, Delimiter, [Rule|Rules]) :-
getRule(List, Delimiter, Rule, Rest),
getRules(Rest, Delimiter, Rules).
Использование запрошенного вами getRule:
getRule([], _Delimiter, [], []) :- !.
getRule([Delimiter|Rest], Delimiter, [], Rest) :- !.
getRule([Item|List], Delimiter, [Item|Rule], Rest) :-
getRule(List, Delimiter, Rule, Rest).
Возможность вызова с помощью
?- getRule(['S', =, a, 'S', b, ;, 'S', =, c, ;], ;, Rule, Rest).
Возвращает
Rule = ['S', =, a, 'S', b],
Rest = ['S', =, c, ;].
И основной:
?- getRules(['S', =, a, 'S', b, ;, 'S', =, c, ;], ;, Rules).
возвращает
Rules = [['S', =, a, 'S', b], ['S', =, c]].
Вы можете явно использовать жесткий код;если хотите!
Пожалуйста, спросите, нужно ли вам какое-либо объяснение кода.
Я добавил модификацию, обсуждаемую в комментариях, и удалил спойлеры, так как вы ее прочитали.
Вот еще одна вещь, которую вы просили:
divideRules(Rules, PureRules) :-
divideRules_(Rules, Temp),
append(Temp, PureRules).
divideRules_([], []) :- !.
divideRules_([Rule|Rules], [PureRule|PureRules]) :-
divideRule(Rule, PureRule),
divideRules_(Rules, PureRules).
divideRule(Rule, PureRule) :-
getRule(Rule, ::=, Left, Right),
append([Left, [::=]], NewLeft),
getRules(Right, '|', PureRight),
maplist(append(NewLeft), PureRight, PureRule).
Вот мое предположение, но я не могу запустить интерпретатор пролога, поэтому он не проверен:
grammarize([], []) :- !.
grammarize([[Left, ::=|Right]|PureRules], [grammar(Left, Right)|Grammars]) :-
grammarize(PureRules, Grammars).