. */ namespace Doctrine\DBAL\Schema; use \Doctrine\DBAL\Types\Type; use Doctrine\DBAL\Schema\Visitor\Visitor; /** * Object representation of a database column * * * @link www.doctrine-project.org * @since 2.0 * @version $Revision$ * @author Benjamin Eberlei */ class Column extends AbstractAsset { /** * @var \Doctrine\DBAL\Types\Type */ protected $_type; /** * @var int */ protected $_length = null; /** * @var int */ protected $_precision = 10; /** * @var int */ protected $_scale = 0; /** * @var bool */ protected $_unsigned = false; /** * @var bool */ protected $_fixed = false; /** * @var bool */ protected $_notnull = true; /** * @var string */ protected $_default = null; /** * @var bool */ protected $_autoincrement = false; /** * @var array */ protected $_platformOptions = array(); /** * @var string */ protected $_columnDefinition = null; /** * @var string */ protected $_comment = null; /** * @var array */ protected $_customSchemaOptions = array(); /** * Create a new Column * * @param string $columnName * @param \Doctrine\DBAL\Types\Type $type * @param int $length * @param bool $notNull * @param mixed $default * @param bool $unsigned * @param bool $fixed * @param int $precision * @param int $scale * @param array $platformOptions */ public function __construct($columnName, Type $type, array $options=array()) { $this->_setName($columnName); $this->setType($type); $this->setOptions($options); } /** * @param array $options * @return Column */ public function setOptions(array $options) { foreach ($options as $name => $value) { $method = "set".$name; if (method_exists($this, $method)) { $this->$method($value); } } return $this; } /** * @param Type $type * @return Column */ public function setType(Type $type) { $this->_type = $type; return $this; } /** * @param int $length * @return Column */ public function setLength($length) { if($length !== null) { $this->_length = (int)$length; } else { $this->_length = null; } return $this; } /** * @param int $precision * @return Column */ public function setPrecision($precision) { if (!is_numeric($precision)) { $precision = 10; // defaults to 10 when no valid precision is given. } $this->_precision = (int)$precision; return $this; } /** * @param int $scale * @return Column */ public function setScale($scale) { if (!is_numeric($scale)) { $scale = 0; } $this->_scale = (int)$scale; return $this; } /** * * @param bool $unsigned * @return Column */ public function setUnsigned($unsigned) { $this->_unsigned = (bool)$unsigned; return $this; } /** * * @param bool $fixed * @return Column */ public function setFixed($fixed) { $this->_fixed = (bool)$fixed; return $this; } /** * @param bool $notnull * @return Column */ public function setNotnull($notnull) { $this->_notnull = (bool)$notnull; return $this; } /** * * @param mixed $default * @return Column */ public function setDefault($default) { $this->_default = $default; return $this; } /** * * @param array $platformOptions * @return Column */ public function setPlatformOptions(array $platformOptions) { $this->_platformOptions = $platformOptions; return $this; } /** * * @param string $name * @param mixed $value * @return Column */ public function setPlatformOption($name, $value) { $this->_platformOptions[$name] = $value; return $this; } /** * * @param string * @return Column */ public function setColumnDefinition($value) { $this->_columnDefinition = $value; return $this; } public function getType() { return $this->_type; } public function getLength() { return $this->_length; } public function getPrecision() { return $this->_precision; } public function getScale() { return $this->_scale; } public function getUnsigned() { return $this->_unsigned; } public function getFixed() { return $this->_fixed; } public function getNotnull() { return $this->_notnull; } public function getDefault() { return $this->_default; } public function getPlatformOptions() { return $this->_platformOptions; } public function hasPlatformOption($name) { return isset($this->_platformOptions[$name]); } public function getPlatformOption($name) { return $this->_platformOptions[$name]; } public function getColumnDefinition() { return $this->_columnDefinition; } public function getAutoincrement() { return $this->_autoincrement; } public function setAutoincrement($flag) { $this->_autoincrement = $flag; return $this; } public function setComment($comment) { $this->_comment = $comment; return $this; } public function getComment() { return $this->_comment; } /** * @param string $name * @param mixed $value * @return Column */ public function setCustomSchemaOption($name, $value) { $this->_customSchemaOptions[$name] = $value; return $this; } /** * @param string $name * @return boolean */ public function hasCustomSchemaOption($name) { return isset($this->_customSchemaOptions[$name]); } /** * @param string $name * @return mixed */ public function getCustomSchemaOption($name) { return $this->_customSchemaOptions[$name]; } /** * @param array $customSchemaOptions * @return Column */ public function setCustomSchemaOptions(array $customSchemaOptions) { $this->_customSchemaOptions = $customSchemaOptions; return $this; } /** * @return array */ public function getCustomSchemaOptions() { return $this->_customSchemaOptions; } /** * @param Visitor $visitor */ public function visit(\Doctrine\DBAL\Schema\Visitor $visitor) { $visitor->accept($this); } /** * @return array */ public function toArray() { return array_merge(array( 'name' => $this->_name, 'type' => $this->_type, 'default' => $this->_default, 'notnull' => $this->_notnull, 'length' => $this->_length, 'precision' => $this->_precision, 'scale' => $this->_scale, 'fixed' => $this->_fixed, 'unsigned' => $this->_unsigned, 'autoincrement' => $this->_autoincrement, 'columnDefinition' => $this->_columnDefinition, 'comment' => $this->_comment, ), $this->_platformOptions, $this->_customSchemaOptions); } }