Comments (5)
Is this still an issue with the latest release?
from alex.
Yes.
$ alex Issue71.x
alex: Prelude.head: empty list
$ alex --version
Alex version 3.2.4, (c) 2003 Chris Dornan and Simon Marlow
(2003
should be either dropped or updated.)
from alex.
The following call to head
throws the error:
https://github.com/simonmar/alex/blob/f2c343b9b20ff9508f482e87528ef486c55b9f86/src/DFAMin.hs#L58
from alex.
The remaining problem is that if the lexer definition contains nullable tokens and the Alex gets stuck (on EOF or no just no possible DFA-transition), it outputs an infinite sequence of the nullable tokens. This happens because alex_scan_tkn
gladly returns accepts of length 0.
The problem can be fixed by checking for the scanned length here:
https://github.com/simonmar/alex/blob/0198f7387a8f31fd8a7ff3efe453edbb00cba4fb/templates/GenericTemplate.hs#L155
and if the length is still 0, output AlexNone
instead of accept or skip.
Why should a lexer not return tokens of length 0? Well, because the number of these token sequences is not determined, it could output any number of such tokens at any point. Thus, outputting 0 of such tokens only is a sensible (and the only sensible) choice.
from alex.
I'd say this issue is fixed now and can be closed.
from alex.
Related Issues (20)
- New release HOT 3
- alex 3.2.7 fails to parse definitions which can pass alex 3.2.6 HOT 13
- How to build `alex` from git sources? Instructions in `README.md` are broken. HOT 3
- Agda-style Lexing HOT 3
- website (bad link) HOT 10
- Makefile (examples) HOT 2
- UTF-8 and text 2.0 HOT 2
- spelling of `DFS.GForrest` HOT 3
- Make `haskell.org/alex` redirect to `haskell-alex.readthedocs.io` ? HOT 6
- `alexSetUserState`/`alexGetUserState` with `monadUserState-bytestring` wrapper HOT 6
- Alex PVP violation? HOT 2
- Function `Util.brack` is not used
- Functions `Sort.isort` and `Sort.insrt` not used HOT 2
- Is module DFS really needed? HOT 2
- Deriving Ord for AlexPosn HOT 4
- upgrading problems with Cabal HOT 3
- Alex generates code that cannot be compiled by GHC 9.2 HOT 13
- Add option `--numeric-version`
- Unused `import Data.Char` in `basic-bytestring` lexer HOT 2
- Alex generates code with unqualified imports, e.g. of `GHC.Exts`
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from alex.