A veduta is a highly detailed, usually large-scale painting of a cityscape or some other vista. This genre of landscape originated in Flanders, where artists such as Paul Bril painted vedute as early as the 16th century. As the itinerary of the Grand Tour became somewhat standardized, vedute of familiar scenes like the Roman Forum or the Grand Canal recalled early ventures to the Continent for aristocratic Englishmen. In the later 19th century, more personal impressions of cityscapes replaced the desire for topographical accuracy, which was satisfied instead by painted panoramas.
Syntactic constraints. Python is a syntactically simple language with fairly strong constraints on what can and can't be done without "messing things up" (both visually and with regards to the language parser). There's no obvious way to structure this information so that people new to the concept will think, "Oh yeah, I know what you're doing." The best that seems possible is to keep new users from creating a wildly incorrect mental model of what the syntax means.
When we instantiate a SimpleMessage and then pass it to the various decorators, we now get new behavior. Moreover, since both the concrete component and the concrete decorators all implement / descend from IMessage, they are interchangeable as far as the program is concerned, meaning that we can loop over them together. Further, rather than having to create a new ExcitedAndQuizzicalMessageDecorator class, we were able to achieve the same effect by double wrapping a SimpleMessage object (first in an ExcitedMessageDecorator and then in a QuizzicalMessageDecorator). Finally, note that despite having been passed into various decorators, our simpleMsg object remains unchanged at the end of the program.
The decorator pattern, also known as the wrapper pattern, is when you wrap an object within another object, thus providing a means of enhancing or overriding certain behavior. The wrapper object will delegate any incoming method calls to the original object, unless it defines a new method to enhance or replace the original object’s behavior. By using the decorator pattern, you can dynamically create as many decorated objects as you want, each enhancing the behavior of the original object in a unique way — and all without mutating the original object. In this manner, you can effectively add, remove, or extend behaviors at runtime.
The decorate() proposal was that no new syntax be implemented -- instead a magic function that used introspection to manipulate the following function. Both Jp Calderone and Philip Eby produced implementations of functions that did this. Guido was pretty firmly against this -- with no new syntax, the magicness of a function like this is extremely high:
Painters deal practically with pigments, so "blue" for a painter can be any of the blues: phthalocyanine blue, Prussian blue, indigo, Cobalt blue, ultramarine, and so on. Psychological and symbolical meanings of color are not, strictly speaking, means of painting. Colors only add to the potential, derived context of meanings, and because of this, the perception of a painting is highly subjective. The analogy with music is quite clear—sound in music (like a C note) is analogous to "light" in painting, "shades" to dynamics, and "coloration" is to painting as the specific timbre of musical instruments is to music. These elements do not necessarily form a melody (in music) of themselves; rather, they can add different contexts to it.