Left-recursive grammars in operator precedence parsing2019 Community Moderator ElectionRecursive grammars in FParsecParsing method arguments with FParsecHow to handle left recursion in FParsecParsing numbers in FParsecParse case-insensitive operators using OperatorPrecedenceParserParsing “x y z” with the precedence of multiplyParsing int or float with FParsecHow to insert an indentation check into the operator precedence parser?Confusion as to how to integrate OperatorPrecedenceParser with mineParsing in to a recursive data structure

Are Wave equations equivalent to Maxwell equations in free space?

Why aren't there more gauls like Obelix?

The need of reserving one's ability in job interviews

Dukha vs legitimate need

Linear Combination of Atomic Orbitals

ESPP--any reason not to go all in?

Preparing as much as possible of a cake in advance

What is the oldest European royal house?

School performs periodic password audits. Is my password compromised?

Should I use HTTPS on a domain that will only be used for redirection?

PTIJ: Mouthful of Mitzvos

What can I do if someone tampers with my SSH public key?

Quitting employee has privileged access to critical information

Why do phishing e-mails use faked e-mail addresses instead of the real one?

Paper published similar to PhD thesis

Learning to quickly identify valid fingering for piano?

If nine coins are tossed, what is the probability that the number of heads is even?

Should we avoid writing fiction about historical events without extensive research?

How do we objectively assess if a dialogue sounds unnatural or cringy?

The past tense for the quoting particle って

Did Amazon pay $0 in taxes last year?

The Key to the Door

In the world of The Matrix, what is "popping"?

Is there a math equivalent to the conditional ternary operator?



Left-recursive grammars in operator precedence parsing



2019 Community Moderator ElectionRecursive grammars in FParsecParsing method arguments with FParsecHow to handle left recursion in FParsecParsing numbers in FParsecParse case-insensitive operators using OperatorPrecedenceParserParsing “x y z” with the precedence of multiplyParsing int or float with FParsecHow to insert an indentation check into the operator precedence parser?Confusion as to how to integrate OperatorPrecedenceParser with mineParsing in to a recursive data structure










0















I have a left recursive grammar. My AST looks something like:



...
and Expr = BinaryExpr of BinaryExpr
and BinaryExpr = Expr * BinaryOperator * Expr
and BinaryOperator = Plus
...


I was planning on using the operator precedence parser for this, for example:



let exprOpp = new OperatorPrecedenceParser<Expr,unit,unit>()
let pBinaryExpr = exprOpp.ExpressionParser
exprOpp.TermParser <- pExpr

let consBinExpr op x y = (x, op, y) |> BinaryExpr
exprOpp.AddOperator(InfixOperator("+", ws, 1, Associativity.Left, (consBinExpr Plus)))


where pExpr is a parser for Expr.



The left recursion causes a stack overflow. I was wondering whether there was a particular FParsec-way of dealing with this while still using the OperatorPrecedenceParser?



Thanks!



EDIT:



The issue may be coming from the fact that pExpr forwards all calls to another parser pExprRef.



let pExpr, pExprRef = createParserForwardedToRef()


and after the operator precedence parser, the reference is defined:



do pExprRef :=
choice [pBinaryExpr, <other-parsers...>];









share|improve this question
























  • Your example would never terminate; you'd need another option in Expr that represents a single value. As it is, your example types are infinitely recursive.

    – rmunn
    yesterday















0















I have a left recursive grammar. My AST looks something like:



...
and Expr = BinaryExpr of BinaryExpr
and BinaryExpr = Expr * BinaryOperator * Expr
and BinaryOperator = Plus
...


I was planning on using the operator precedence parser for this, for example:



let exprOpp = new OperatorPrecedenceParser<Expr,unit,unit>()
let pBinaryExpr = exprOpp.ExpressionParser
exprOpp.TermParser <- pExpr

let consBinExpr op x y = (x, op, y) |> BinaryExpr
exprOpp.AddOperator(InfixOperator("+", ws, 1, Associativity.Left, (consBinExpr Plus)))


where pExpr is a parser for Expr.



The left recursion causes a stack overflow. I was wondering whether there was a particular FParsec-way of dealing with this while still using the OperatorPrecedenceParser?



Thanks!



EDIT:



The issue may be coming from the fact that pExpr forwards all calls to another parser pExprRef.



let pExpr, pExprRef = createParserForwardedToRef()


and after the operator precedence parser, the reference is defined:



do pExprRef :=
choice [pBinaryExpr, <other-parsers...>];









share|improve this question
























  • Your example would never terminate; you'd need another option in Expr that represents a single value. As it is, your example types are infinitely recursive.

    – rmunn
    yesterday













0












0








0








I have a left recursive grammar. My AST looks something like:



...
and Expr = BinaryExpr of BinaryExpr
and BinaryExpr = Expr * BinaryOperator * Expr
and BinaryOperator = Plus
...


I was planning on using the operator precedence parser for this, for example:



let exprOpp = new OperatorPrecedenceParser<Expr,unit,unit>()
let pBinaryExpr = exprOpp.ExpressionParser
exprOpp.TermParser <- pExpr

let consBinExpr op x y = (x, op, y) |> BinaryExpr
exprOpp.AddOperator(InfixOperator("+", ws, 1, Associativity.Left, (consBinExpr Plus)))


where pExpr is a parser for Expr.



The left recursion causes a stack overflow. I was wondering whether there was a particular FParsec-way of dealing with this while still using the OperatorPrecedenceParser?



Thanks!



EDIT:



The issue may be coming from the fact that pExpr forwards all calls to another parser pExprRef.



let pExpr, pExprRef = createParserForwardedToRef()


and after the operator precedence parser, the reference is defined:



do pExprRef :=
choice [pBinaryExpr, <other-parsers...>];









share|improve this question
















I have a left recursive grammar. My AST looks something like:



...
and Expr = BinaryExpr of BinaryExpr
and BinaryExpr = Expr * BinaryOperator * Expr
and BinaryOperator = Plus
...


I was planning on using the operator precedence parser for this, for example:



let exprOpp = new OperatorPrecedenceParser<Expr,unit,unit>()
let pBinaryExpr = exprOpp.ExpressionParser
exprOpp.TermParser <- pExpr

let consBinExpr op x y = (x, op, y) |> BinaryExpr
exprOpp.AddOperator(InfixOperator("+", ws, 1, Associativity.Left, (consBinExpr Plus)))


where pExpr is a parser for Expr.



The left recursion causes a stack overflow. I was wondering whether there was a particular FParsec-way of dealing with this while still using the OperatorPrecedenceParser?



Thanks!



EDIT:



The issue may be coming from the fact that pExpr forwards all calls to another parser pExprRef.



let pExpr, pExprRef = createParserForwardedToRef()


and after the operator precedence parser, the reference is defined:



do pExprRef :=
choice [pBinaryExpr, <other-parsers...>];






f# fparsec






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited yesterday







falkmar

















asked yesterday









falkmarfalkmar

11




11












  • Your example would never terminate; you'd need another option in Expr that represents a single value. As it is, your example types are infinitely recursive.

    – rmunn
    yesterday

















  • Your example would never terminate; you'd need another option in Expr that represents a single value. As it is, your example types are infinitely recursive.

    – rmunn
    yesterday
















Your example would never terminate; you'd need another option in Expr that represents a single value. As it is, your example types are infinitely recursive.

– rmunn
yesterday





Your example would never terminate; you'd need another option in Expr that represents a single value. As it is, your example types are infinitely recursive.

– rmunn
yesterday












0






active

oldest

votes











Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55022064%2fleft-recursive-grammars-in-operator-precedence-parsing%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























0






active

oldest

votes








0






active

oldest

votes









active

oldest

votes






active

oldest

votes















draft saved

draft discarded
















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55022064%2fleft-recursive-grammars-in-operator-precedence-parsing%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Save data to MySQL database using ExtJS and PHP [closed]2019 Community Moderator ElectionHow can I prevent SQL injection in PHP?Which MySQL data type to use for storing boolean valuesPHP: Delete an element from an arrayHow do I connect to a MySQL Database in Python?Should I use the datetime or timestamp data type in MySQL?How to get a list of MySQL user accountsHow Do You Parse and Process HTML/XML in PHP?Reference — What does this symbol mean in PHP?How does PHP 'foreach' actually work?Why shouldn't I use mysql_* functions in PHP?

Compiling GNU Global with universal-ctags support Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Data science time! April 2019 and salary with experience The Ask Question Wizard is Live!Tags for Emacs: Relationship between etags, ebrowse, cscope, GNU Global and exuberant ctagsVim and Ctags tips and trickscscope or ctags why choose one over the other?scons and ctagsctags cannot open option file “.ctags”Adding tag scopes in universal-ctagsShould I use Universal-ctags?Universal ctags on WindowsHow do I install GNU Global with universal ctags support using Homebrew?Universal ctags with emacsHow to highlight ctags generated by Universal Ctags in Vim?

Add ONERROR event to image from jsp tldHow to add an image to a JPanel?Saving image from PHP URLHTML img scalingCheck if an image is loaded (no errors) with jQueryHow to force an <img> to take up width, even if the image is not loadedHow do I populate hidden form field with a value set in Spring ControllerStyling Raw elements Generated from JSP tagds with Jquery MobileLimit resizing of images with explicitly set width and height attributeserror TLD use in a jsp fileJsp tld files cannot be resolved