Browse Source

Merge pull request #370 from cviebrock/develop

Add unsigned() modifier, so you can create unsigned integer columns.
Taylor Otwell 13 years ago
parent
commit
ebcae547fa

+ 15 - 0
laravel/database/schema/grammars/grammar.php

@@ -39,4 +39,19 @@ abstract class Grammar extends \Laravel\Database\Grammar {
 		return parent::wrap($value);
 	}
 
+	/**
+	 * Get the SQL syntax for indicating if a column is unsigned.
+	 *
+	 * @param  Table   $table
+	 * @param  Fluent  $column
+	 * @return string
+	 */
+	protected function unsigned(Table $table, Fluent $column)
+	{
+		if ($column->type == 'integer' && $column->unsigned)
+		{
+			return ' UNSIGNED';
+		}
+	}
+
 }

+ 1 - 1
laravel/database/schema/grammars/mysql.php

@@ -77,7 +77,7 @@ class MySQL extends Grammar {
 			// types to the correct types.
 			$sql = $this->wrap($column).' '.$this->type($column);
 
-			$elements = array('nullable', 'defaults', 'incrementer');
+			$elements = array('unsigned', 'nullable', 'defaults', 'incrementer');
 
 			foreach ($elements as $element)
 			{

+ 1 - 1
laravel/database/schema/grammars/postgres.php

@@ -65,7 +65,7 @@ class Postgres extends Grammar {
 			// types to the types used by the database.
 			$sql = $this->wrap($column).' '.$this->type($column);
 
-			$elements = array('incrementer', 'nullable', 'defaults');
+			$elements = array('unsigned', 'incrementer', 'nullable', 'defaults');
 
 			foreach ($elements as $element)
 			{

+ 1 - 1
laravel/database/schema/grammars/sqlite.php

@@ -91,7 +91,7 @@ class SQLite extends Grammar {
 			// types to the types used by the database.
 			$sql = $this->wrap($column).' '.$this->type($column);
 
-			$elements = array('nullable', 'defaults', 'incrementer');
+			$elements = array('unsigned', 'nullable', 'defaults', 'incrementer');
 
 			foreach ($elements as $element)
 			{

+ 1 - 1
laravel/database/schema/grammars/sqlserver.php

@@ -72,7 +72,7 @@ class SQLServer extends Grammar {
 			// types to the types used by the database.
 			$sql = $this->wrap($column).' '.$this->type($column);
 
-			$elements = array('incrementer', 'nullable', 'defaults');
+			$elements = array('unsigned', 'incrementer', 'nullable', 'defaults');
 
 			foreach ($elements as $element)
 			{