Crazy Idea: Chatting to Your Programming Language

What Is This?

Today I’m writing about the embryo of a crazy idea I’ve had. It hasn’t yet passed the tests of usefulness and feasibility. I can’t yet clearly visualise what the implementation of the idea looks like. I’m writing about it in order to clarify my thoughts, and perhaps to spark your own related crazy ideas.

Prelude

I believe in improving the tools and processes that we use. As a software engineer, one tool that I use is a compiler. When writing software, my role is to communicate to the compiler enough about what a program should do; the compiler’s role is to understand my communication and, from that, construct the actual program. In an ideal programming language, the process of communicating the program internals to the compiler (that is, writing the source code) should be as smooth and intuitive as possible. (Another trait of an ideal programming language is that a developer should be able to quickly understand any piece of source code, but I’m going to put this trait on a shelf until I’ve developed my idea a little bit.)

In normal life, the most natural and intuitive way that I communicate a concept, however complicated, is through a conversation. If I want Ashley to understand my idea, I start by explaining the most basic points of my idea. He gives me some indication that he understands, so I explain a few more points. He draws some inference from what I’ve explained, and he asks me, “So does that mean that the discombobulators would need to be defenestrated?”. I see his line of reasoning and reply, “Yes, but only until the phase nebula has set.” At this, he’s totally confused and asks “What’s a phase nebula?”.

The Idea

My idea is this: mightn’t it make development smoother if we could build up our software through a conversation with a programming language? Put aside for the moment everything you think you know about programming languages. Imagine what it could look like at a first pass:

Welcome to [insert name of language].
> when user says add task to (workspace) with (description):
…    * create task with description, workspace
…    * append task to tasks to review of workspace
…
Confirm: task is object with description, workspace [y/n]? y
Confirm: workspace is object with tasks to review [y/n]? y
I don't understand what description is.
>

In this example the interaction is English-like, but it doesn’t have to be. It might be quicker for a developer to enter some symbolic short-hand that resembles source code for an existing language. But as you communicate with the language, it builds up its own model of what you’re trying to express. It may make assumptions on the way. Some assumptions may require your confirmation. The language may be so certain of other assumptions that it only asks for your confirmation if it stumbles upon an apparent contradiction. For this idea to work properly, the language would need to keep track of which parts of the program internals are its assumptions and which parts you specified. There’d need to be a way for you as the developer to correct or refine something that you’d previously said. And there’d need to be a way for the language to repeat back to you what you’ve said in its own “words” (this is likely to be more succinct and precise than your original words).

But IDEs Already Do All That

Sure, there are IDEs out there that give you feedback about the inconsistencies in your code, and even ones that will, at the click of a button, make some attempt to correct your mistakes. But if you think that that’s all there is to my idea, you need to go back and reread the bit where I said “Put aside for the moment everything you think you know about programming languages.” Existing IDEs are focussed around the single way we currently write software: by editing text files. Let’s explore the possibility that there’s another way to write software, a way that complements good developers’ thought processes and improves the efficiency of software development.

Feedback

In any sort of endeavour, your cognitive feedback loop is important. Unless you enjoy the thrill of flying blind, you want to be able to see the results of your actions. The shorter the time between initiating an action and seeing its results, the better. A drawback with reducing programming to a conversation is that this feedback loop is using only a fraction of the available bandwidth, and isn’t taking advantage of the possible media. That is to say, if you explain some of your program to the language and the only feedback you get is “Ok” or “Yep”, then we’re regressing to the days of BASICA and GW-BASIC, and we’re certainly not utilising the graphical potential of modern devices.

Wouldn’t it be clever if the language displayed some sort of graphical representation of the part of the program internals that you’re currently describing—perhaps some sort of mind map, perhaps a flowchart, or perhaps something else? The display should be presented in such a way that it’s easy for you as a developer to judge how well the program internals correspond to your own mental model of the program. This means that the language’s “mental” model of the program should be structurally as close as possible to yours. (This raises the question of what exactly is a developer’s mental model of a program. Does the developer’s mental model change between first inventing software and maintaining it?)

Of course, once the program internals are visually displayed, why shouldn’t the developer manipulate those internals visually? This strikes me as a really good way of making minor tweaks to a program. But the way that we’re used to communicating as humans is verbally, and so I’d guess that that’s how we’d be best at expressing things like what a new section of the program should do, which part of the program we’d like to edit, and possibly even changes of the program’s behaviour.

Maintaining Software

Way back in the prelude to this article, I said that in an ideal programming language, a developer should be able to quickly understand how a part of a program works by looking at the internals (I actually said “source code”, but by now you should have got the idea that a language may not have source code as such). The reason I temporarily put this language trait aside is that programming languages which aspire to this ideal usually do so by having source code which is succinct, neatly laid out, and explicit rather than implicit. But here we have the idea of a language without real source code. All things considered, I think that having a visual representation of program internals as described in the previous section would go a long way towards making programs maintainable. The language would also need to have ways for a developer to quickly navigate through the program internals. From my experience the three most important navigation tools would be: (a) a way of seeing the the definitions of symbols (to do the job of ctags); (b) a way of finding all uses of a symbol (to do the job of grep); and (c) a way of navigating to the part of a program that performs a particular action, calculation or decision.

What Now?

This is still only the embryo of a crazy idea. There are many details to be filled out. I can’t yet say for certain whether implementing the idea would be feasible. If it is, I can’t yet say how useful the implementation would turn out to be. I can’t yet clearly visualise what such an implementation would look like. I can’t even say how much time I’ll spend thinking about this idea before another crazy idea demands my focus. If you like this idea, please let me know! I spend more working on projects when I know others are interested. And perhaps you’ve got some time on your hands. I hear collaborative projects often last longer than individual projects.

Posted in long | Tagged , , , , , | 7 Comments

Happy Spam: I Can Only Compliment You

There’s a phenomenon I’ve been noticing, and I’d value your comments on the best approach to take.

This is what happens: I post an article to my blog. Then I wait. Then the comment moderation queue starts to get comments like this:

“i can only compliment you for the good job you have been doing in this blog, congratulations and keep it coming. [URL that I’ve removed]” –Darlene

“I like the invaluable data you give in your posts. I will bookmark your weblog and check again here frequently. I am pretty certain I will learn lots of new stuff right here!” –wifi access point

“Very nice post and right to the point. I don’t know if this is truly the best place to ask but do you guys have any thoughts on where to get some professional writers? Thanks :)” –Oliver Lindsay

“Bookmarked your post!” –Bail Bonds Los Angeles County

I call these “happy spam”. Here’s what all the happy spam comments have in common:

  • the commenter leaves a website URL along with their alleged name and email address;
  • the comment is positive and complimentary; and
  • the comment says nothing that’s specifically related to the article it’s commenting on.

Lest you get the wrong impression, let me assure you that I do get genuine comments and even some overt spam on this blog. But I would estimate that more than 90% of the comments that come to me for moderation are happy spam. Some comments even have these three happy spam traits and additionally include a URL in the comment itself. These I refer to as “happy spam spam”.

Most of the time I assume that people are just trying to get links to sites they control out there on the Internet. My typical approach is to strip all URLs from the comment (including the link from the commenter’s apparent name) and then approve the comment. I figure that if people are going to say nice things about my blog for their own selfish gain I might as well make public the nice things they’ve said.

Sometimes if I suspect that the comment may just be vague happy not-spam, I take a look at the commenter’s website to see if it contains anything that might indicate that the commenter falls into the article’s target audience. If so, there’s a chance that I’ll be generous enough to approve the comment without stripping the URL.

So the moral of the story for you, dear reader, is that when you post a comment on my blog you should write something relevant to the article you’re commenting on.

Partly I’m just writing this article to see if people will post happy spam to an article about happy spam. But if you have an opinion on how I should treat comments of this kind, I’d love to hear it. Should I approve them all in good faith? Is it deceptive of me to just approve the spam comments that say good things about my site and reject the ones that say nothing about my site? Should I tighten things up by requiring a captcha or email verification for people to comment? Please comment on this article and let me know your thoughts. If everyone who reads my blog comments on this article, we might even get the spam rate for this article down to 50%. But I doubt it.

Update (2012-06-15): The comments on this article were open for 30 days. For this article only, I approved all happy spam comments without editing so as to preserve a specimen of the comments. I did delete one or two outright spam comments. As of today, I have comment guidelines which I will be applying to all new comments. No longer will happy spam be tolerated on this site.

Posted in midlength | Tagged , , , | 10 Comments

Flowchart Python

Introduction

In 2006, I created Flowchart Python, a Python-based language that uses a flowchart for high-level language structure. I released it on pygame.org. A workmate was recently searching for something related to Python and flowcharts, and stumbled across my project. After trying to show him the project in action, I decided it was time to upload a cleaner version of Flowchart Python to the Internet.

Flowchart Python v1.0, 2007

What is Flowchart Python NOT?

Flowchart Python is not:

  • a tool for editing .py files as flowcharts;
  • a tool for viewing .py files as flowcharts; or
  • a tool for generating .py files from flowcharts.

Perhaps Flowchart Python would be more useful if it were one of those things, and in the future I may add tools which do such things, but those were not my design goals when I wrote the software.

What is Flowchart Python?

Flowchart Python lets you design and edit flowcharts. At the lowest level (variable assignment, function calls, etc.) you enter Python code. When you run a flowchart, the flowchart will be compiled to a .pyc file and run. This means that flowcharts can import normal Python modules and normal Python modules can import (compiled) flowcharts. But there is currently no mechanism for converting a Python source file to a flowchart or vice versa.

What Have I Changed in Version 1.1?

I have just uploaded version 1.1 of Flowchart Python. Despite all temptations I have been careful not to make any large changes in this upload. All that I have done is:

  • update Flowchart Python to work with the latest Python 2 library code;
  • used Python’s traceback module to display tracebacks rather than a home-rolled version;
  • fixed a spurious traceback;
  • fixed issues revealed by pyflakes (e.g. useless imports and assignments);
  • changed the code to use Unix line endings;
  • removed trailing whitespace from source code;
  • added __init__.py, setup.py etc.; and
  • called pygame.display.quit() before pygame.quit() to give the illusion of snappiness on exit.

The upshot is that Flowchart Python is now cross-platform and tested on Python 2.7.

How Do I Use It?

Flowchart Python was designed to be used by programmers. This meant that my priority in writing the software was to give hotkeys for everything useful rather than making obvious buttons in the UI. Below are a few pointers on use. In my notes below I haven’t specified the hotkeys for everything but in general if you can find a feature in the menu, the hotkey will be listed beside the command name.

Navigation

  • space zooms the view to the selected block
  • ctrl+mouse drag pans and zooms
  • alt+mouse drag pans only
  • S, F, E, D to move selection left, right, up, down
  • R to move selection to child of current block
  • W to move selection to parent of current block

Adding Blocks

To insert control structures, you first add an empty block, then use the ‘Substitute’ menu option (or hotkey) to set up the desired kind of block.

A flowchart containing nothing but a bunch of empty blocks.

There are two ways to add blocks. You can use the insert command (either from the menu or use the hotkey). Alternatively, if you move the mouse over the border of a given block, it will highlight the edge under the mouse in pink. This means that clicking will insert a new block at that position in the flowchart.

An edge highlighted in pink indicates that clicking will insert a new empty block at that location.

Editing Blocks

To add a control structure, select an empty block and choose ‘Substitute’ from the menu. The different kinds of blocks are:

  • Execute – executes a chunk of Python code.
  • If – tests the condition.
  • Loop – surprisingly enough, this loops.
  • For Loop – behaves like a Python for loop.
  • Loop Escape – exits the loop (I don’t know why I didn’t call this break. I’ll probably change it to that in a future version of the software).
  • Function Def – defines a function.
  • Class – defines a class.
  • Procedure – defines a funny flowcharty thing which can have multiple input and output routes, and cannot return a value.
  • Procedure call – calls a procedure.
  • Try – error checking.
  • Bottleneck – from multiple strands of execution, the same thing(s) will be run, then the original strand will be resumed.
  • Group – allows you to group blocks and give explanatory comments.

A bottleneck block allows multiple strands of execution to be temporarily combined.

 

Editing Mappings

Between blocks are mappings. These are denoted by blue circles joined by coloured lines. You can remap any of these by either clicking on the nodes to join, or pressing ‘m’ to enter mapping mode, using e, s, d, f to navigate and enter to select nodes to connect.

Reordering the connections at a mapping.

Keyboard Layouts

I currently develop on Linux. When I originally wrote Flowchart Python I developed in Windows. On Windows, the keycodes returned by pygame do not respect the keyboard layout selected in your operating system. I’m a dvorak user, so this annoyed me. If you are running Flowchart Python on Windows and want to use it in dvorak mode, find the comment near the start of main.py which says “To start in dvorak keyboard layout, comment out the following line.”, and do what it says.

Another note on keyboard layouts: even when typing in text fields, Flowchart Python uses the physical keystrokes to decide what letters you’ve typed. I guess I wasn’t aware that Pygame key events have a unicode character associated with them. Consequently you’ll find it very hard to insert special characters into the text fields.

How Do I Get It?

Flowchart Python is licensed under version 2 of the GNU General Public License. You may not download, distribute, edit or use the software unless you agree to the terms of the license.

If you accept the license, you can obtain version 1.1 of Flowchart Python on PyPI by following this link.

Future Work

Now that I’ve dug this code out, I like the idea of doing some more work on it. My coding style has improved in the last six years, so there’s plenty of refactoring I could do. It would also be nice to rename some things to names more familiar to Python developers, and to provide some way of viewing .py files as flowcharts. That said, I also have many other interesting projects to work on, and I can’t say how much time I’ll chose to spend on Flowchart Python.

Posted in long | Tagged , , , , | 8 Comments

Romulus, My Window Manager

About a year ago, I wrote about making your own window manager in Python, and how to extend this to use Twisted as your window manager’s main loop. Around the time I wrote those articles, I also wrote a tiling window manager, called Romulus, for my own personal use. I consider it to be unfinished, but at the request of a workmate, I’ve made the code available.

The rest of this post is technical in nature and does not go into detailed explanations. Do not expect to find it useful unless you are willing to fiddle with things and dig around for answers.

This project is licensed under version 3 of the GNU General Public License. To download, use, modify or distribute it you must agree with the license.

The project is in two parts, twinman (a framework) and Romulus itself. Let me stress that this project is still unfinished and is far from polished. Some notes if you’d like to try using it:

  • alt+v, alt+h to split vertically / horizontally
  • alt+enter to open terminal, alt+shift+enter to lock screen
  • alt+h,k,l,m to move focus, alt+shift+h,k,l,m to move window between panes
  • detects resolution on start / reload, so after running xrandr, restart (there’s a menu option to very crudely reload)
  • alt+t toggles the tab bar
  • alt+shift+g labels a window with a given letter
  • alt+g goes to the window with the given label

I usually run Romulus from the launcher which I’ve included in the public Romulus repository. The launcher has three buttons, one for Romulus, one for xterm and one for quit (logout). This means that if Romulus does crash all your windows stay alive because the launcher is still alive.

Also, the launcher loads key=value lines from ~/.environment and sets them in os.environ before starting Romulus, so you can set your PATH, PYTHONPATH etc. that way since it’s not being run from a bash shell so it won’t have .bashrc. At the moment the launcher has some paths hard-coded into it, so you’ll have to fiddle with it to make it work for your system. You should also refer to this article for tips about testing window managers (either using Xephyr or by running a second X server).

Posted in midlength | Tagged , , , , | 5 Comments

On Factions and Fractions

Imagine a situation where a group of n people have to make a decision by simple majority. For the sake of the argument, let’s call this group of people a parliament.

Now let’s consider an individual person P who is a member of the parliament. Let d be the number of decisions which the parliament is going to make while P is a member, disregarding any decisions of which P does not care about the outcome.

Let us assume that P is inherently selfish and therefore wants to maximise the number of these d decisions which are decided in P's favour. A good strategy for P is to rally together a group of n/2+1 members of the parliament with similar opinions to P. Let us call this group a party. If this party were to agree to always vote together in the parliament for an outcome decided in a fair manner by the party, this would be likely to increase the number of decisions which the parliament decides in P's favour.

All that remains then, is for the party to settle on what constitutes a “fair manner” for deciding which option the party will vote for in the parliament. The obvious answer is of course for the party to make a decision by simple majority.

So we now have a situation where a group of n/2+1 people have to make a decision by simple majority. A good strategy for P is to rally together a group of (n/2+1)/2+1 members of the party with similar opinions to P. Let us call this group a faction. If this faction were to agree to always vote together in the party for an outcome decided by simple majority by the faction, this would be likely to increase the number of decisions which the party decides in P's favour and therefore increase the number of decisions which the parliament decides in P's favour.

So we now have a situation where a group of (n/2+1)/2+1 people have to make a decision by simple majority. A good strategy for P is to rally together a group of ((n/2+1)/2+1)/2+1 members of the faction with similar opinions to P. Let us call this group a subfaction. If this subfaction were to agree to always vote together in the faction for an outcome decided by simple majority by the subfaction, this would be likely to increase the number of decisions which the faction decides in P's favour and therefore increase the number of decisions which the parliament decides in P's favour.

This concludes my demonstration.

Posted in midlength | Tagged , | 3 Comments