The original ABC language, Python's predecessor (1991)

(github.com)

98 points | by tony 13 hours ago ago

26 comments

  • dvdkon 12 hours ago

    Nice find. This looks like the best introduction to the language in the repo: https://raw.githubusercontent.com/gvanrossum/abc-unix/refs/h...

    • nuancebydefault 11 hours ago

      Wow 2 * 1000 without rounding errors, 40 years ago this must have been super impressive, since I find that quite a feat of today's python.

      • nick__m 10 hours ago

        2 * 1000 is 2000 ;)

        I think you meant 2**1000

        the syntax for formatting ate your star https://news.ycombinator.com/formatdoc

        • swores 9 hours ago

          For anyone else who, like me a moment ago, doesn't know the meaning of ** but is curious: it's how many (but not all) programming languages express "to the power of", aka 2**1000 = 2^1000

          • pansa2 7 hours ago

            > 2**1000 = 2^1000

            The reason for using `**` is that `^` is widely used for bitwise exclusive-or. So commonly `2**1000 != 2^1000`!

            • kragen 5 hours ago

              I think Fortran used ** because EBCDIC didn't have ^ or uparrow. ABC and Python followed Fortran rather than C on this point. units(1) supports both.

              • shawn_w 4 hours ago

                C uses ^ for bitwise xor and a function for exponentiation, though.

            • swores 4 hours ago

              Interesting, thanks!

        • nuancebydefault 10 hours ago

          Oh that's why i did not get any upvotes /i

        • Lucasoato 8 hours ago

          Wow, I didn't know that you could write

            like
              this
                for
                  code
                    blocks
          • jockm 7 hours ago

            It’s been around since at least occam, maybe longer

      • doug-moen 5 hours ago

        Lisp has had arbitrary precision arithmetic since the early 1970s. So did dc on Unix, also in the early 1970s. ABC didn't arrive until 1987.

      • aidenn0 4 hours ago

            Python 3.11.13 (main, Jun  3 2025, 18:38:25) [GCC 14.3.0] on linux
            Type "help", "copyright", "credits" or "license" for more information.
            >>> 2**1000
            10715086071862673209484250490600018105614048117055336074437503883703510511249361224931983788156958581275946729175531468251871452856923140435984577574698574803934567774824230985421074605062371141877954182153046474983581941267398767559165543946077062914571196477686542167660429831652624386837205668069376
            >>> _/2**999
            2.0
  • kristopolous 3 hours ago

    I swear I remember using this. I even remember the syntax. I was able to compile it and just start writing in it. I have no idea how I know this syntax.

    Did early linux have this? Maybe netbsd?

    I actually found it. It was on simtel: https://archive.org/details/Simtel20_Sept92

    I must have gotten it from there. I would routinely get any thing Walnut Creek would make.

    I also realized a couple years ago I could navigate EDLIN without help and knew how to use masm. Somehow I had forgotten what I know but my fingers did not.

  • mg 3 hours ago

    The first example in the lanuage introduction (https://homepages.cwi.nl/~steven/abc/):

       HOW TO RETURN words document:
          PUT {} IN collection
          FOR line IN document:
             FOR word IN split line:
                IF word not.in collection:
                   INSERT word IN collection
          RETURN collection
    
    In Python it would be:

        def words(document):
           collection = set()
           for line in document:
              for word in line.split():
                 if word not in collection:
                    collection.add(word)
           return collection
    
    I kept the splitting by line and "if word not in collection:" in there even though they don't have an impact on the outcome. I have the feeling that even in the original example they have only been put there to show the language constructs, not to do anything useful. If one wanted to optimize it, it could all be collapsed to just "return set(text.split())", but that would not show off the language features.

    ABC uses 225 chars, Python 218 chars. 3% less.

    So one could say Python is 3% more efficient than ABC.

    • volemo 2 hours ago

      “HOW TO RETURN” for something as common as “def” is crazy!

      • mg 35 minutes ago

        Well, not as bad as something like

            public static function words(string $document): array {
        
        which some languages these days are coming up with.
  • zahlman 12 hours ago

    Extremely cool. Thanks, GvR.

    For my own language design I've wanted to introduce some of this ABC syntax back into Python. Mainly for unpacking data and doing index/slice assignments; a lot of beginners seem to get tripped up because assignments in Python use the same syntax as mutations, so maybe it's better to write e.g. `a['b'] = c` like `set b = c in a`, or `update a with {'b': c}`, or ... who knows, exactly.

    • eru 6 hours ago

      I agree that Python would benefit from separating mutation and assignment.

      Especially when you are dealing with nested functions. You'd get around the whole need for 'global' and 'nonlocal' declarations. (Though your linter might still ask you for them for clarity.)

      As a minimal syntax change, I would propose using perhaps = for introduction of a variable (the common case) and := for an explicit mutation of an existing variable.

      But you could also use `let . = ..` and `. = ..` like Rust does.

  • layer8 8 hours ago

    The use of “HOW TO” for defining subroutines is kinda neat. Though “HOW TO RETURN” for functions doesn’t quite hit the mark. “HOW TO OBTAIN” or “HOW TO SUPPLY” would work with the same number of characters.

  • ahartmetz 12 hours ago

    Interesting, seems like Python is a strict improvement over ABC though many things are very similar. The PUT ... IN ... and INSERT ... IN ... syntax looks quite clunky and un-composable, at least the examples never do more than one (high-level) operation per line. Also, I guess GvR's English wasn't that good at the time - it should be have been INTO, right?

  • dec0dedab0de 11 hours ago

    The year says 91, but it looks like it was recently pushed to github, which is a notable event on its own.

  • nurettin 5 hours ago

    It actually looks surprisingly usable https://homepages.cwi.nl/~steven/abc/types.html

  • perrohunter 12 hours ago

    Where is the GIL in this?

    • eru 6 hours ago

      You only need the GIL in the first place, when you are doing multi-threading.

      Python only got its own GIL in version 1.5 of CPython.