A friend who attended the Stockholm Business School said that the way forward is, to come up with big and crazy ideas and go as far as you can with them. This is what I have done here. The next step will be to scale them back, but they are for the most part, free from implementation details or hangups on stuff like security.
A new way from the old
Imagine a graphic designer working away on a project using a PhotoShop like clone. He’s designing some art work for a company while in video conference with a colleague who at the other end, can see exactly what is being worked on and how it looks. All of this is taking place inside a canvas tag in the browser. Just as he’s expressing how great it would be to have a tool in his palette that could spray paint in a specific way, he sees an alert appear in the corner of his eye. In his inbox his colleague has sent him a new visual component.
He drags out of the message from his inbox onto the palette with the rest of the tools and starts to use it. “Excellent… just was I was missing”, he remarks.
Imagine a network of database servers, numbering in their tens of thousands that exist solely for the purpose of serving the community. The users in the community have the ability to, drag, drop, copy, paste, move and compare data sets with the greatest of ease via visual components that are moved around on a multi-user collaborative canvas, which can be viewed, shared and duplicated with just a couple of mouse clicks.
Drag in a schema from a populated MySQL database you find on a forum into a PHP scaffolding component, which you in turn drag to an ubuntu cloud server hosted on Amazon; all of which are represented by visual components. Each one contain clusters of other components that contain variables and hierarchies of commands, which map to source code. All commands are virtual and can be easily monitored, tapped, rerouted, hooked or just omitted in order to assist with simulated dry runs to aid in testing. Tests can be automatically run when any change is made.
Programming used to be fun
I used to have difficulty pulling myself away from the computer (well, still do actually) in the days of Visual Basic 5. You could get results instantaneously and just like working on a farm, you had almost instant gratification and spontaneous feedback, thus you were not impaired from seeing the fruits of your labor. Maybe the internet had made me spoilt, with all this streaming video at my fingers. Shrinking attention spans has lead us to demand that everything happens now, straight way with no delay. If I’m not stimulated within 10 seconds, I’m moving on. Ok, well I’m not quite there, but a lot of people are, but I digress. Programming used to be fun, because I could see the results straight away.
But now, with our 16 terminal windows open, languages embedded in other languages embedded in markup mixed in with version control, logging, deployment, hosting. Oh my god. How much do we need to know to simply get the shit to work.
Assisted visual programming
Not assisted visual coding. The components of course will map to the code underneath. But think of clicking a button, which spawns a dialogue of options just to the right of where you clicked. Lables, radio buttons, button groups. Any combination of visual controls could appear. Clicking a radio button again changes the shape of the controls. This is how you will do your programming for the most part, and it should be very difficult to make mistakes because of the limited options available to you.
Assisted strings
By far, the easiest point of failure in any programming projects are string variables. They can hold filenames, database field names, paths, or relative urls to pages in your application. But lets face it; they are usually not checked, tested or managed. All of the above can work as components that have tests built in to make sure they exist, from the very moment you insert them into your programming. If you’re referring to a file, a test will either make sure its on the filesystem in question, or depending on the context, a little worker script will check it exists on the remote system or site. If its a new file that doesn’t exist yet, you will set a flag somewhere to register this fact, and then set another flag on another component when it comes into existence.
If you’re working with relative internal URLs, these should be centrally managed in some kind of store and behave like variables. Referring to them in your programming will ensure your user will never encounter an error 404. Each URL is also a component. So changing a URL in your central store will also change all of the places in your programming automatically where you have referred to them. But adding or removing new URLs to the central store should be fluent and not slow you down or distract you from whatever you’re programming, which will therefore work via an auto-complete or an intelisence type mechanism.
Embedded Components
You’re reading some documentation and come across some sample program. You click into the embedded program and start exploring it. You browse through the hierarchy of components, and now curious, you want to try it out. A couple of clicks and you’ve duplicated the sample program into you’re workspace and testing the code, as well as manipulating different values like a todler in a playpen. You tag your work and continue reading through the documentation.
You come across another program in the doc you’re reading and run it without duplicating it. It does just what you need. You tag the program and continue browsing the docs.
Some time passes and you’ve tagged 8 programs. Some you have modified, and others have just run directly from the documentation you found them in. All of which contain pre-populated titles, descriptions, URLs and clickable meta-data about where you got them and what documents they came from. With a couple of clicks, you find a colleague and send the tag with the comment “Here are some programs that might help us with the new project!”
You later add more programs to the tag, which your colleague receives notifications about. These notifications in themselves can be individually stored, marked as read, and/or categorised, manually or automatically to be easily found later.