169 похожих чатов

В FsLexYacc есть два варианта передачи стейта, через мутабельный стейт

и через рекурсию. Первый вариант у меня работает, но не подходит из-за проблем с мультипоточкой. Второй вариант видимо я как-то неправильно использую, так как у меня он заходит в него один раз, и в следующий вызов не передается стейт. Выглядит так:


rule read section =
parse
| "---"name+"---" { printfn "1. %A" section; read (lexeme lexbuf) lexbuf }
| whitespace { printfn "2. %A" section; read section lexbuf }
| newline { printfn "3. %A" section; read section lexbuf }
| '=' { EQUALITY }


Кейс у меня такой:

---types---

some data

---functions---

another some data

---etc---

...



Т.е. я хочу при считывании находить “секцию” types, functions, etc, и хранить ее значение в section

Как поченить?

16 ответов

17 просмотров
Nikolay-M Автор вопроса

Ну что, у нас по FsLexYacc нет специалистов?

Nikolay-M Автор вопроса
Vladislav K
Зачем тебе оно

https://youtu.be/EHDmhm2iXqE?t=19

Nikolay-M Автор вопроса
Vladislav K
Зачем тебе оно

Да по приколу решил распарсить TL язык

Nikolay M
Да по приколу решил распарсить TL язык

А зачем там лекс якк, его ж так собрать можно

Nikolay-M Автор вопроса
Vladislav K
А зачем там лекс якк, его ж так собрать можно

Можно, но LexYacc более подходящая тулза кмк, на будущее полезно будет иметь знания

Nikolay M
Да по приколу решил распарсить TL язык

Ты же читал отчёты тех, кто этим занимался до тебя? И что им это не пригодилось? И что у нас в tdsharp уже есть kinda parser?

Nikolay M
Можно, но LexYacc более подходящая тулза кмк, на б...

Я не знаю что из этого лучше, но глянул бы ещё fparsec. Но, думаю, ты в курсе?

Nikolay-M Автор вопроса
Nikolay M
Почему не пригодилось? 🤔

Потому что там схема совершенно наркоманская, и не заводится без костылей.

Nikolay-M Автор вопроса
Nikolay M
Наркоманская в плане синтаксиса TL?

В плане самой организации. Она не вся нужна.

Мне кажется ещё проще спарсить как есть и забить хуй с построением грамматик и прочего

Nikolay-M Автор вопроса
Vladislav K
Мне кажется ещё проще спарсить как есть и забить х...

Да там на самом деле из пишется, я бы не сказал что какое-то сложное. Просто язык позволяющий более абстрактно писать правила парсинга. Это так же тип зачем F#, если можно то же самое на C# написать)

Похожие вопросы

Обсуждают сегодня

Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Коллеги, добрый вечер. Создаю коллекцию от TFPGMap, ключ - перечисление, значение - целое. Нужно отсортировать коллекцию по значению. Как это можно сделать?
Kirill Filippenok
11
Скажи а ты когда этот канал создавал ты уже дельфи не любил, или это со временем пришло?
Роман Лях (rgreat)
18
Привет, такой вопросик появился кажется ли вам что Rust слишком сложный/строгий для высокоуровневого программирования и слишком "безопасный"/строгий для низкоуровневого?
Крокант
10
Всем привет! Использую кастомное модальное диалоговое окошко, все по классике - mrOK, mrCancel как ModalResult. Однако есть нюанс - в главной форме есть универсальный обработч...
Олег Гранишевский
20
Карта сайта