/** * Exports the object as an array. * * You can specify the key type of the array by passing one of the class * type constants. * * @param string $keyType (optional) One of the class type constants BasePeer::TYPE_PHPNAME, BasePeer::TYPE_STUDLYPHPNAME, * BasePeer::TYPE_COLNAME, BasePeer::TYPE_FIELDNAME, BasePeer::TYPE_NUM. * Defaults to BasePeer::TYPE_PHPNAME. * @param boolean $includeLazyLoadColumns (optional) Whether to include lazy loaded columns. Defaults to TRUE. * @param boolean $includeForeignObjects (optional) Whether to include hydrated related objects. Default to FALSE. * * @return array an associative array containing the field names (as keys) and field values */ public function toArray($keyType = BasePeer::TYPE_PHPNAME, $includeLazyLoadColumns = true, $includeForeignObjects = false) { $keys = BookPeer::getFieldNames($keyType); $result = array($keys[0] => $this->getId(), $keys[1] => $this->getTitle(), $keys[2] => $this->getISBN(), $keys[3] => $this->getPrice(), $keys[4] => $this->getAuthorId()); if ($includeForeignObjects) { if (null !== $this->aAuthor) { $result['Author'] = $this->aAuthor->toArray($keyType, $includeLazyLoadColumns, true); } } return $result; }
/** * Exports the object as an array. * * You can specify the key type of the array by passing one of the class * type constants. * * @param string $keyType (optional) One of the class type constants BasePeer::TYPE_PHPNAME, BasePeer::TYPE_STUDLYPHPNAME, * BasePeer::TYPE_COLNAME, BasePeer::TYPE_FIELDNAME, BasePeer::TYPE_NUM. * Defaults to BasePeer::TYPE_PHPNAME. * @param boolean $includeLazyLoadColumns (optional) Whether to include lazy loaded columns. Defaults to true. * @param array $alreadyDumpedObjects List of objects to skip to avoid recursion * @param boolean $includeForeignObjects (optional) Whether to include hydrated related objects. Default to FALSE. * * @return array an associative array containing the field names (as keys) and field values */ public function toArray($keyType = BasePeer::TYPE_PHPNAME, $includeLazyLoadColumns = true, $alreadyDumpedObjects = array(), $includeForeignObjects = false) { if (isset($alreadyDumpedObjects['Book'][$this->getPrimaryKey()])) { return '*RECURSION*'; } $alreadyDumpedObjects['Book'][$this->getPrimaryKey()] = true; $keys = BookPeer::getFieldNames($keyType); $result = array($keys[0] => $this->getId(), $keys[1] => $this->getTitle(), $keys[2] => $this->getISBN(), $keys[3] => $this->getPrice(), $keys[4] => $this->getAuthorId()); if ($includeForeignObjects) { if (null !== $this->aAuthor) { $result['Author'] = $this->aAuthor->toArray($keyType, $includeLazyLoadColumns, $alreadyDumpedObjects, true); } } return $result; }
/** * Exports the object as an array. * * You can specify the key type of the array by passing one of the class * type constants. * * @param string $keyType (optional) One of the class type constants TableMap::TYPE_PHPNAME, TableMap::TYPE_STUDLYPHPNAME, * TableMap::TYPE_COLNAME, TableMap::TYPE_FIELDNAME, TableMap::TYPE_NUM. * Defaults to TableMap::TYPE_PHPNAME. * @param boolean $includeLazyLoadColumns (optional) Whether to include lazy loaded columns. Defaults to TRUE. * @param array $alreadyDumpedObjects List of objects to skip to avoid recursion * @param boolean $includeForeignObjects (optional) Whether to include hydrated related objects. Default to FALSE. * * @return array an associative array containing the field names (as keys) and field values */ public function toArray($keyType = TableMap::TYPE_PHPNAME, $includeLazyLoadColumns = true, $alreadyDumpedObjects = array(), $includeForeignObjects = false) { if (isset($alreadyDumpedObjects['Book'][$this->getPrimaryKey()])) { return '*RECURSION*'; } $alreadyDumpedObjects['Book'][$this->getPrimaryKey()] = true; $keys = BookTableMap::getFieldNames($keyType); $result = array($keys[0] => $this->getId(), $keys[1] => $this->getName(), $keys[2] => $this->getIsbn(), $keys[3] => $this->getAuthorId()); $virtualColumns = $this->virtualColumns; foreach ($virtualColumns as $key => $virtualColumn) { $result[$key] = $virtualColumn; } if ($includeForeignObjects) { if (null !== $this->aAuthor) { $result['Author'] = $this->aAuthor->toArray($keyType, $includeLazyLoadColumns, $alreadyDumpedObjects, true); } } return $result; }
public function testToArrayIncludesForeignReferrers() { $a1 = new Author(); $a1->setFirstName('Leo'); $a1->setLastName('Tolstoi'); $arr = $a1->toArray(BasePeer::TYPE_PHPNAME, null, array(), true); $this->assertFalse(array_key_exists('Books', $arr)); $b1 = new Book(); $b1->setTitle('War and Peace'); $b2 = new Book(); $b2->setTitle('Anna Karenina'); $a1->addBook($b1); $a1->addBook($b2); $arr = $a1->toArray(BasePeer::TYPE_PHPNAME, null, array(), true); $this->assertTrue(array_key_exists('Books', $arr)); $this->assertEquals(2, count($arr['Books'])); $this->assertEquals('War and Peace', $arr['Books']['Book_0']['Title']); $this->assertEquals('Anna Karenina', $arr['Books']['Book_1']['Title']); $this->assertEquals('*RECURSION*', $arr['Books']['Book_0']['Author']); }
/** * @param Author $author */ public function setAuthor(Author $author) { $this->attributes = array_merge($this->attributes, $author->toArray()); }
public function testToArray() { $author = new Author('James Bond <*****@*****.**>'); $this->assertSame(['name' => 'James Bond', 'email' => '*****@*****.**'], $author->toArray()); }