From 29366bb9c77aaaa8ecd668e419cc90067c6f1837 Mon Sep 17 00:00:00 2001
From: Mark Fox <mark@ixel.org>
Date: Sat, 17 Aug 2013 21:15:03 -0700
Subject: [PATCH] Updated require version and my earlier errors dissolved

As stated, the tutorial was written for 2.4.x, but the composer.json settings proffered would install 2.3.4, which has a different enough API that basic parts of the tutorial code would fail.
---
 docs/en/tutorials/getting-started.rst | 37 ++++++++-------------------
 1 file changed, 11 insertions(+), 26 deletions(-)

diff --git a/docs/en/tutorials/getting-started.rst b/docs/en/tutorials/getting-started.rst
index 1e88f8538..4038947c7 100644
--- a/docs/en/tutorials/getting-started.rst
+++ b/docs/en/tutorials/getting-started.rst
@@ -87,14 +87,16 @@ the following contents:
 
     {
         "require": {
-            "doctrine/orm": "2.*",
+            "doctrine/orm": "2.4.*",
             "symfony/yaml": "2.*"
         },
         "autoload": {
             "psr-0": {"": "src/"}
-        }
+        },
+        "minimum-stability" : "dev"
     }
 
+
 Install Doctrine using the Composer Dependency Management tool, by calling:
 
 ::
@@ -105,30 +107,14 @@ This will install the packages Doctrine Common, Doctrine DBAL, Doctrine ORM,
 Symfony YAML and Symfony Console into the `vendor` directory. The Symfony 
 dependencies are not required by Doctrine but will be used in this tutorial.
 
-This is the current directory structure:
-
+Add the following directories:
 ::
 
     doctrine2-tutorial
-    |-- composer.json
-    `-- vendor
-
-Next we'll create a basic bootstrapped application that uses the Symfony 
-Console to interact with Doctrine via the command line.
-
-Here's a preview of what we'll add:
-  
-::
-
-    doctrine2-tutorial
-    |-- bootstrap.php
-    |-- cli-config.php
-    |-- composer.json
     |-- config
     |   |-- xml
     |   `-- yaml
-    |-- src
-    `-- vendor
+    `-- src
 
 Obtaining the EntityManager
 ---------------------------
@@ -145,13 +131,14 @@ step:
     <?php
     // bootstrap.php
     use Doctrine\ORM\Tools\Setup;
+    use Doctrine\ORM\EntityManager;
     
     require_once "vendor/autoload.php";
     
-    // Create a simple "default" Doctrine ORM configuration for XML Mapping
+    // Create a simple "default" Doctrine ORM configuration for Annotations
     $isDevMode = true;
     $config = Setup::createAnnotationMetadataConfiguration(array(__DIR__."/src"), $isDevMode);
-    // or if you prefer yaml or annotations
+    // or if you prefer yaml or XML
     //$config = Setup::createXMLMetadataConfiguration(array(__DIR__."/config/xml"), $isDevMode);
     //$config = Setup::createYAMLMetadataConfiguration(array(__DIR__."/config/yaml"), $isDevMode);
     
@@ -162,7 +149,7 @@ step:
     );
     
     // obtaining the entity manager
-    $entityManager = \Doctrine\ORM\EntityManager::create($conn, $config);
+    $entityManager = EntityManager::create($conn, $config);
 
 The first require statement sets up the autoloading capabilities of Doctrine
 using the Composer autoload.
@@ -200,9 +187,7 @@ doctrine command. Its a fairly simple file:
     // cli-config.php
     require_once "bootstrap.php";
     
-    $helperSet = new \Symfony\Component\Console\Helper\HelperSet(array(
-        'em' => new \Doctrine\ORM\Tools\Console\Helper\EntityManagerHelper($entityManager)
-    ));
+    return \Doctrine\ORM\Tools\Console\ConsoleRunner::createHelperSet($entityManager);
 
 You can then change into your project directory and call the
 Doctrine command-line tool: