|
|
|
|
|
by zerothehero
5662 days ago
|
|
> So, the only reason you would now use yacc is parsing speed. "speed" means a couple different things. Someone might say the only reason you would use C++ rather than Python is speed -- i.e. you can always get within a constant factor with Python. Ignoring other aspects of the languages, let's call that true. But Russ Cox is saying that you would also use yacc when you want a O() bound on the parsing algorithm (a linear algorithm). That is, the technique they advocate will produce parsers more than a constant factor slower than yacc. Frankly I don't understand their rebuttal at all. The rebuttal is that it doesn't matter for practical purposes? That doesn't sound like computer science to me. And practically speaking, it does matter, because plenty of people write exponential time regexps and don't know it, and it will blow up in their face on large input. |
|