Lunduke
News • Science & Tech
The True History of vi (and vim)
How a broken pascal compiler, a 300 baud modem, and a 1970s terminal helped create the (in)famous text editor.
August 08, 2023
post photo preview

Earlier this week (August 3rd, 2023), Bram Moolenaar, creator and long-time maintainer of Vim passed away.  The following article -- originally published earlier this year -- has been updated to include a brief history of Vim.


Everyone who has spent any time with UNIX or Linux knows about vi — the ubiquitous text editor that seems to have existed since the dawn of time itself.

Likewise, there are better than even odds that the first time you ran vi (or vim, which is based on vi)… you got stuck and couldn’t figure out how to exit the gosh-darned program.

Don’t feel ashamed. It’s a right of passage.

Your first experience with vi / vim looked something like this. You know it’s true.

What follows is the story of that much loved — and much hated — text editor. Where it came from, who created it, how it was almost very different, and why on earth it is the way it is.

It all started with ed

As with so many stories in computer history, the tale of vi begins long before vi, itself, ever comes into existence.

Our story begins in August of 1969, at AT&T Bell Labs.

There, Ken Thompson was beginning work on what would become UNIX. At that time it was a barebones system, running on a PDP-7, consisting of only three little components: an assembler, a shell… and a simple text editor known as “ed”.

Ed, which is (obviously) short for “editor”, is a line-mode text editor — meaning you edit one line of text at a time. A process which can drive any person to the brink of madness.

Being a line editor, ed doesn’t look like much. So here’s a screenshot of the ed manpage.

Historical Side Note: The design of ed was inspired by QED (which is short for “Quick EDitor"“) — a similar line-mode text editor created for the Berkeley Time Sharing System in the mid-1960s — and was re-written for MULTICS (the precursor to UNIX) by Ken Thompson. So it seems natural that, when Thompson needed a basic text editor for UNIX… he would base it on the design of QED, which he was already so familiar with.

Ed quickly became the defacto line-mode text editor for UNIX — remaining a part of the POSIX standard to this very day.

A wild Pascal appears

A few years later, in 1975, Ken Thompson went to Berkeley (the University of California) and built a Pascal compiler for UNIX.

There, his Pascal compiler came to the attention of a student at UC Berkeley… Bill Joy. The man who would go on to create vi.

From Bill Joy’s 1999 interview with Linux Magazine:

“What happened is that Ken Thompson came to Berkeley and brought this broken Pascal system, and we got this summer job to fix it. While we were fixing it, we got frustrated with the editor we were using which was named ed. ed is certainly frustrating.”

As with so many stories in the advancement of software… work begins when a programmer gets frustrated with existing software.

“We got this code from a guy named George Coulouris at University College in London called em - Editor for Mortals - since only immortals could use ed to do anything. By the way, before that summer, we could only type in uppercase. That summer we got lowercase ROMs for our terminals. It was really exciting to finally use lowercase.”

Anyone who has used ed for any sizable project knows how frustrating it can be to use. While ed has many strengths (and is great for usage via shell scripts) editing large portions of text is not one of them.

Now, with inspiration from the “em” text editor, things really kicked into gear.

From the August 1984 issue of UNIX Review:

“So Chuck (Haley) and I looked at that and we hacked on em for a while, and eventually we ripped the stuff out of em and put some of it into what was then called en, which was really ed with some em features. Chuck would come in at night - we really didn't work exactly the same hours although we overlapped in the afternoon. I'd break the editor and he'd fix it and then he'd break it and I'd fix it. I got really big into writing manual pages, so I wrote manual pages for all the great features we were going to do but never implemented.”

Put simply… ed + em = en. Sort of.

Also, I love the whole “I wrote manual pages for all the great features we were going to do but never implemented” part. Been there!

Modems and Terminals and vi weirdness

Back to the 1999 Linux Magazine interview:

I don't know if there was an eo or an ep but finally there was ex. [laughter] I remember en but I don't know how it got to ex. So I had a terminal at home and a 300 baud modem so the cursor could move around and I just stayed up all night for a few months and wrote vi.”

ed… em… en… [eo… ep?]… ex… then, finally, vi.

That is how we got to vi. The family tree of vi, if you will.

Worth noting here that “vi” is short for “visual mode of ex”. Running “vi” is literally a shortcut for launching the “ex” text editor directly into the full screen “visual mode” instead of the default “line mode”

In fact, if you were already running ex, you could enter the “visual mode” by entering the vi command.

And, what’s that? Vi was programmed on a 300 baud modem?

Seriously. Considering a 300 baud modem is 1/4th the speed of a 1200 baud modem (which transmits text slower than most people can read it)… this explains much of the design of vi.

“It was really hard to do because you've got to remember that I was trying to make it usable over a 300 baud modem. That's also the reason you have all these funny commands. It just barely worked to use a screen editor over a modem. It was just barely fast enough.”

Here, Bill Joy compares the reasons behind the design differences between emacs and vi:

“The people doing Emacs were sitting in labs at MIT with what were essentially fibre-channel links to the host, in contemporary terms. They were working on a PDP-10, which was a huge machine by comparison, with infinitely fast screens.

So they could have funny commands with the screen shimmering and all that, and meanwhile, I'm sitting at home in sort of World War II surplus housing at Berkeley with a modem and a terminal that can just barely get the cursor off the bottom line.

It was a world that is now extinct. People don't know that vi was written for a world that doesn't exist anymore.

Short, single character commands in vi kept things usable even of that slow connection.

As Bill Joy put it, “vi was written for a world that doesn't exist anymore.”

While the hardware limitation of the 300 baud modem had a significant influence on the design of vi… arguably the terminal (and keyboard) being used by Bill Joy had an even bigger impact.

That terminal: the ADM-3A built by Lear Siegler.

The ADM-3A is the model of terminal that Bill Joy programmed ex visual mode (aka vi) on.

For example: Why does vi use H, J, K, and L for cursor movement? Because, on the ADM-3A, those keys doubled as the arrow keys.

The keyboard layout of the ADM-3A.

You’ll also note that the Escape key is where the Tab key is on most modern keyboard. That’s why Esc is the vi mode switching key… it was, on that keyboard, easy to hit without moving your left hand off of the home row.

And, despite common keyboard layouts no longer being like this, vi stayed this way.

Vi almost changed significantly

A fun little sidenote: Bill Joy almost added multi-window support and other features… but he didn’t have backups of his code. And, as is the way, he lost that code.

“I was in the process of adding multiwindows to vi when we installed our VAX, which would have been in December of '78. We didn't have any backups and the tape drive broke. I continued to work even without being able to do backups. And then the source code got scrunched and I didn't have a complete listing. I had almost rewritten all of the display code for windows, and that was when I gave up. After that, I went back to the previous version and just documented the code, finished the manual and closed it off. If that scrunch had not happened, vi would have multiple windows, and I might have put in some programmability - but I don't know.”

Yep. We were this close to vi being quite different in those early days.

But the source code got “scrunched”.

Which is a technical term. I think.

Vi… forever

In May of 1979, Bill Joy — who was also the driving force behind BSD — released the first public version of vi (the visual mode for the ex text editor) as part of the 2nd release of the Berkeley Software Distribution (2BSD).

While, at this point, BSD was not yet a full operating system — it was an archive of a few pieces of software for UNIX — this was the launching pad for what would become one of the most famous (and infamous) text editors ever created.

While vi may have initially only been distributed to a mere 75 people (as part of the 2BSD archive)… it would go on to become a standard of POSIX, distributed on nearly every UNIX-alike system for the last 40 years.

More likely than not, people will be struggling to escape from vi another 40 years into the future.

Heck. A million years from now only three things will remain: cockroaches, Hostess Twinkies, and vi.

All because Bill Joy used an ADM-3A terminal on a 300 baud connection to build a text editor to fix a broken Pascal compiler.

Not too darned shabby for a mode of a text editor written for a world that doesn't exist anymore.

The Story of Vim

As popular -- and historically significant -- as vi is... one of vi's clones is, arguably, even more widely used: Vim.  Linux users regularly vote for Vim as their favorite text editor (or, at least, one of their favorites).

The path from vi to Vim wound through Unix, Atari ST, and Amiga systems... and back again.

  • In 1987, a man named Tim Thompson created a vi clone (from scratch, with no code copied from vi) for the Atari ST.  He called it STEVIE (which stands for ST Editor for VI Enthusiasts.)
  • In 1988, STEVIE was ported to OS/2, Amiga, and UNIX by Tony Andrews.
  • Later in 1988, Bram Moolenaar took the source code for the Amiga port of STEVIE and began modifying it to meet his own needs.  The result was Vim (or "Vi IMitation").  Because it wasn't a fork or port of Vi... but an imitation.
  • Moolenaar would continue to work on Vim for the next few years, eventually making the first public release in 1991.

Eventually (in 1993), the "Vi IMitiation" name was changed to "Vi IMproved"... and Vim was ported to an incredible number of platforms -- from UNIX to DOS to Haiku.

And it still uses those same, crazy, vi default keys... inspired by the ADM-3A.

community logo
Join the Lunduke Community
To read more articles like this, sign up and join my community today
17
What else you may like…
Videos
Podcasts
Posts
Articles
Linux Distro Declared "Non-Woke", Causing New Users & Interest to Skyrocket

While "Woke" Linux Distributions (like openSUSE) are struggling to survive, interest in OpenMandriva - a non-Woke Open Source project - is exploding.

00:29:15
January 19, 2025
Godot Game Engine Went Woke... And Lost $160,000 Per Year.

A few months ago, the Open Source Godot Game Engine enacted a mass "cleansing" of Non-Woke supporters. Then their monthly donations dropped by over 25%.

00:10:46
January 17, 2025
Tech Journalists Rally in Support of Racism and Sexism in Big Tech

"Save me from rich, white men," declares the Tech Journalists in response to some Big Tech firms decreasing racist DEl spending.

00:31:20
November 22, 2023
The futility of Ad-Blockers

Ads are filling the entirety of the Web -- websites, podcasts, YouTube videos, etc. -- at an increasing rate. Prices for those ad placements are plummeting. Consumers are desperate to use ad-blockers to make the web palatable. Google (and others) are desperate to break and block ad-blockers. All of which results in... more ads and lower pay for creators.

It's a fascinatingly annoying cycle. And there's only one viable way out of it.

Looking for the Podcast RSS feed or other links? Check here:
https://lunduke.locals.com/post/4619051/lunduke-journal-link-central-tm

Give the gift of The Lunduke Journal:
https://lunduke.locals.com/post/4898317/give-the-gift-of-the-lunduke-journal

The futility of Ad-Blockers
November 21, 2023
openSUSE says "No Lunduke allowed!"

Those in power with openSUSE make it clear they will not allow me anywhere near anything related to the openSUSE project. Ever. For any reason.

Well, that settles that, then! Guess I won't be contributing to openSUSE! 🤣

Looking for the Podcast RSS feed or other links?
https://lunduke.locals.com/post/4619051/lunduke-journal-link-central-tm

Give the gift of The Lunduke Journal:
https://lunduke.locals.com/post/4898317/give-the-gift-of-the-lunduke-journal

openSUSE says "No Lunduke allowed!"
September 13, 2023
"Andreas Kling creator of Serenity OS & Ladybird Web Browser" - Lunduke’s Big Tech Show - September 13th, 2023 - Ep 044

This episode is free for all to enjoy and share.

Be sure to subscribe here at Lunduke.Locals.com to get all shows & articles (including interviews with other amazing nerds).

"Andreas Kling creator of Serenity OS & Ladybird Web Browser" - Lunduke’s Big Tech Show - September 13th, 2023 - Ep 044
January 13, 2025
Last 24 Hours: 55% off DRM-Free MP4s, & Discounted Lifetime Subscriptions

Holy guacamole, Batman! We are now over 80% of the way to our funding goal… for the end of February. And it’s not even half way through January! I am absolutely gobsmacked.

Want to help push us over the 100% line — and directly fund the truly independent Tech Journalism of The Lunduke Journal?

Lots of options. Big and small (and all amazingly helpful). Scroll down & choose whatever works best for you.

Lunduke Journal Discounts

For the next 24-sh hours (through Tuesday, January 14th), in addition to regular subscriptions, you can grab two limited discounts:

  1. Discounted Lifetime Subscriptions (details below)

  2. DRM-Free, MP4 Downloads for 2024 & 2025 (combined) for 55% off.

There many ways to support The Lunduke Journal. Choose the option that makes you smile. It’s all listed below.

Where to grab a Monthly or Yearly Subscription:

Lifetime Subscription Details:

  • Pay once, full subscription for life (on Locals, Substack, or both).

  • Available only through Tuesday, January 14th. Then the Lifetime Subscription option goes “back in the vault”.

  • Can be purchased via Locals, Substack, or with Bitcoin. Scroll down for steps.

Where to buy a DRM-Free, MP4 video yearly download pass:

Want to be able to download every show The Lunduke Journal releases (and watch them on whatever device you like)? Yeah. You can do that.

The Famous Lifetime Subscription via Locals

The "World Famous Lunduke Journal Lifetime Subscription" is exactly what it sounds like. Pay once and get full access to The Lunduke Journal (with all the perks of subscription on Locals). For life.

New Lifetime Subscriptions are available, for $200, from now through January 14th. Then this option goes "back into the vault".

Here's how to grab one of these coveted bad boys for yourself:

  1. Go to Lunduke.Locals.com/support.

  2. Select "Give Once".

  3. Enter "200" into the amount field.

  4. After checking out, Lunduke will toss you an email once your account is set to full lifetime status. (This usually happens within a few hours.)

The Famous Lifetime Subscription via Substack

You can also snag a Lifetime Subscription via Substack:

  1. Go to Lunduke.Substack.com/subscribe.

  2. Select the “Lifetime Subscription” option.

  3. After checking out, Lunduke will toss you an email once your account is set to full lifetime status. (This usually happens within a few hours.)

If you would like full, Lifetime access to Lunduke.Locals.com (which is included):

  1. Make a free account on Lunduke.Locals.com.

  2. Email “bryan at lunduke.com” with the email address you use on both Substack and Locals (can be different email addresses).

  3. Lunduke will toss you an email once your account is set to full lifetime status on Locals.

The Famous Lifetime Subscription (with Bitcoin discount)

And, finally, you can obtain a Lifetime Subscription via Bitcoin. Save a few bucks with this option, as Bitcoin processing has fewer fees associated with it.

  • Make sure you have a Lunduke.Locals.com account (a free account works just fine).

  • Send $190 worth of Bitcoin (or more) to the following address:

bc1qyjakve8fywm8pz2v99v57yhjj0vzr2vjze6fcq

  • Email "bryan at lunduke.com" with the following information: What time you made the transaction, how much was sent (in Bitcoin), and the email address you use (or plan to use) on Locals.com.

Nice and easy. Lots of options.

Once again, thank you. The Lunduke Journal would not be possible without your support.

You rule.

-Lunduke

Read full Article
January 12, 2025
Discounted Lifetime Subs, 55% Discount on MP4 Downloads for 2 Days

The Lunduke Journal remains 100% free from advertising… and, even more importantly, 100% free from all Big Tech influence.

And, because we never take a penny from any company, this is only possible thanks to you.

All of you amazing nerds showed tremendous support for The Lunduke Journal last month — grabbing Lifetime and standard subscriptions — meeting our necessary funding requirements for January… before January even started.

Mind. Blown.

This allows me to focus on new reporting — without needing to worry so much about funding and “business stuff” during the month. Which means more shows & more investigations. A massive win for all of us.

That also means that, this month, we don’t need to do a big “fundraiser”. Instead, we’re going to just send out this quick reminder of how absolutely critical your support is for the continued success The Lunduke Journal — the last bastion of truly independent Tech Journalism.

Seriously. Couldn’t do this without you.

Scroll down and take a look at the options. See if any jump out at you. Then give yourself a high five for making Tech Journalism that much more awesome.

Lunduke Journal Discounts

For the next 2 days (through Wednesday, January 15th), in addition to regular subscriptions, you can grab two limited discounts:

  1. Discounted Lifetime Subscriptions (details below)

  2. DRM-Free, MP4 Downloads for 2024 & 2025 (combined) for 55% off.

There many ways to support The Lunduke Journal. Choose the option that makes you smile. It’s all listed below.

Where to grab a Monthly or Yearly Subscription:

Lifetime Subscription Details:

  • Pay once, full subscription for life (on Locals, Substack, or both).

  • Available only until Wednesday, January 15th. Then the Lifetime Subscription option goes “back in the vault”.

  • Can be purchased via Locals, Substack, or with Bitcoin. Scroll down for steps.

Where to buy a DRM-Free, MP4 video yearly download pass:

Want to be able to download every show The Lunduke Journal releases (and watch them on whatever device you like)? Yeah. You can do that.

The Famous Lifetime Subscription via Locals

The "World Famous Lunduke Journal Lifetime Subscription" is exactly what it sounds like. Pay once and get full access to The Lunduke Journal (with all the perks of subscription on Locals). For life.

New Lifetime Subscriptions are available, for $200, from now through January 15th. Then this option goes "back into the vault".

Here's how to grab one of these coveted bad boys for yourself:

  1. Go to Lunduke.Locals.com/support.

  2. Select "Give Once".

  3. Enter "200" into the amount field.

  4. After checking out, Lunduke will toss you an email once your account is set to full lifetime status. (This usually happens within a few hours.)

The Famous Lifetime Subscription via Substack

You can also snag a Lifetime Subscription via Substack:

  1. Go to Lunduke.Substack.com/subscribe.

  2. Select the “Lifetime Subscription” option.

  3. After checking out, Lunduke will toss you an email once your account is set to full lifetime status. (This usually happens within a few hours.)

If you would like full, Lifetime access to Lunduke.Locals.com (which is included):

  1. Make a free account on Lunduke.Locals.com.

  2. Email “bryan at lunduke.com” with the email address you use on both Substack and Locals (can be different email addresses).

  3. Lunduke will toss you an email once your account is set to full lifetime status on Locals.

The Famous Lifetime Subscription (with Bitcoin discount)

And, finally, you can obtain a Lifetime Subscription via Bitcoin. Save a few bucks with this option, as Bitcoin processing has fewer fees associated with it.

  • Make sure you have a Lunduke.Locals.com account (a free account works just fine).

  • Send $190 worth of Bitcoin (or more) to the following address:

bc1qyjakve8fywm8pz2v99v57yhjj0vzr2vjze6fcq

  • Email "bryan at lunduke.com" with the following information: What time you made the transaction, how much was sent (in Bitcoin), and the email address you use (or plan to use) on Locals.com.

Nice and easy.

Once again, thank you. The Lunduke Journal would not be possible without your support.

You rule.

-Lunduke

Read full Article
January 09, 2025
post photo preview
The House of Lunduke BBS
Telnet: BBS.LUNDUKE.COM

The House of Lunduke BBS is a 20 node, Telnet BBS (bbs.lunduke.com) focused on the golden age of DOS BBS gaming -- including TradeWars 2002 and Legend of the Red Dragon.

 

 

The BBS is free to use, & creating an account takes only a moment.  All new users are granted 2 hours of access to all games on the system (more than enough to get in your daily turns of every one of these classic games).

Current games on the BBS:

  • TradeWars 2002 (aka TW2002)
  • Legend of the Red Dragon (aka LORD)
  • Legend of the Red Dragon 2
  • The Pit
  • Exitilus
  • DoorMUD
  • Barren Realms Elite

 

How to Connect

 

Accessing The House of Lunduke BBS is incredibly easy.  Simply point any Telnet client at "bbs.lunduke.com" on port 23 (the default Telnet port).

This means, on many systems, a simple:

telnet bbs.lunduke.com

Will, technically, work.

However, if you want to have the absolute best experience -- and see what BBSing was truly like back in the 1980s and 1990s -- you'll want to use a Telnet client capable of displaying ANSI color... specifically one tuned for BBSes.

The following Telnet clients are all recommended and work well with The House of Lunduke:

Once you have chosen your Telnet client, simply add "bbs.lunduke.com" to your address book and connect.  Or, from within some Telnet clients, you can also type "atdtbbs.lunduke.com" (no spaces).

Fun fact: "ATDT" is a command which tells an old-school modem to "tone dial this number".  The "AT" stands for "Attention", "D" stands for "Dial", and ending T stands for "Tone".  In the old days ATDT would be followed by a phone number... but, since we're connecting via Telnet, we now use a domain.

Or, if you want to get really old-school, it is possible to utilize DOSBox and an era appropriate terminal client (such as Telemate).

 

 

F.A.Q.

 

Q: What software does The House of Lunduke BBS run?

A: The core BBS software is known as Virtual Advanced (a successor to VBBS), a DOS-based BBS package that acheived some popularity during the early 1990s.  All of the games on the system (known as "Door games" in BBS terminology) also run on DOS -- and each is the most popular version (or the last version) of each.  A Telnet server handles incoming telnet connections -- which then interfaces with the DOS-based BBS software, using what is known as a FOSSIL driver.

 

Fun Fact: A FOSSIL driver is a serial interface driver -- which makes it easier to use a standard interface to multiple different communication devices (such as a type of dial-up modem or a Telnet connection).  FOSSIL stands for "Fido Opus SEAdog Standard Interface Layer".  Which is a fun name.

 

Q: What does "20 node" mean?

A: In "ye olden times", BBSes used modems and phone lines.  One person, at a time, could call a BBS on each phone line.  Each of these is a "node".  We are now living in the future -- and using Telnet instead of phone lines -- which means that, in theory, we could have a small mountain of people connecting at the same time.  However.  Since we are using 1980s and 1990s DOS software, jury-rigged to work with the modern Internet, some of those old limitations still apply.  20 nodes were chosen as that makes for an incredibly large BBS system... but not too difficult to manage.

 

Q: Why not use a more modern BBS server?

A: There are several "modern" BBS servers -- with many fancy benefits.  MysticBBS, Synchronet, and others.  The House of Lunduke BBS is not about being modern.  Or fancy.  It is about preserving a snapshot of a high-point in BBS gaming history.

Read full Article
See More
Available on mobile and TV devices
google store google store app store app store
google store google store app tv store app tv store amazon store amazon store roku store roku store
Powered by Locals