C:\xampp\htdocs\landing\wp-content\plugins\wordpress-seo\lib\migrations\column.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
<?php

namespace Yoast\WP\Lib\Migrations;

use 
Exception;

/**
 * Yoast migrations column class.
 */
class Column {

    
/**
     * The adapter.
     *
     * @var Adapter
     */
    
private $adapter;

    
/**
     * The name.
     *
     * @var string
     */
    
public $name;

    
/**
     * The type.
     *
     * @var mixed
     */
    
public $type;

    
/**
     * The properties.
     *
     * @var mixed
     */
    
public $properties;

    
/**
     * The options.
     *
     * @var array
     */
    
private $options = [];

    
/**
     * Creates an instance of a column.
     *
     * @param Adapter $adapter The current adapter.
     * @param string  $name    The name of the column.
     * @param string  $type    The type of the column.
     * @param array   $options The column options.
     *
     * @throws Exception If invalid arguments provided.
     *
     * @return Column
     */
    
public function __construct$adapter$name$type$options = [] ) {
        if ( ! 
$adapter instanceof Adapter ) {
            throw new 
Exception'Invalid Adapter instance.' );
        }
        if ( empty( 
$name ) || ! \is_string$name ) ) {
            throw new 
Exception"Invalid 'name' parameter" );
        }
        if ( empty( 
$type ) || ! \is_string$type ) ) {
            throw new 
Exception"Invalid 'type' parameter" );
        }
        
$this->adapter $adapter;
        
$this->name    $name;
        
$this->type    $type;
        
$this->options $options;
    }

    
/**
     * Returns the SQL of this column.
     *
     * @return string
     */
    
public function to_sql() {
        
$column_sql  = \sprintf'%s %s'$this->adapter->identifier$this->name ), $this->sql_type() );
        
$column_sql .= $this->adapter->add_column_options$this->type$this->options );
        return 
$column_sql;
    }

    
/**
     * The SQL string version.
     *
     * @return string
     */
    
public function __toString() {
        return 
$this->to_sql();
    }

    
/**
     * The SQL type.
     *
     * @return string
     */
    
private function sql_type() {
        return 
$this->adapter->type_to_sql$this->type$this->options );
    }
}
x

Windows NT KPTV 6.2 build 9200 (Windows Server 2012 Datacenter Edition) i586