Software Engineering as a Craft An Article by Thomas Wilson thomaswilson.xyz The decreasingly tangible product of code, i.e. that all we have are files on a hard-drive, may make it easy to forget that writing software produces a thing. If you produce a wonky chair or an overly long fork, it’s easy to see the quality of work was not great. By calling for a perception of software as a craft, we fight against that ability to forget or not notice the final quality of the product. You could watch two software engineers with different levels of experience, or in different domains, and it wouldn’t necessarily be so easy to guess which is which, at least from a distance. So maybe there is something to be said for the value of software as a craft, for sometimes focusing on the practice of making better, or at least different, software just for the sake of it. craftsoftware
The situation talks back As the designer shapes the situation in accordance with his initial presentation of it, the situation “talks back” and he responds to the situation’s back-talk. In a good process of design, this conversation with the situation is reflexive. In answer to the situation’s back-talk, the designer reflects-in-action on the construction of the problem, the strategies of action, or the model of the phenomena, which have been implicit in his moves. Donald Schon, The Reflective Practitioner What's wrong with the rational modelWhat the prototype tells youExpressing ideas helps to form themThe idea grows as they workDrawing as a means of thinkingFour principlesWriting, Briefly design