Speaking as a Fancy Computer Science Professor at a Fancy Institution of Higher Education who teaches the course on Programming Languages:
-
If a UI button is a programming language, it's a tiny, trivial one. But that lens of “In what ways is this user interface a form of programming?” does open the door to insights about what experiences humans are going to have trying to use it.
We programmers understand the difficulties and the dangers of:
- compounding complexity
- mismatch between mental model and machine implementation
- error states
- unintended consequences
- solving the problem at hand using the building blocks available -
Paul Cantrellreplied to Paul Cantrell last edited by [email protected]
- not losing sight of the problem in the middle of fighting the machine
- the way social / human problems can come to a head when codified in commands given to a machine
- the way a better abstraction can change whether something is easy, flexible, error-prone, adaptable, correct
- etcViewing computer interaction as a series of increasingly programming-like steps goes a long way toward explaining why your dad can’t figure out how to change the wifi password.
-
Paul Cantrellreplied to Paul Cantrell last edited by [email protected]
Looking at things that way, @nikclayton’s reply is unironically correct:
https://mastodon.social/@nikclayton/113680873868692643I mean, seriously, formatting things with a word processor can feel a hell of a lot like getting some developer API to do this one damned thing that it just…won’t…do.
And it feels the same because •it has the same set of underlying problems•. Machines are surprising. Abstractions are surprising. Human-machine gap-bridging is hard.
-
I know, I know, the Reply Guy Armada is coming to tell me “If •everything* is programming, then •nothing• is!” Cool your jets, my friends.
Some things a very much programming, some things only slightly so. The useful question here is not “Where is the precise boundary?” but rather “How much does it belong to this family of problems, and how can we learn about it by bringing the knowledge and experience of that discipline to bear?”
-
@sophieschmieg @inthehands @Crell 'for any reasonable all-or-none definition of chicken, it has happened at least once in history that a chicken has hatched from an egg laid by a non-chicken, something that can obviously never have happened'
-
Here @aubilenon gets at something really important, and per the above, all the comparisons to “is it art / music / a game” etc etc are on point:
https://peoplemaking.games/@aubilenon/113680577564840603Context matters. Intent matters. Patterns of usage matter •a lot•.
-
This post is deleted!
-
@inthehands scoped problems, their meta-problems, and their ancestors' and descendants' problems…
-
@inthehands @nikclayton PREACH!
-
@datarama
Agreed, right up to the end: at that point, you're making Roller Coaster Tycoon / Minecraft into a programming language.People who build working machines out of the Game of Life quickly start building up design patterns and abstractions. Programming is a kind of problem and/or a way of using something, not just an intrinsic attribute of the object itself.
-
@billseitz
Heh, I’m game as long as we don’t forget that the purpose of the Cube Rule is to be silly -
This post is deleted!
-
@inthehands @billseitz If it has a frontend and a backend, it's a compiler. if backend only, it's a database. if it doesn't end, it's called a daemon. if it also has a leftend and a rightend it's ravioli
-
@inthehands @nikclayton This all reminds me of one of the first actual "debugging" tools I ever used (this was before I had done enough "what-people-who-think-HTML-isn't-programming" programming to use or need a traditional debugger for it).
"Reveal Codes."
This was the magic WordPerfect command from the 80s/90s that showed you why, for example, the fricking italics weren't working or that one section on that one page was just a little bit off. "Reveal Codes" popped up a little text area (not even a window, this was DOS, after all) showing a section of your text and all the associated "codes", which were tags indicating the structure or appearance of whatever they contained.
A *lot* like HTML.
And using Reveal Codes to figure out where your document was going wrong, and why, and how to fix it, was a lot like wrangling HTML to get your web page to have the right structure and appearance...and, as noted, also like trying to figure out how to get a cranky API to get the kind of output that you need it to deliver.
-
@jorendorff @billseitz
“Our fully relational ravioli offers the dual benefits of both persistence and delicience” -
@datarama
I mean, we’re dancing around two sides of the same coin: yes, and at some point, you’ve got to admit that it’s become a musical instrument. -
@inthehands @billseitz idunno sounds like it could lead to spaghetti code
-
@jorendorff @billseitz
* slow clap * -
@inthehands @nikclayton and even a button is increasingly complex - I’m often seeing forms where the button changes state to indicate whether or not you can click if (or if there is some portion of the form you haven’t finished filling out)
But every site does this differently and it is eh not at all obvious often which state the button is in - without attempting to click it
Further many sites have multiple buttons and knowing which to click when is not always obvious (save vs next? Etc)
-
@inthehands @nikclayton I'd actually go so far as to say that Reveal Codes back in the 80s made HTML almost instantly comprehensible, even with emerging complexities like (then-larval) style sheets, in the 90s. And *that* in turn made it possible for me to make the jump to web development as a career when a previous one started to head south -- more so in many ways than having a reasonably decent background in "what the annoying pedants call programming" programming as well.