Dream big: your ideal composition / typesetting software
 
            I'll start the discussion with some features I have long desired, in vain, in ID:
A paradigm of design and composition derived from the way book designers traditionally notate specifications. A platform dedicated to typography, not graphic design. A tool made for serious typographers and compositors who design and typeset books and other printed materials. Perhaps an interface inspired by the design sketches of, say, Richard Eckersley.
Contextual/conditional paragraph styling. E.g., if paragraph A is styled as a subhead, paragraph B will automatically begin full-out. The ability to write sophisticated chains of reasoning for automating par styling.
Some built-in understanding of the parts of a scholarly or literary text: subheads, extracts, notes, dialogue, stage directions, citations … the ability to place a marker in a text saying, e.g., EXTRACT STARTS HERE, and have all subsequent pars style accordingly until an END EXTRACT marker. Nested markers for nested extracts, subheads within extracts, etc.
A sophisticated hyphenation engine. The ability to assign multiple ranked dictionaries: e.g., check for a word in dictionary A; if not found, consult dictionary B, and so on. Controls for limiting the breaking of already hyphenated words, limiting hyphenation / line breaks within the last # chars of a paragraph, or the first/last # of chars within a quotation or parenthetical.
The ability to write cross-font kerning pairs for, e.g., kerning roman delimiters against ital letters.
A choice regarding how letterforms align against margins: (a) align to sidebearings; (b) align to rightmost/leftmost point on letterform glyph; (c) hang punctuation (with options); (d) optical margin.
An option to justify by "counter reshaping": stretch/condense the counterforms of glyphs without changing their stroke weight. Would be used very subtly in conjunction with word spacing and letterspacing.
Dynamic sidenotes.
Some sort of protection of the text itself. Quark now touts new AI tools for rewriting text, demonstrating a complete misunderstanding of their market. Typographers in ordinary circumstances may not alter their copy at all. It would be nice to have software that understands this and at least flags it as a potential issue or asks "Are you sure?". The difference between typesetting software and word processing software.
Color-coded highlighting of paragraph styles, character styles, GREP styles.
An interface for setting tables that mimics that of early dedicated typesetting machines, not spreadsheet logic.
Integrated math typesetting. Integrated charts and graphs. Ideally, integrated music engraving, or at least support for placing music directly from a music engraving program.
Native support for all the many kinds of finessing I routinely do with GREP styles; see other threads.
Native support for ME and CJK scripts. A composition engine designed from the ground up for global text.
A way to define a span of text and do something to it, such as put it in a box, add a diagonal strikethrough, add a horizontal brace over it, add a syllable marking for prosody. A way to say START BRACE HERE and END BRACE HERE.
Letterspacing applied to a range of text, but only within the range, not after the last character.
Baseline grids per page, spread, textblock.
An interface that uses traditional typographic terminology.
Tools for imposition and prepress.
No bloat. No AI. No tools for video or web stuff. MAYBE XML export or some such thing for e-books. But fundamentally a tool for composing printed text.
A program that is not web-based and does not require a subscription.
This is all just off the top of my head right now. Undoubtedly more to come. In the meantime, join the fray!
Josh
Comments
- 
            (You can see some of my requests and complaints regarding ID here.)0
- 
            Support for negative indents.
 Support for mortising drop caps.
 Support for hanging numbers for lists or notes in the margin.1
- 
            Support for centering poetry on the longest line.
 Generally, support for the kinds of things professional compositors do routinely that currently require workarounds because their tools weren't designed for them.0
- 
            An open, human-readable, Unicode text-based native file format like SILE, beneath an interface something like LyX. The file format independent of the tools to manipulate it.0
- 
            A font menu that doesn't just show all the fonts on your system, but lets you specify what fonts are relevant to the document and shows just those.
 OpenType features like all small caps accessible in the main interface.3
- 
            A distinction between galleys and pages. The ability to view text as a long continuous galley or as a series of made-up pages. The ability to write nuanced rules for breaking text into pages.0
- 
            The ability to display a language-specific glyphs palette. For instance, if I am typesetting something in Norwegian, I would pull up the Norwegian "typecase" and get a curated selection of glyphs specific to that language.0
- 
            A way to simulate the show-through from the other side of the printed leaf. Useful for checking backing up. Generally, more features that recognize and reflect the physicality of printed books.1
- 
            Joshua Langman said:The ability to display a language-specific glyphs palette. For instance, if I am typesetting something in Norwegian, I would pull up the Norwegian "typecase" and get a curated selection of glyphs specific to that language.I guess you mean character set by “glyphs palette”.The functionality you describe I’d rather see met by a new generation of keyboards. Because fiddling about in glyph palettes (or character selection tool windows – the same thing) is neither productive nor user-friendly.I imagine a keyboard which offers a) one-klick selection of Norwegian, Spanish, Urdu, Mandarin, Devanagari, Frisian, Bulgarian … you name it; b) keys which instantly display all the relevant characters for a chosen language/orthography.0
- 
            A way to specify a cascading sequence of fallback fonts for missing characters: If a character is not supported in the text font, use the character from font A; if it's not in font A, use font B … with custom sizing and alignment for each fallback font. Also, the ability to specify fonts for specific characters: primes from font X, angle brackets from font Y. The ability to save such a "composite font" for use across documents.
 Alignment options for verse: (1) center on longest line; (2) center on average line length; (3) center on median line length …
 Built-in support for the niceties required by common style guides. For instance, how is it that the most widely used professional typesetting software in the world cannot break URLs according to Chicago style? (I'm rather proud of my approach to this, but all GREP-based methods, including mine, are imperfect.)
 The ability to recognize figure calls etc in the text to assist the typesetter in ensuring that figures are placed appropriately.
 Are there any software engineers on here? I do not have this skill, but if someone who does wants to pursue making a new piece of software, I would very seriously consider teaming up with them and tackling this for real.
 1
- 
            A way to build the placement of text on the page into a paragraph style. So, for instance, chapter-opening sinkage could be a property of the first-par style or the chapter title style and would not require resizing the text frame.
 A built-in understanding of constructs like parts, chapters, sections, so the software could accept instructions like "chapters begin recto only" or "chapter opening drops to fifth text line."0
- 
            I've been working on my dream layout application for the past year. It's based on baseline and Swiss grids from the start. You have the ability to define the body style and it will generate headings, captions etc based on the baseline grid.
 I too am largely skeptical of AI. However, my app does use LLMs to populate premade templates if users want to.
 I've been careful when creating the file format so developers will easily be able to programatically create documents.
 I've decided to keep it browser based since I eventually want it to be a collaborative editor like Figma.
 ME and Chinese is supported from the start since my app uses Harfbuzz.
 Output is currently just pdf.
 I'm still a considerable way off a v1.0.0 but I'm getting closish to have a working MVP.
 @Joshua Langman I may reach out to you at some point. The typographic features you're after may be a bit too intense for my 80% product but we can see. 
 2
- 
            SILE (and sometimes LaTeX, Typst, and other FOSS) developer here.It would be very easy to do *some* things better than InDesign, but bringing up an all new GUI project to the minimum breadth of features to viably use as a replacement is quite an ask. Not impossible, but a big bite.I've done quite a bit of thinking about how programmatic typesetting engines (LaTeX, SILE, Typst, Speedata, etc.) could interface better with designer-friendly GUIs. One of the big overhauls I'm working on for SILE (targeted at v0.16.0) is organizing the internals of frames, fonts, and language in less of an ad-hoc way that is only friendly to direct code access and more of a structured module registry with a regular predictable API that would be much easier to eventually bolt a GUI onto.On the other hand, I also think your approach of a "do everything" app won't be the best plan. I would separate concerns a bit through the workflow so that the on disk file format is one thing, the rules controlling the typesetting engine behavior are another, the interface(s) used to edit the above two things are another, the actual build process is another, and finally tooling for the review process is another. That isn't to say one GUI couldn't eventually wrap all of those, but I think tackling them as separate problems with an eventual way to control the end-to-end workflow is more realistic.As a FOSS developer mostly working on this in spare time (with some of my day-job involving actual book publishing, hence the interest) I can say that it would probably take at least one fill time and a couple part time people to really make such a project even get off the ground, but there is *so much room for improvement* left on the table by all existing workflows, both commercial and open source.In my mind one of the major problems in publishing is the non-synchronous stages that a manuscript currently forced to go through where assorted writers, editors, typesetters, designers, and producers are all isolated both in time and tooling. My goal is to have a whole ecosystem of tooling so that everybody has access to tooling that suites their role that also interacts with the whole process in a way that the project can stay flexible. If the author spots a typo after the book is typeset and the cover designed, they should be able to fix it in the same software they did the initial authoring in, and that change should easily propagate the the final production files and the resulting changes should be trackable and reviewable from the perspective of each role with no extra work involved or redoing any steps of their workflow from scratch.4
- 
            Followup ...My vision for what needs to happen in the typesetting & publishing space as far as GUI's should work is much more akin to what Graphite is doing for non-destructive editing of graphics. Re-inventing a better InDesign or Quark is not just as a GUI editor is not of that much interest to me. I don't just want a new GUI to be a better Scribus that could actually challenge InDesign. I would like something more like Graphite that completely changes the paradigm so that GUI typesetting can play nice with also editing the typesetting process as code and be reproducible/reusable/editable even while the inputs keep changing.
 1
- 
            A sophisticated hyphenation engine.(Emoji of a person dacing shaking arms and crying of agreement.) As of now, in theory, we can install Hunspell packages for languages not included in the default installation. Actually, trying to do so nullifies the whole spellchecking feature. 0
- 
            Many thanks to Marc, alerque, and others for your thoughtful comments and perspectives. I so appreciate your insight. Keep it coming.
 Alerque — I'm not sure about allowing an author to tweak the production files for a book. There are reasons that authors are seldom allowed access to those files. But I'd be more than happy to discuss and perhaps be persuaded.
 In the meantime, I continue …
 A way to sort fonts by support for a given character. Enter a codepoint to view all fonts on the system that support it.0
- 
            A way to sort fonts by support for a given character. Enter a codepoint to view all fonts on the system that support it.I have two tools in my toolbox that do this, one is part of fontconfig, the other is distributed in TeXLive $ fc-list :charset=1F4F9 /usr/share/fonts/TTF/Symbola.ttf: Symbola:style=Regular /usr/share/fonts/joypixels/JoyPixels.ttf: JoyPixels:style=Regular /usr/share/fonts/noto/NotoSansSymbols2-Regular.ttf: Noto Sans Symbols 2:style=Regular /usr/share/fonts/OTF/Symbola.otf: Symbola:style=Regular /home/caleb/.local/share/fonts/TTF/NotoColorEmoji.ttf: Noto Color Emoji:style=Regular $ albatross U+1F4F9 __ __ __ .---.-.| | |--.---.-.| |_.----.-----.-----.-----. | _ || | _ | _ || _| _| _ |__ --|__ --| |___._||__|_____|___._||____|__| |_____|_____|_____| Unicode glyph with code points [1F4F9] mapping to [📹] (AND search) ┌─────────────────────────────────────────────────────────────────────────────┐ │ Font name │ ├─────────────────────────────────────────────────────────────────────────────┤ │ JoyPixels │ │ Noto Color Emoji │ │ Noto Sans Symbols 2 Regular │ │ Symbola │ └─────────────────────────────────────────────────────────────────────────────┘Of course you'll say you aren't looking for a CLI tool, you want it to be right at your finger tips in a GUI. Well I can make a GUI that does just that, or better yet add it into some open source GUI that already handles font browsing and would mix and match with other purposes. And yes, it could go in a typesetting GUI too, but you're quickly approaching the reason all-purpose GUIs grow into monstrosities: the tools you consider handy and want at your finger tips are useless clutter to the next guy. 0
- 
            The ability to substitute one character/glyph for another, without affecting the underlying text encoding. The ability to include this surface-level substitution in a paragraph style. This feature alone would be invaluable. One of the largest limitations of GREP styles is that they cannot swap one codepoint for another.
 The ability to define a span of text and rotate or mirror it without breaking it out into a separate text frame.
 @mwichary— This thread seems like something you might be interested in. Care to join us? (We haven't properly met, but I'm a fan of your work.)
 @alerque — it's not necessarily that I want to see a UI with lots of buttons and icons for all of these functions. I could be very happy with a sort of hybrid UI / command line / tagging interface. But I would need the syntax to be typographer-friendly and maybe display a WYSIWYG preview of whatever is going on in the code. Your screenshot scares me. Book designers traditionally think in terms of drafting table, ruler, T-square, pica pole, not code.0
- 
            A tool that treats space characters in a manner appropriate to typesetting, not word processing. A tool that will automatically disregard or strip out all leading spaces (never kosher in typesetting) and all consecutive word spaces (that's what en quads and other characters are for). The ability to set space characters like quads to breaking or non-breaking. To allow "fixed spaces" and quads to stretch for justification, or not.0
- 
            Calling Matthew Butterick. I don't know how to reach you, but maybe mentioning your name will do the trick.
 Also Marcin Wichary, as noted above.
 And I have directed Peter Kahrel, the preeminent InDesign script writer, to this thread.
 Welcome to the party!0
- 
            I wanted to invite Charles Ellertson to comment, but some research revealed that he died several years ago. He was a true career-long compositor and one of the most insightful voices I know of regarding typesetting and technology. His writings are very much worth reading; see, for instance, his essay in Rich Hendel's Aspects of Contemporary Book Design. When I imagine someone who might appreciate the dream software that is in my head, it is he.0
- 
            
 I think Caleb's point is that you sound like you're asking for all the font- and typesetting- related things to be in one single application, which would mean the application should be full of kinds of bells and whistles, and that naturally makes it more cluttered and therefore harder to use. I don't see a reason why a typesetting application should tell you which fonts contain which codepoints; that is something that can be done better by a dedicated tool.Joshua Langman said:@alerque — it's not necessarily that I want to see a UI with lots of buttons and icons for all of these functions. I could be very happy with a sort of hybrid UI / command line / tagging interface.
 In fact, you could even divide up your wish list into "editor mode", "layout mode" and "preview mode", and see it as (at least) three separate applications which talk to each other. That would reduce the interface clutter and also make the scope of implementation more manageable.1
- 
            
 This would be great. But even just a feature to hide system fonts from the font menu would be great.Joshua Langman said:A font menu that doesn't just show all the fonts on your system, but lets you specify what fonts are relevant to the document and shows just those.
 1
- 
            Rename "baseline shift" to "vertical shift," and add a "horizontal shift." Make them operate in relative units, not absolute values. Horizontal shift would be for those times when you just want to nudge something over without affecting the characters after it. Currently this requires two kerning adjustments; a horizontal shift would accomplish it with only one adjustment, and be easier to tweak.0
- 
            Joshua Langman said:Calling Matthew Butterick. I don't know how to reach you, but maybe mentioning your name will do the trick.I don’t think just mentioning Matthew will likely draw his attention. I suspect his energies are directed elsewhere, being focused on litigation against AI companies right now. He does have an account on TD, so you could try private-messaging him directly. Also he does have one of his email contacts publicly displayed here: https://docs.racket-lang.org/quad/ (And yes, it is sad that we lost Charles a few years ago.) 0
- 
            I would settle for one that didn’t “upgrade” continually, disorienting me.
 In fact, I still do the majority of my design work (FontLab, InDesign, Photoshop) on a 2014 iMac with similar vintage apps, despite being online with more recent tech.
 For things such as negative indents (outdents?) there are workarounds; adding another feature to accomplish this would, from my perspective, just make the UI more cumbersome.
 Part of the problem is that I am a generalist, and if I don’t use a particular app frequently it becomes strange, whether or not it has changed.
 1
- 
            Decotype ACE and TeX.0
- 
            Guide labels. This has always been missing from ID. The ability to label guides and have the label show up on rollover or as a tag outside the trim. Would be especially useful when preparing files to be used by someone else.2
- 
            What are these "design sketches of, say, Richard Eckersley."? I found https://typographica.org/typography-books/a-grammar-of-typography-classical-book-design-in-the-digital-age/ but still not sure what you mean                        0 I found https://typographica.org/typography-books/a-grammar-of-typography-classical-book-design-in-the-digital-age/ but still not sure what you mean                        0
- 
            Dave — I don't have any images handy to post right now, and unfortunately I can't find any online. Among a certain crowd, Eckersley, who for most of his career was an in-house book designer for the University of Nebraska Press, is considered the preeminent designer of scholarly books of the modern (postmodern) era. He initiated something of a renaissance in book typography for academic publishing. He was also part of the last generation to design books with a ruler and pencil on a drafting table, and his layouts — also known as tissues — resemble dimensioned architectural drawings. Of course, many other designers at the time and before produced similar layout drawings. When I envision an interface inspired by this work, I think of something resembling a blank sheet of tissue paper on which establishing the type area, margins, and guides is as easy as drawing a pencil line. Note also that this approach, contrary to the logic of existing design applications, works from the inside out: rather than setting the margins first and defining the type area by subtraction, this approach begins with defining the type area, establishing the margins by the space that's left over. This distinction is reflected in the language used by designers to write specs for compositors: traditionally, only the top and gutter margins are specified; the other margins are implied by these two plus the width and depth of the textblock.
 The two best books I know of on the craft of book design as practiced by Eckersley et al. are both by Richard Hendel: On Book Design and Aspects of Contemporary Book Design. They both include images of hand-drawn layouts.0
Categories
- All Categories
- 46 Introductions
- 3.9K Typeface Design
- 485 Type Design Critiques
- 560 Type Design Software
- 1.1K Type Design Technique & Theory
- 654 Type Business
- 852 Font Technology
- 29 Punchcutting
- 519 Typography
- 119 Type Education
- 323 Type History
- 77 Type Resources
- 112 Lettering and Calligraphy
- 33 Lettering Critiques
- 79 Lettering Technique & Theory
- 549 Announcements
- 91 Events
- 114 Job Postings
- 170 Type Releases
- 173 Miscellaneous News
- 276 About TypeDrawers
- 54 TypeDrawers Announcements
- 120 Suggestions and Bug Reports










