“Just write,” they said, “It doesn’t matter what tool you use…”
Writing is the hard part, everything else is just formatting. You could scratch your novel into a wall with a rock, or use a modal command line text editor, the point is: you should be focusing on writing. Your tool should be a secondary concern.
…says the README file trying to sell me on a writing tool…
Right? I’m losing the sale before the customer even drove the car, but Giterary isn’t really selling something (it happens to free, open source software, which bring together other, powerful, freely available tools).
So, what does Giterary do as a writing tool? Giterary is a tool that suggests a better way to work, helps you if it can, concentrating on making the hard things easy, and keeping the simple stuff simple. You can just write if you want, but it brings together powerful tools that let you manage complexity down the road.
“A first novel won’t be as much work as you think. It will be much more. ”
Consider the scale of a novel. For the most part, published writing projects weigh in at around ~50,000 to 100,000 words (and often more). They can take years to write, after which they tend to require extensive editing, re-reads, re-writes, and whatever requisite iterations it takes to make a better product.
Now consider a machine with ~50,000 to 100,000 moving parts. A novel-machine that takes a human’s attention as input and outputs compelling plot, worthwhile characters, and subtlety. As the engineer/author, it’s your job to fabricate the machine parts, construct them correctly, and maybe apply a layer of paint. Sure, it works for you the first time you run it, but when your best friend takes a whirl it seizes midway past the second-stage turbine spooling. You walk slowly through the smoldering wreckage. Your friend is alright. Your pride is not. And you forgot to take notes the first time around.
The point is: if writing a novel is hard, maintaining a novel is complex. The latter of which is overlooked when just writing is a primary concern.
Giterary offers a set of nice things to write and maintain a novel, managing complexity at both ends of the process, and hopefully without you noticing. How does it do this? Well…
When programmers are lazy, everyone benefits.
Computer programmers look at your machine with 100,000 moving parts and laugh. Software weighs in at tens of thousands to a few million lines of source code. They don’t even bother to count the words, were there even words to count.
They laugh because they solved the management of that complexity a long time ago. Lo, and they chanted in their sing-song way, “A hundred people need to work on something with at least a million lines of code. And they should all be able to work at the same time, and be able to detect and communicate their changes efficiently, and maintain detailed histories of their changes, and gracefully solve conflicts, should they arise.” And thus it was so, and they’ve been improving on this concept ever since.
If your novel were like the programmers’ source code, you’d be able to manage your novel with these all-powerful tools of the programmer gods. The thing is, your novel is source code, much like its words are part of your novel-machine. It’s just a matter of formatting.
That’s nice. So what does this do, again?
Giterary suggests you write your chapters in Markdown syntax (but you don’t absolutely have to). Markdown is a text-based format that lets you do complex formatting by just writing, and largely ignoring things like formatting, markup, and tedium. It also extends Markdown’s functionality by allowing textual annotations and “wikilinking” between your files, similar to Wikipedia, letting you build a web of references to information you need.
Giterary puts these text-based files into a hierarchical directory structure of your choosing, and manages these files using a Gitgit repository. The Gitgit repository stores all versions of all files, and Giterary wraps around the Gitgit repository to let you easily see information about your files, down to showing you when you swapped out “she said” with “she said, languorously.”
The killer feature, though, is Git’s ability to act as a distributed database. You can take the entirety of your Giterary instance, clone it to any computer, make changes, and then push them back. Need to work offline on the plane, but submit your changes once you’re back in civilization? Not a problem.
(Side note: It can also do things like show you dictionary word counts, auto-generating tables of contents, dialog highlighting, document partitioning, document collections, auto-saving drafts, etc., and other common word processing features, but those are pretty run-of-the-mill, so you can discover those for yourself.)
Nobody has time for that noise, I just want to write. Why would I need that?
Three reasons:
You will forget about something, or, forget why you did something.
I barely remember last week. Yesterday’s already fuzzy around the edges. Things I wrote a year ago might as well have been written by a different person, with different hopes and dreams. And while I can’t talk to that person, using Giterary will let me see what that stranger did, and if they provided notes, see what they were thinking.
Giterary helps you talk to the past, and leave messages for the future.
It may not only ever be you making the changes.
You never thought about that, did you, hot shot? Well, yeah, I guess maybe you did. The possibility of multiple authors isn’t unheard of, but that pales in comparison to the most common case: you will eventually need to turn your things over to an editor.
You can submit a massive, monolithic Word document via email and hope Track Changes does the job. But what do you do while you’re waiting for them to send your document back? What if you’re still working on a chapter? How do you maintain which is the “master” copy, and which is for edits? Do you copy-paste your edits, like the beasts of the wild?
If you feel shame, that’s okay. It means the healing can begin. Giterary provides an intelligent system to manage change, and to do so immediately, letting you maintain a sane workflow for you, your potential co-authors, and your editors.
Unless you’re part of the Otaku-Neckbeard-Hacker data integrity enthusiast crowd, you’ll probably manage you data badly.
So, do you write a bit while you’re at work on your netbook? On the train, or on the bus? Do you sometimes back up your work to your external drive at home? (whispering) Do you sometimes forget to do so?
That’s fine. We’re human. Sometimes we forget. But every computing device has an internal clock, counting down relentlessly to the moment it craters, or is simply stolen. Having multiple copies of your work ensures the work lost is minimal. A problem arises, though: you have two backup copies, but you can’t tell which is the latest version.
With a Gitgit repository, you can simply ask. And you can synchronize changed between the two, even if changes were made at different points in time. And you can do it with freely available tools.
While storing metadata for changes to wording may seem like information overload, you can ignore it until you absolutely need it. The nice thing about Giterary is that it gives you a place to do these things while letting you focus on just writing.
Why would I need to organize my information this way?
Sure, everyone has their own way to deal with their information. But there are a few nice things to the way Giterary deals.
If everything is a text file, there are no surprises.
Text is text is text. Files are files are files. Directories are, well, a bit more complicated, but you see what I mean. File formats change, features come and go, and registration keys get lost. Text files are the most basic way to store your information, and frankly, are hard to screw up. Most important: vast arrays of editing tools are available (far grander than Notepad), and are available everywhere you will ever turn on a computing device. You will never have to hunt down a copy of proprietary software that supports your file format (Word), nor worry that other programs won’t support the features of the one you wrote in.
You maybe should be dividing up your novel anyway…
Just saying. Why wouldn’t you try to divide out the pieces of your work into separate files? Or organize your reference documents and glossaries and appendices in a structured way?
The reason I can think of for not doing so is because eventually you’ll have to stitch them back together. This is easy for a computer to do, so why can’t you work on your smaller pieces, then tell the computer to put them together when you’re done? Giterary supports this, both in partitioning out documents into smaller files, as well as automatically creating “collection” files to stitch them back together. Plus, you can modify your collections to change the order of your documents without changing the underlying documents.
A wiki lets you create information and an interface to it at the same time
This sounds strange, but you see it every time you visit Wikipedia. The content of a document is well and good, but it’s the links within a document that lead you to the most interesting things. With a series of wikilinks, you can turn a normal document into a navigational structure. You can build chapter lists, character sheets, TODO lists, glossaries, indexes, whatever you want. And you can do it using the same syntax you use to write your story.
For the Otaku-Neckbeard-Hacker crowd…
I’m not a writer, though I once had hopes and dreams. I am, instead, a programmer who likes words and how they go together. I know writers, though, and editors, too. Though my fervor for the nerdier portions of this project burns bright, their practicality and intolerance tempered Giterary into a finer steel. That said, there are still some nerdy things.
Minimal system requirements
The application requires PHP, a web server to serve the PHP scripts, and the Gitgit executable. Nothing else. Everything is self-contained.
A simple codebase. The kind you’d like to start with, but not have to build yourself.
Do you like learning an entirely new object model every time you need to modify a project? Me neither. Use of OO is limited, preferring a series of functions that wrap around Gitgit CLI functionality and display logic. Need complex, stateful logic for something? Great. I hope my functions help.
There’s a simplistic templating engine, a few performance tracking modules, and some file caching, but nothing special. Everything is PHP, Javascript, and CSS.
Edit how you want, Gitgit how you want.
Don’t like the Giterary editor? Prefer Notepad++? TextMate? SublimeText? Vim? Emacs? Something with an even greater sense of vague technological elitism? Great. Edit with that. I won’t be sad. Edit locally, and upload via your Gitgit client. That is, whichever of the dozens of beautiful, full-featured Gitgit clients roaming the wild. There is a git post-receive hook that will keep your web application up-to-date, but you can do with it as you like.
That’s the idea, anyway…
Thanks for reading. Happy writing!