One of the ways that we organize all the functionality provided by lldb is to use a hierarchical command structure, with nested commands. That means that when you first look at lldb, you see an organized set of commands mirroring the basic constructs in a debugger. Then we use aliases to make the most commonly used commands available in a couple of keystrokes. But when you start adding user commands, since they have to be root commands, you quickly overwhelm this orderly setup. To fix this problem, I'm adding the ability for users who add commands to also nest them in a sensible hierarchy.
This change keeps the "built-in" and the "user added" command hierarchies separate, you can't add user commands or multiword subtrees into the builtin commands. I think it would be too confusing if we started having user commands sprinkled among the built-in commands. I also don't allow you to add aliases into multiword command trees. The whole point of aliases is to make something available at the top level, so this didn't seem to make sense.
I apologize in advance for the size of the patch, but there really wasn't anything testable up till it was actually working, which is pretty much this patch.