Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[CIR][IR] Refactor ScopeOp assembly format #311

Merged
merged 6 commits into from
Dec 6, 2023

Conversation

sitio-couto
Copy link
Collaborator

@sitio-couto sitio-couto commented Nov 15, 2023

Stack from ghstack (oldest at bottom):

This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
cir.scopes with a return value.

This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

[ghstack-poisoned]
bcardosolopes pushed a commit that referenced this pull request Nov 17, 2023
…310)

Stack from [ghstack](https://github.com/ezyang/ghstack) (oldest at
bottom):
* #314
* #313
* #312
* #311
* __->__ #310

The `shouldPrintTerm` and `checkBlockTerminator` were replaced in favor
of `omitRegionTerm` and `ensureRegionTerm` respectively. The first is
essentially the same method but simplified. The latter was refactored to
do only two things: check if the terminator omission of a region is
valid and, if so, insert the omitted terminator into the region.

The simplifications mostly leverage the fact that we only omit empty
yield values in a single-block region.
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

[ghstack-poisoned]
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

[ghstack-poisoned]
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

[ghstack-poisoned]
Copy link
Member

@bcardosolopes bcardosolopes left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

[ghstack-poisoned]
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

[ghstack-poisoned]
sitio-couto added a commit that referenced this pull request Dec 6, 2023
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: #311
@sitio-couto sitio-couto merged commit 9a3383c into gh/sitio-couto/2/base Dec 6, 2023
sitio-couto added a commit that referenced this pull request Dec 6, 2023
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: #311
@sitio-couto sitio-couto deleted the gh/sitio-couto/2/head branch December 6, 2023 14:16
lanza pushed a commit that referenced this pull request Dec 20, 2023
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: #311
lanza pushed a commit that referenced this pull request Jan 29, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: #311
lanza pushed a commit that referenced this pull request Mar 23, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: #311
eZWALT pushed a commit to eZWALT/clangir that referenced this pull request Mar 24, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: llvm#311
lanza pushed a commit that referenced this pull request Apr 29, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: #311
lanza pushed a commit that referenced this pull request Apr 29, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: #311
eZWALT pushed a commit to eZWALT/clangir that referenced this pull request Apr 29, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: llvm#311
lanza pushed a commit that referenced this pull request Apr 29, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: #311
pysuxing pushed a commit to pysuxing/llvm-project that referenced this pull request Jul 17, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: llvm/clangir#311
Hugobros3 pushed a commit to shady-gang/clangir that referenced this pull request Oct 2, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: llvm#311
keryell pushed a commit to keryell/clangir that referenced this pull request Oct 19, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: llvm#311
lanza pushed a commit that referenced this pull request Nov 5, 2024
This simplifies and modularizes the assembly format for ScopeOp by
using the Tablegen assembly description and a new custom printer/parser
that handles regions with omitted terminators.

It also fixes an issue where the parser would not correctly handle
`cir.scopes` with a return value.

ghstack-source-id: c5b9be705113c21117363cb3bd78e19d133c3fc5
Pull Request resolved: #311
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants