diff --git a/activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb b/activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb
index 555a611e68..ffc3847a31 100644
--- a/activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb
+++ b/activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb
@@ -103,15 +103,14 @@ module ActiveRecord
# The +options+ hash can include the following keys:
# [:id]
# Whether to automatically add a primary key column. Defaults to true.
- # Join tables for +has_and_belongs_to_many+ should set :id => false.
+ # Join tables for +has_and_belongs_to_many+ should set it to false.
# [:primary_key]
# The name of the primary key, if one is to be added automatically.
- # Defaults to +id+. You must NOT pass :id => false otherwise :primary_key option
- # will have no effect.
+ # Defaults to +id+. If :id is false this option is ignored.
#
- # Also note that this just sets the primary_key in the table. You still need to
- # add :set_primary_key => '' in the model to tell model what column is the
- # primary_key. Models do NOT auto-detect the primary_key from table defintion.
+ # Also note that this just sets the primary key in the table. You additionally
+ # need to configure the primary key in the model via the +set_primary_key+ macro.
+ # Models do NOT auto-detect the primary key from their table definition.
#
# [:options]
# Any extra options you want appended to the table definition.
diff --git a/railties/guides/source/active_support_core_extensions.textile b/railties/guides/source/active_support_core_extensions.textile
index de0c00ac68..58824d7aeb 100644
--- a/railties/guides/source/active_support_core_extensions.textile
+++ b/railties/guides/source/active_support_core_extensions.textile
@@ -1107,50 +1107,54 @@ If for whatever reason an application loads the definition of a mailer class and
NOTE: Defined in +active_support/core_ext/class/delegating_attributes.rb+.
-h4. Descendants & Subclasses
-
-h5. +descendants+
-
-The +descendants+ method returns all classes, including its children, that inherits from self.
-
-
-class C; end
-C.descendants #=> []
-
-class B < C; end
-C.descendants #=> [B]
-
-class A < B; end
-C.descendants #=> [B, A]
-
-class D < C; end
-C.descendants #=> [B, A, D]
-
+h4. Subclasses & Descendants
h5. +subclasses+
-The +subclasses+ method returns all direct classes that inherits from self.
+The +subclasses+ method returns the subclasses of the receiver:
class C; end
-C.subclasses #=> []
+C.subclasses # => []
class B < C; end
-C.subclasses #=> [B]
+C.subclasses # => [B]
class A < B; end
-C.subclasses #=> [B]
+C.subclasses # => [B]
class D < C; end
-C.subclasses #=> [B, D]
+C.subclasses # => [B, D]
-The order in which these class are returned is unspecified.
+The order in which these classes are returned is unspecified.
WARNING: This method is redefined in some Rails core classes but should be all compatible in Rails 3.1.
NOTE: Defined in +active_support/core_ext/class/subclasses.rb+.
+h5. +descendants+
+
+The +descendants+ method returns all classes that are < than its receiver:
+
+
+class C; end
+C.descendants # => []
+
+class B < C; end
+C.descendants # => [B]
+
+class A < B; end
+C.descendants # => [B, A]
+
+class D < C; end
+C.descendants # => [B, A, D]
+
+
+The order in which these classes are returned is unspecified.
+
+NOTE: Defined in +active_support/core_ext/class/subclasses.rb+.
+
h3. Extensions to +String+
h4. Output Safety