Skip to content

FamilyTree::getAddress

James Cobban edited this page Mar 9, 2021 · 2 revisions

$tree->getAddress($idar)

Up: class FamilyTree

This is a factory method to get an instance of class Address. It takes one parameter:

parameter description
$idar the value of unique numeric key 'idar'

This returns a shared instance of class Address which is identified by the value of 'idar'. This differs from new Address(array('idar' => $idar)) in that if the current application process has previously created an instance of class Address for that value of 'idar' by calling $tree->getAddress($idar) then $tree->getAddress($idar) returns that existing instance rather than creating a new instance.

This has two advantages:

  1. If the current thread has previously created an instance then this is much faster than creating a new entry, which would, among other things, require reading the record from the database again.
  2. If all parts of the application use $tree->getAddress($idar) then all parts of the application will be using the same copy of the object and all changes made by any part of the application will be reflected when the instance is saved to the database by any part of the application.

This method invokes the static class function Address::getAddress($idar).

Next: $tree->getSource($idsr)

Clone this wiki locally