Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
D
doctrine-dbal
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Tomáš Trávníček
doctrine-dbal
Commits
e5377453
Commit
e5377453
authored
May 27, 2012
by
Benjamin Eberlei
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #143 from schmittjoh/simpleArrayType
added simple_array type
parents
e29aa271
1760be64
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
126 additions
and
2 deletions
+126
-2
AbstractPlatform.php
lib/Doctrine/DBAL/Platforms/AbstractPlatform.php
+1
-1
JsonArrayType.php
lib/Doctrine/DBAL/Types/JsonArrayType.php
+59
-0
SimpleArrayType.php
lib/Doctrine/DBAL/Types/SimpleArrayType.php
+61
-0
Type.php
lib/Doctrine/DBAL/Types/Type.php
+5
-1
No files found.
lib/Doctrine/DBAL/Platforms/AbstractPlatform.php
View file @
e5377453
...
@@ -301,7 +301,7 @@ abstract class AbstractPlatform
...
@@ -301,7 +301,7 @@ abstract class AbstractPlatform
*/
*/
protected
function
initializeCommentedDoctrineTypes
()
protected
function
initializeCommentedDoctrineTypes
()
{
{
$this
->
doctrineTypeComments
=
array
(
Type
::
TARRAY
,
Type
::
OBJECT
);
$this
->
doctrineTypeComments
=
array
(
Type
::
TARRAY
,
Type
::
SIMPLE_ARRAY
,
Type
::
JSON_ARRAY
,
Type
::
OBJECT
);
}
}
/**
/**
...
...
lib/Doctrine/DBAL/Types/JsonArrayType.php
0 → 100755
View file @
e5377453
<?php
/*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL. For more information, see
* <http://www.doctrine-project.org>.
*/
namespace
Doctrine\DBAL\Types
;
/**
* Array Type which can be used to generate json arrays.
*
* @since 2.3
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
*/
class
JsonArrayType
extends
Type
{
public
function
getSQLDeclaration
(
array
$fieldDeclaration
,
\Doctrine\DBAL\Platforms\AbstractPlatform
$platform
)
{
return
$platform
->
getClobTypeDeclarationSQL
(
$fieldDeclaration
);
}
public
function
convertToDatabaseValue
(
$value
,
\Doctrine\DBAL\Platforms\AbstractPlatform
$platform
)
{
if
(
null
===
$value
)
{
return
null
;
}
return
json_encode
(
$value
);
}
public
function
convertToPHPValue
(
$value
,
\Doctrine\DBAL\Platforms\AbstractPlatform
$platform
)
{
if
(
$value
===
null
)
{
return
array
();
}
$value
=
(
is_resource
(
$value
))
?
stream_get_contents
(
$value
)
:
$value
;
return
json_decode
(
$value
,
true
);
}
public
function
getName
()
{
return
Type
::
JSON_ARRAY
;
}
}
\ No newline at end of file
lib/Doctrine/DBAL/Types/SimpleArrayType.php
0 → 100755
View file @
e5377453
<?php
/*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL. For more information, see
* <http://www.doctrine-project.org>.
*/
namespace
Doctrine\DBAL\Types
;
/**
* Array Type which can be used for simple values.
*
* Only use this type if you are sure that your values cannot contain a ",".
*
* @since 2.3
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
*/
class
SimpleArrayType
extends
Type
{
public
function
getSQLDeclaration
(
array
$fieldDeclaration
,
\Doctrine\DBAL\Platforms\AbstractPlatform
$platform
)
{
return
$platform
->
getClobTypeDeclarationSQL
(
$fieldDeclaration
);
}
public
function
convertToDatabaseValue
(
$value
,
\Doctrine\DBAL\Platforms\AbstractPlatform
$platform
)
{
if
(
!
$value
)
{
return
null
;
}
return
implode
(
','
,
$value
);
}
public
function
convertToPHPValue
(
$value
,
\Doctrine\DBAL\Platforms\AbstractPlatform
$platform
)
{
if
(
$value
===
null
)
{
return
array
();
}
$value
=
(
is_resource
(
$value
))
?
stream_get_contents
(
$value
)
:
$value
;
return
explode
(
','
,
$value
);
}
public
function
getName
()
{
return
Type
::
SIMPLE_ARRAY
;
}
}
\ No newline at end of file
lib/Doctrine/DBAL/Types/Type.php
View file @
e5377453
...
@@ -34,6 +34,8 @@ use Doctrine\DBAL\Platforms\AbstractPlatform,
...
@@ -34,6 +34,8 @@ use Doctrine\DBAL\Platforms\AbstractPlatform,
abstract
class
Type
abstract
class
Type
{
{
const
TARRAY
=
'array'
;
const
TARRAY
=
'array'
;
const
SIMPLE_ARRAY
=
'simple_array'
;
const
JSON_ARRAY
=
'json_array'
;
const
BIGINT
=
'bigint'
;
const
BIGINT
=
'bigint'
;
const
BOOLEAN
=
'boolean'
;
const
BOOLEAN
=
'boolean'
;
const
DATETIME
=
'datetime'
;
const
DATETIME
=
'datetime'
;
...
@@ -56,6 +58,8 @@ abstract class Type
...
@@ -56,6 +58,8 @@ abstract class Type
/** The map of supported doctrine mapping types. */
/** The map of supported doctrine mapping types. */
private
static
$_typesMap
=
array
(
private
static
$_typesMap
=
array
(
self
::
TARRAY
=>
'Doctrine\DBAL\Types\ArrayType'
,
self
::
TARRAY
=>
'Doctrine\DBAL\Types\ArrayType'
,
self
::
SIMPLE_ARRAY
=>
'Doctrine\DBAL\Types\SimpleArrayType'
,
self
::
JSON_ARRAY
=>
'Doctrine\DBAL\Types\JsonArrayType'
,
self
::
OBJECT
=>
'Doctrine\DBAL\Types\ObjectType'
,
self
::
OBJECT
=>
'Doctrine\DBAL\Types\ObjectType'
,
self
::
BOOLEAN
=>
'Doctrine\DBAL\Types\BooleanType'
,
self
::
BOOLEAN
=>
'Doctrine\DBAL\Types\BooleanType'
,
self
::
INTEGER
=>
'Doctrine\DBAL\Types\IntegerType'
,
self
::
INTEGER
=>
'Doctrine\DBAL\Types\IntegerType'
,
...
@@ -191,7 +195,7 @@ abstract class Type
...
@@ -191,7 +195,7 @@ abstract class Type
if
(
!
isset
(
self
::
$_typesMap
[
$name
]))
{
if
(
!
isset
(
self
::
$_typesMap
[
$name
]))
{
throw
DBALException
::
typeNotFound
(
$name
);
throw
DBALException
::
typeNotFound
(
$name
);
}
}
if
(
isset
(
self
::
$_typeObjects
[
$name
]))
{
if
(
isset
(
self
::
$_typeObjects
[
$name
]))
{
unset
(
self
::
$_typeObjects
[
$name
]);
unset
(
self
::
$_typeObjects
[
$name
]);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment