Self-Contained Version Controlled Plain Text

=> I read this status about "a file format to store multiple versions of a plain text file in the same file", and it's one of those ideas that just inspires me instantly.

Why? Well... The use-case is pretty limited, but that also means a solution can be simple and tailored exactly to it. As Valenoern puts it:

there are a number of people out there who don't seem to like git and prefer other version control systems, and I like the notion of a simple revision format which doesn't lock you into a specific version control program

I have a few ideas for implementation, depending on your specific goals.

First of all, if the files are meant to be entirely readable by humans without "correct tools" I'd suggest that each version is represented in full and only separated by special tags. Something like this:

---20210308T12:07:31Z
This is the first version of this file.
(Actually the second, but I just made a short addendum)
---20210301T08:51:02Z
This is the first version of this file.

It's arguably the simplest, and my first goto. If you want to use existing libraries to parse it you might benefit from using XML markup of some kind instead. This would allow easier addition of metadata, as well. Either your own format:



  
    20210308T12:07:31Z
    This is the first version of this file.
(Actually the second, but I just made a short addendum)
  
  
    20210301T08:51:02Z
    This is the first version of this file.
  

Or even just Atom:



  The intended filename here
  Maybe the same as 'id', mostly?
  20210308T12:07:31Z
  
    Björn Wärmedal
    bjorn.warmedal@gmail.com
  
  
  
  
    2
    This could be a 'commit comment'
    
      Björn Wärmedal
      bjorn.warmedal@gmail.com
    
    20210308T12:07:31Z
    This is the first version of this file.
(Actually the second, but I just made a short addendum)
  
  
    1
    First version
    
      Someone Else
      someone@else.com
    
    20210301T08:51:02Z
    This is the first version of this file.
  

Depending on how much tooling you're willing to tailor and use, and which information you want in meta-data, you may want to save deltas instead of the full content for each revision. This would definitely be preferable to large files with many small changes, but we're talking plain text here. You may save more room and CPU by just compressing the file.

Disclaimer: I haven't run the above atom through a validator. It could be that I've missed some mandatory element, or got the timestamp wrong. Generally validators will want the entry id tags to reference a URL, but having a unique identifier of other kind there is not uncommon.

-- CC0 ew0k, 2021-03-26

Proxy Information
Original URL
gemini://warmedal.se/~bjorn/posts/self-contained-version-controlled-plain-text.gmi
Status Code
Success (20)
Meta
text/gemini; lang=en
Capsule Response Time
115.587478 milliseconds
Gemini-to-HTML Time
0.415504 milliseconds

This content has been proxied by September (ba2dc).