Hi,
I'll leave discussion about code simplification aside, because I know the evil hides in the details, and I have a far too vague idea of the internal code to make up my mind (and I doubt arguing about virtual code complexity at this level will lead to any decisive point).
My opinion is the following:
the main point with the thing->path paradigm is that you cannot edit the style of the output. This is by desing, and I'm happy this choice was made, and I think it was a smart choice: we now have our good working and simple to implement lpes! On the other hand, we will sooner or later want to have LOEs (live-"object"-effects) to allow more sophisticated effect (like interpolate shape+style between two objects).
I think we should keep lpes as they are and implement the more sophisticated LOEs. Once they work correctly, we'll can move the lpes to be special cases of LOEs.
Doing the move Kzysztof suggests seem to be more or less equivalent to implementing LOE (am I wrong there?)... The main point is to allow other things than paths (virtually any independent well formed svg object) as output which is the main benefit I see in this representation. Moreover it looks deep and difficult, so there is no hurry anyway. So what about starting to work on LOE's instead of changing LPE's?
Btw, I think the good output for the example of bulia would be:
<svg:switch>
<inkscape:envelope-deformation>