Mercurial > ~dholland > hg > ag > index.cgi
view doc/admin/todo-large.txt @ 9:60b08b68c750
Switch to static inline as an expedient build fix.
Should probably set this up with working C99 inline but for the moment
I don't have the energy.
author | David A. Holland |
---|---|
date | Mon, 30 May 2022 23:56:45 -0400 |
parents | 13d2b8934445 |
children | f9e4689b837d |
line wrap: on
line source
Large todo items This file describes the bigger and more involved projects or undertakings that can or should be done on AnaGram moving forward. ------------------------------------------------------------ USER INTERFACE - Build a new user interface that's based on a non-legacy toolkit. This is the most pressing issue and almost nothing else in this file should be undertaken until the new user interface is under control. - Conflict diagnostics. AG's conflict diagnostics are already far better than yacc's; however, they are still opaque to most users and could be improved a good deal. There are a number of areas for improvement: (1) presentation; we have a GUI, we can and should use it to draw diagrams and arrows and whatnot, and not limit ourselves to rows of text like AG 1.x had to. We should show a sample input that leads to the conflict, and bracket it on the bottom showing the rules and reductions that go one way and on the top showing the rules and reductions that go the other. (2) common forms; a lot of conflicts arise from common mistakes and common issues. We should have a set of pattern-matching rules to identify and report these common forms, and link to explanations and fix suggestions in the help. - Better crossreferencing of tables. The right-button popup menu for auxiliary windows is fine, but you ought to get something useful by default if you click (or double-click?) on things directly. Also, there are more useful crossreferences than currently exist. - Better presentation of tables. To really take advantage of the information in the various tables and windows AG provides, you have to understand quite a bit about how AG works. This should not be necessary. Also, the AG 2.x user interface is a direct conceptual port of the text-based AG 1.x user interface. It's still fundamentally based on lines of text. This is not necessary and could be improved a great deal without undue difficulty. - Command-line version. agcl should print basic conflict diagnoses as well as the warning and error messages, so one doesn't have to fire up the GUI every time one makes a silly editing mistake. - It would be nice if when you opened the Configuration Parameters window you could change the settings for the current run. (Has to be for the current run, because saving changes is not remotely practical.) - Multiple grammars. In the long run it would be nice to be able to have multiple grammars loaded at the same time and be able to shuffle tokens between them when using File Trace or Grammar Trace. This would allow easier testing and debugging of projects that use multiple interacting grammars, or that use AG to implement communication protocols. Unfortunately, this is *not* trivial. ------------------------------------------------------------ PROGRAMMING INTERFACE - Language support. There's been talk of Java support for AG for quite a while. It would be nice to actually *do* it. Beyond that, other languages which would be useful or interesting to support include Perl, Python, Ruby, Cyclone, OCaml... you name it. Right now adding any of these would be nontrivial; however, after the first couple adding another should be relatively straightforward. Note also that as many of these languages aren't syntactically compatible with either C or AnaGram, we will need to design a way to put the syntax and the accompanying code in separate files. - Configuration support for multiple languages. There also needs to be a better and more systematic configuration mechanism for choosing output language and output language dialect. - Output name. It's nice for makefiles to be able to know what the output files will be named. Unfortunately, there's no good way to do this that I can think of, because it depends on the output language. If anyone has a brilliant idea, please share it. - Include files and/or a module system for grammars. Common bits of grammar have to be cut and pasted all the time. Some mechanism to avoid this would be nice. (Some users have used cpp or m4 to preprocess AG input; this works but it's awfully ugly.) - Reading yacc files. There's been a yacc-to-AnaGram converter around for a long time, but it's not fully functional and hasn't ever been officially released or supported. (It originally got hung up because yacc's input language is defined, at least in some references, in a way that makes the grammar LR(2). This is not important now, if it ever was; bison, for example, does not accept the offending constructs.) It might be better at this point to merge the functionality directly into AnaGram so it can read (and build) .y files directly. Finding a clean version of y2ag is the first order of business. Note: the y2ag.syn in the test suite is mangled in some fashion and not a good place to start. ------------------------------------------------------------ BUILD - Dumping UI. To improve the regression testing I'd like to have a fake user interface that takes *all* the data normally available in the various windows and tables and just dumps it to stdout. - Parser equivalence. One of the problems with the test suite is that sometimes an internal change will, perfectly legitimately, permute elements in the various parse tables, causing huge test diffs that need to be inspected by hand. It would be nice to figure out how to either (1) canonicalize the tables so this doesn't happen, or (2) write some kind of munging script that automatically validates and suppresses these changes. (Obviously, (1) is better, but I'm not sure it's feasible.) - Figure out how to do coverage checking in the test suite. (This includes coverage of AG code, coverage of the code sections from the engine definition, and also coverage of config parameters that affect code generation.) ------------------------------------------------------------ INTERNALS - Character sets. Right now, AG is limited to 16-bit-wide character sets, which is a problem as Unicode is now 24 bits wide. Also, the internal handling of case folding and so on is totally inadequate and needs a general revamp. And keywords only work with 8-bit character sets. - Lexemes and disregard. I'd like to clean up the implementation of disregard whitespace and lexemes. It has a sound theoretical foundation, but you wouldn't know it from the existing code. (To be fair, the existing code was severely constrained by DOS memory issues.) - LR(k) grammars. Jerry was talking about this before he died; unfortunately, I don't think anyone knows exactly what he had in mind... - Regexp keywords. Keyword recognition is already a string search process; there's no real reason it couldn't be extended to include regular expression matching. The catch of course is how you preserve any useful notion of soundness in the grammar. - Merge duplicate conflicts. A lot of times the same conflict will happen with a whole pile of tokens. Right now these are all generated and displayed independently; they should really be folded together. - Fix the code generator. The code generator is an ugly mess and needs rationalization. - Interactive completions. Many command-driven programs nowadays allow you to push a key (often tab) to get a list of legal inputs based on what's been typed so far. If input is being handled by an AG parser, you can in theory run the parser on the input so far, inspect the state, and get a list of legal tokens, which you can then use to give the user a context-sensitive list of possible things to type. This is, however, not something that you can possibly code up yourself by interfacing to AG, at least not in any pleasant way, so AG ought to provide support. ------------------------------------------------------------ MANUAL AND DOCS - The manual index is in a parlous state. It was badly mauled by conversion from WP to LaTeX and needs to be rebuilt with reference to the old WP version. - Merge the various articles of shared text that are found in the help, the manual, the miscellaneous documentation, the web page, and/or elsewhere too. These should all be maintained from one master source. The most urgent instances are "sbb" (the syntactic building blocks, found in the examples directory, the misc documentation, and the manual) and the Glossary. Note that the text in the help system is often slightly different from the corresponding text in the manual on purpose, because it plays a different role and has a somewhat different narrative context. (However, the various copies of the Glossary should all be the same. These include: the manual appendix, the glossary web page, the copy in the misc docs, and the one in the help.) - The manual needs a discussion of Unicode, wchar_t, wide characters, multibyte characters, and all that. Of course, first we have to actually *work* with such constructs... (All four listed terms need to appear in the index, too.) - Somewhere in the manual there should be a section to tell you what to do for interactive use. The most important issue, if each input line isn't a complete parse, is how to make sure it won't try to look ahead past the end of a line when the user expects the line to be complete and the program to do something. - Somewhere in the manual there should be a section to tell you what to do for a parser that runs indefinitely and only exits at program shutdown, like you might use to handle a network protocol in a daemon. - It would be nice to have a section or appendix that describes common sources of conflicts and what to do about them. Such constructs include: - if-then-else (text already exists) - repeated repetitions (a -> b..., b -> c...) - poisoning lookahead by bad nesting of productions (I had an example involving trying to distinguish whitespace and comments at too high a level) - sequences of nondelimited tokens (a -> identifier...) - generalize the previous to the full lexer model - ... ------------------------------------------------------------ EXAMPLES - Update the examples to use agclib1 (as seen in XIDEK) instead of oldclasslib.