Overall unfamiliarity with the concept. For people who have a passing acquaintance with algebra (or even basic arithmetic) or have used at least one other programming language, much of Python is intuitive. Very few people will have had any experience with the decorator concept before encountering it in Python. There's just no strong preexisting meme that captures the concept.
Aesthetics is the study of art and beauty; it was an important issue for 18th- and 19th-century philosophers such as Kant and Hegel. Classical philosophers like Plato and Aristotle also theorized about art and painting in particular. Plato disregarded painters (as well as sculptors) in his philosophical system; he maintained that painting cannot depict the truth—it is a copy of reality (a shadow of the world of ideas) and is nothing but a craft, similar to shoemaking or iron casting. By the time of Leonardo, painting had become a closer representation of the truth than painting was in Ancient Greece. Leonardo da Vinci, on the contrary, said that "Italian: La Pittura è cosa mentale" ("English: painting is a thing of the mind"). Kant distinguished between Beauty and the Sublime, in terms that clearly gave priority to the former. Although he did not refer to painting in particular, this concept was taken up by painters such as J.M.W. Turner and Caspar David Friedrich.
Aerosol paint (also called spray paint) is a type of paint that comes in a sealed pressurized container and is released in a fine spray mist when depressing a valve button. A form of spray painting, aerosol paint leaves a smooth, evenly coated surface. Standard sized cans are portable, inexpensive and easy to store. Aerosol primer can be applied directly to bare metal and many plastics.
As an example, consider a window in a windowing system. To allow scrolling of the window's contents, one may wish to add horizontal or vertical scrollbars to it, as appropriate. Assume windows are represented by instances of the Window interface, and assume this class has no functionality for adding scrollbars. One could create a subclass ScrollingWindow that provides them, or create a ScrollingWindowDecorator that adds this functionality to existing Window objects. At this point, either solution would be fine.
This code works for our purposes but it’s not exactly dynamic. If we wanted our initial simpleMsg object to sometimes act excited and sometimes quizzical, we could only do so by instantiating entirely new objects from the relevant subclass. Moreover, the ExcitedAndQuizzicalMessage is really just a combination of ExcitedMessage and QuizzicalMessage and probably shouldn’t have its own class. To fix these problems, let’s now return to the decorator pattern and see how it might help us.
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:
Moreover, the use of language is only an abstraction for a color equivalent. The word "red", for example, can cover a wide range of variations from the pure red of the visible spectrum of light. There is not a formalized register of different colors in the way that there is agreement on different notes in music, such as F or C♯. For a painter, color is not simply divided into basic (primary) and derived (complementary or mixed) colors (like red, blue, green, brown, etc.).