The feature is described in the documentation, but maybe it got too few words (Which is not because we don't use it and don't want you to use it, but because it's so simple).
In the following I want to show you how to do this. You'll see that it is relatively straight forward.
Let's assume you have an existing Ecore model, describing a library of books (sounds familiar?;-)):
data:image/s3,"s3://crabby-images/7a69f/7a69f8a54428ce49946d4b19548dc1db4d040492" alt=""
data:image/s3,"s3://crabby-images/d1100/d11008650970c24ce1654db469f3f082182c969a" alt=""
Next, you run Xtext's generator and you'll get an EMF Resource writing and reading instances of your Ecore model to the textual syntax defined in aboves Xtext grammar.
In addition you'll get an editor for your new language :
data:image/s3,"s3://crabby-images/00db4/00db48559413c55fcaec188b74dd52abd27166fe" alt=""
You can, of course, still use any EMF-based editor, since it's just an EMF model:
data:image/s3,"s3://crabby-images/c436f/c436f7b55f1472ab151f32275eb54103d3659c69" alt=""
Note, that you cannot only import multiple Ecore models but can even mix generated and imported Ecore models in the same grammar.
To sum it up: The feature we have in Xtext to derive an Ecore model from the grammar description, is a very convenient option to get you started. If you have one or more existing Ecore models, you won't want and need to use it. But if you start developing a new language this feature speeds up your turn-arounds dramatically.