Attachments
Screen shot 2011-03-18 at 11.17.22 AM.png
Main screen at time of hang
Screen shot 2011-03-18 at 11.32.41 AM.png
sample process: stack trace
Votes
For: 3 (100%)
Against: 0 (0%)
Total: 3
March 18, 2011 03:22 PM
Alan Pinstein
While debugging, I am often running into situations where "stepping" stops working. It looks like it's getting confused on a "step" as the variable inspector goes blank, and then stepping no longer works. The stack looks accurate, though. There is no beach ball, just it's hung. Hitting STOP works in that the STOP button will be greyed out but PHP is still stuck. If you then QUIT, it works though, no need to force-quit, and at that point the PHP process under debug "continues".
It seems to be repeatable; that is if you completely restart MacGDBp it will hang in the exact same spot.
I've gotten some info from the connection log for you that will hopefully help.
This is the XML of the last successful RECV.
<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1"
xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="source"
transaction_id="27"
encoding="base64"><![CDATA[<?php

interface WFModelBuilder
{
    // get a WFModelEntity for the given entity name
    function buildEntityModel($entity);
}

// PHOCOA WFModel Class Structure -- internal representation of the object model. Decoupled from the implementations.
class WFModel extends WFObject
{
    protected $builder = NULL;

    protected $entities = array();
    static private $_instance = NULL;

    function sharedModel()
    {
        if (!self::$_instance)
        {
            self::$_instance = new WFModel;
        }
        return self::$_instance;
    }

    function __toString()
    {
        $str = NULL;
        foreach ($this->entities as $entity) {
            $str .= "\n" . $entity->valueForKey('name');
            foreach ($entity->getProperties() as $property) {
                $str .= "\n - " . $property->valueForKey('name') . " (" . $property->valueForKey('type') . ")";
            }
            foreach ($entity->getRelationships() as $rel) {
                $str .= "\n > " . $rel->valueForKey('name') . " (" . ($rel->valueForKey('toOne') ? 'to-one' : 'to-many') . ($rel->valueForKey('isExtension') ? ' [EXT]' : NULL) . ", " . ($rel->valueForKey('required') ? 'required' : 'optional') . ")";
            }
        }
        $str .= "\n\n";
        return $str;
    }

    public function addEntity($entity)
    {
        $this->entities[$entity->valueForKey('name')] = $entity;
    }

    public function entities()
    {
        return $this->entities;
    }

    public function getEntity($name)
    {
        if (isset($this->entities[$name])) return $this->entities[$name];
        return NULL;
    }

    public function buildEntity($entityName)
    {
        if (isset($this->entities[$entityName]))
        {
            throw( new WFException("Entity {$entityName} is already built. Use WFModel::getEntity().") );
            return $this->getEntity($entityName);
        }

        // create entity
        $entity = new WFModelEntity;
        $entity->setValueForKey($entityName, 'name');
        $this->addEntity($entity);
        $this->builder->buildEntityModel($entity);

        return $entity;
    }

    public function buildModel($adapter, $configFile, $buildEntities)
    {
        // bootstrap
        $builderClass = 'WFModelBuilder' . $adapter;
        $this->builder = new $builderClass;
        $this->builder->setup();
        foreach ($buildEntities as $entity) {
            $this->buildEntity($entity);
        }

        if (file_exists($configFile))
        {
            // READ CONFIG - read a config YAML file and "override" settings in various entities, such as descriptiveColumnName, or cardinality:
            $config = WFYaml::load($configFile);
            // Blog:
            //   descriptiveColumnName: name
            //   relationships:
            //     BlogPreferences:
            //       minCount: 0
            //       maxCount: NULL
            //       isExtension: true

            // apply config
            foreach ($config as $entityName => $entityConfig) {
                try {
                    $entity = $this->getEntity($entityName);
                } catch (WFException $e) {
                    print "WARNING: Entity {$entityName} not loaded...\n";
                    continue;
                }
                foreach ($entityConfig as $key => $config) {
                    switch ($key) {
                        case 'relationships':
                            foreach ($config as $relationshipName => $relationshipConfig) {
                                $rel = $entity->getRelationship($relationshipName);
                                if (!$rel)
                                {
                                    print "WARNING: Relationship: {$relationshipName} of Entity {$entityName} not loaded...\n";
                                    continue;
                                }
                                foreach ($relationshipConfig as $key => $value) {
                                    if ($key === 'inverseRelationship')
                                    {
                                        list($entityName, $relName) = explode('.', $value);
                                        if (!$entityName or !$relName) throw( new WFException("inverseRelationship format must be <entityName>.<relationshipName>") );
                                        if (!$this->getEntity($entityName))
                                        {
                                            $invEntity = new WFModelEntity;
                                            $invEntity->setValueForKey($entityName, 'name');
                                            $this->builder->buildEntityModel($invEntity);
                                            $this->addEntity($invEntity);
                                        }
                                        $rel->setInverseRelationship($this->getEntity($entityName)->getRelationship('relName'));
                                    }
                                    else
                                    {
                                        $rel->setValueForKey($value, $key);
                                    }
                                }
                            }
                            break;
                        case 'properties':
                            foreach ($config as $propertyName => $propertyConfig) {
                                $property = $entity->getProperty($propertyName);
                                if (!$property)
                                {
                                    print "WARNING: Property: {$propertyName} of Entity {$entityName} not loaded...\n";
                                    continue;
                                }
                                foreach ($propertyConfig as $key => $value) {
                                    switch ($key) {
                                        case 'type':
                                            $value = eval("return {$value};");
                                            break;
                                    }
                                    $property->setValueForKey($value, $key);
                                }
                            }
                            break;
                        default:
                            $entity->setValueForKey($config, $key);
                            break;
                    }
                }
            }
        }
    }
}

class WFModelEntity extends WFObject
{
    protected $name = NULL;
    protected $primaryKeyProperty = NULL;
    protected $descriptiveColumnName = NULL;
    protected $properties = array();
    protected $relationships = array();

    public function addProperty($property)
    {
        if (!($property instanceof WFModelEntityProperty)) throw( new WFException("addProperty parameter must be a WFModelEntityProperty.") );
        $this->properties[$property->valueForKey('name')] = $property;
        return $this;
    }
    public function getProperty($name)
    {
        if (isset($this->properties[$name])) return $this->properties[$name];
        return NULL;
    }
    public function getProperties()
    {
        return $this->properties;
    }

    public function addRelationship($rel)
    {
        if (!$rel->valueForKey('name')) throw( new WFException("Relationships must have a name before being added.") );
        if (!($rel instanceof WFModelEntityRelationship)) throw( new WFException("addRelationship parameter must be a WFModelEntityRelationship.") );
        if (isset($this->relationships[$rel->valueForKey('name')])) throw( new WFException("Relationship " . $rel->valueForKey('name') . " already exists for entity " . $this->valueForKey('name')) );
        $this->relationships[$rel->valueForKey('name')] = $rel;
        return $this;
    }
    public function getRelationship($name)
    {
        if (isset($this->relationships[$name])) return $this->relationships[$name];
        return NULL;
    }
    public function getRelationships()
    {
        return $this->relationships;
    }
}
class WFModelEntityProperty extends WFObject
{
    protected $name = NULL;
    protected $type = WFModelEntityProperty::TYPE_STRING;
    protected $defaultValue = NULL;

    const TYPE_STRING = 'string';
    const TYPE_TEXT = 'text';
    const TYPE_NUMBER = 'number';
    const TYPE_DATETIME = 'datetime';
    const TYPE_TIME = 'time';
    const TYPE_DATE = 'date';
    const TYPE_BOOLEAN = 'boolean';
}
class WFModelEntityRelationship extends WFObject
{
    protected $name = NULL;     // a call to get{$name} on the entity should fetch the related object(s)
    protected $isExtension = false; // extensions are to-one relationships that use the same id field in both tables and the related table stores "extended" properties. The extended table is basically a "grouping" of properties for the primary entity.
    protected $toOne = true;    // TRUE = to-one, FALSE = to-many
    protected $required = false;    // orthogonal to minCount; minCount is only enforced if there is a relationship. Required disallows lack of related object(s).
    protected $minCount = 1;
    protected $maxCount = 1;
    protected $inverseRelationship = NULL;

    function setToOne($isToOne)
    {
        if (!is_bool($isToOne)) throw( new WFException("boolean expected.") );
        $this->toOne = $isToOne;
        $this->minCount = $this->maxCount = ($this->toOne ? 1 : NULL);
    }
    function setMinCount($num)
    {
        if ($this->toOne) throw( new WFException("Can't set minCount on to-one relationships.") );
        $this->minCount = $num;
    }
    function setMaxCount($num)
    {
        if ($this->toOne) throw( new WFException("Can't set maxCount on to-one relationships.") );
        $this->maxCount = $num;
    }
    function setInverseRelationship($r)
    {
        if (!($r instanceof WFModelEntityRelationship)) throw( new WFException("Relationship must be a WFModelEntityRelationship.") );
        $this->inverseRelationship = $r;
    }
}

// PHOCOA Code-Gen Classes
// Right now, hard-coded for Propel; refactor later to call out to builder classes for things like entity lookup code (any ORM-specific stuff)
class WFModelCodeGenPropel extends WFObject
{
    protected $smarty = NULL;
    protected $modulePath = NULL;

    function __construct()
    {
        $this->smarty = new WFSmarty;
        $this->smarty->left_delimiter = '{{';
        $this->smarty->right_delimiter = '}}';

        // figure out modulePath
        // walk up PWD until we hit "modules" and use that.
        $dir = getcwd();
        $parts = explode('/', $dir);
        $this->modulePath = NULL;
        foreach ($parts as $part) {
            if ($this->modulePath === NULL)
            {
                if ($part == 'modules')
                {
                    $this->modulePath = WWW_ROOT;
                    continue;
                }
            }
            else
            {
                $this->modulePath .= '/' . $part;
            }
        }
        $this->modulePath .= '/';
    }

    function generateModuleForEntity($entity)
    {
        print "Generating module for entity '" . $entity->valueForKey('name') . "'\n";
        $cwd = getcwd();
        $moduleName = strtolower( $entity->valueForKey('name') );
        $moduleDir = $cwd . '/' . $moduleName;
        if (file_exists($moduleDir))
        {
            print "WARNING: Module $moduleName already exists. Skipping\n";
            return;
        }

        mkdir($moduleDir); // module dir
        $this->modulePath .= $moduleName;

        // setup shared instances
        $sharedYaml[$entity->valueForKey('name')] = array(
                'class' => 'WFArrayController',
                'properties' => array(
                    'class' => $entity->valueForKey('name'),
                    'classIdentifiers' => $entity->valueForKey('primaryKeyProperty'),
                    'selectOnInsert' => true,
                    'automaticallyPreparesContent' => false
                    )
                );
        $sharedYaml['paginator'] = array(
                'class' => 'WFPaginator',
                'properties' => array(
                    'modeForm' => 'search',
                    'pageSize' => 25,
                    'itemPhraseSingular' => $entity->valueForKey('name'),
                    'itemPhrasePlural' => $entity->valueForKey('name') . 's'
                    )
                );
        file_put_contents($moduleDir . '/shared.yaml', WFYaml::dump($sharedYaml));

        $sharedEntityId = $entity->valueForKey('name');

        // build module code
        $this->smarty->assign('moduleName', $moduleName);
        $this->smarty->assign('entity', $entity);
        $this->smarty->assign('entityName', $entity->valueForKey('name'));
        $this->smarty->assign('sharedEntityId', $sharedEntityId);
        $this->smarty->assign('sharedEntityPrimaryKeyProperty', $entity->valueForKey('primaryKeyProperty'));
        $this->smarty->assign('descriptiveColumnName', $entity->valueForKey('descriptiveColumnName'));

        // look up Peer column constant name from the PHP name; call ObjPeer::translateFieldName($name, $fromType, $toType)
        $translateF = array($entity->valueForKey('name') . 'Peer', 'translateFieldName');
        $peerColName = call_user_func($translateF, ucfirst($entity->valueForKey('descriptiveColumnName')), BasePeer::TYPE_PHPNAME, BasePeer::TYPE_FIELDNAME);
        $this->smarty->assign('descriptiveColumnConstantName', strtoupper($peerColName));

        $moduleCode = $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/module.tpl');
        file_put_contents($moduleDir . '/' . $moduleName . '.php', $moduleCode);

        // build list page
        // list.yaml
        $listYaml = array();
        $listFormId = 'search' . $entity->valueForKey('name') . 'Form';
        $listYaml[$listFormId] = array(
                'class' => 'WFForm', 'children' => array(
                    'search' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Search'
                            ),
                        ),
                    'clear' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Clear'
                            ),
                        ),
                    'paginatorState' => array(
                        'class' => 'WFPaginatorState',
                        'properties' => array('paginator' => '#module#paginator')
                        ),
                    'query' => array('class' => 'WFTextField'),
                    )
                );
        $listYaml['paginatorNavigation'] = array(
                'class' => 'WFPaginatorNavigation',
                'properties' => array('paginator' => '#module#paginator'),
                );
        $listYaml['paginatorPageInfo'] = array(
                'class' => 'WFPaginatorPageInfo',
                'properties' => array('paginator' => '#module#paginator'),
                );

        $descriptiveColumnName = $entity->valueForKey('descriptiveColumnName');
        $listYaml[$descriptiveColumnName] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "{$descriptiveColumnName}Prototype" => array(
                        'class' => 'WFLink',
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/detail/%1%')
                                ),
                            'label' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('descriptiveColumnName')
                                )
                            )
                        )
                    )
                    );
        $listYaml['editLink'] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "editLinkPrototype" => array(
                        'class' => 'WFLink',
                        'properties' => array('label' => 'Edit'),
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/edit/%1%')
                                )
                            )
                        ) 
                    )
                );
        $listYaml['deleteLink'] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "deleteLinkPrototype" => array(
                        'class' => 'WFLink',
                        'properties' => array('label' => 'Delete'),
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/confirmDelete/%1%')
                                )
                            )
                        ) 
                    )
                );
        file_put_contents($moduleDir . '/list.yaml', WFYaml::dump($listYaml));

        // build list.tpl
        $this->smarty->assign('listFormId', $listFormId);
        file_put_contents($moduleDir . '/list.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/list.tpl'));

        // build edit page
        // build edit.yaml
        $editYaml = array();
        $editFormId = 'edit' . $entity->valueForKey('name') . 'Form';
        $editYaml[$editFormId] = array('class' => 'WFForm', 'children' => array());

        $widgets = array();
        foreach ($entity->getProperties() as $property) {
            $widgetID = $property->valueForKey('name');
            $widgets[$widgetID] = $property;

            if ($property->valueForKey('name') === $entity->valueForKey('primaryKeyProperty'))
            {
                $class = 'WFHidden';
            }
            else
            {
                switch ($property->valueForKey('type')) {
                    case WFModelEntityProperty::TYPE_TEXT;
                        $class = 'WFTextArea';
                        break;
                    case WFModelEntityProperty::TYPE_NUMBER;
                    case WFModelEntityProperty::TYPE_STRING;
                    case WFModelEntityProperty::TYPE_DATETIME;
                    case WFModelEntityProperty::TYPE_TIME;
                    case WFModelEntityProperty::TYPE_DATE;
                        $class = 'WFTextField';
                        break;
                    case WFModelEntityProperty::TYPE_BOOLEAN;
                        $class = 'WFCheckbox';
                        break;
                    default:
                        $class = 'WFTextField';
                }
            }
            $editYaml[$editFormId]['children'][$widgetID] = array(
                    'class' => $class,
                    'bindings' => array(
                        'value' => array(
                            'instanceID' => $sharedEntityId,
                            'controllerKey' => 'selection',
                            'modelKeyPath' => $widgetID
                            )
                        )
                    );

        }
        // status message
        $editYaml['statusMessage'] = array('class' => 'WFMessageBox');
        $editYaml[$editFormId]['children']['saveNew'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Create ' . $entity->valueForKey('name'),
                    'action' => 'save'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        'options' => array(
                            'valueTransformer' => 'WFNegateBoolean',
                            )
                        )
                    )
                );
        $editYaml[$editFormId]['children']['save'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Save'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        )
                    )
                );
        $editYaml[$editFormId]['children']['deleteObj'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Delete'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        )
                    )
                );
        file_put_contents($moduleDir . '/edit.yaml', WFYaml::dump($editYaml));

        // build edit.tpl
        $this->smarty->assign('editFormId', $editFormId);
        $this->smarty->assign('widgets', $widgets);
        file_put_contents($moduleDir . '/edit.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/edit.tpl'));

        // build confirmDelete page
        $confirmDeleteYaml = array();
        $confirmDeleteFormId = 'confirmDelete' . $entity->valueForKey('name')  . 'Form';
        $pkId = $entity->valueForKey('primaryKeyProperty');
        $confirmDeleteYaml[$confirmDeleteFormId] = array(
                'class' => 'WFForm',
                'children' => array(
                    $pkId => array(
                        'class' => 'WFHidden',
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => 'selection',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                )
                            )
                        ),
                    'cancel' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Cancel'
                            )
                        ),
                    'deleteObj' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Delete'
                            )
                        )
                    ),
                    );
        $confirmDeleteYaml['confirmMessage'] = array(
                'class' => 'WFMessageBox',
                'bindings' => array(
                    'value' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => $descriptiveColumnName,
                        'options' => array(
                            'ValuePattern' => 'Are you sure you want to delete ' . $entity->valueForKey('name') . ' "%1%"?'
                            )
                        )
                    )
                );
        file_put_contents($moduleDir . '/confirmDelete.yaml', WFYaml::dump($confirmDeleteYaml));
        
        // confirmDelete.tpl file
        $this->smarty->assign('confirmDeleteFormId', $confirmDeleteFormId);
        file_put_contents($moduleDir . '/confirmDelete.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/confirmDelete.tpl'));

        // delete success
        $deleteSuccessYaml = array();
        $deleteSuccessYaml['statusMessage'] = array(
                'class' => 'WFMessageBox',
                'properties' => array(
                    'value' => $entity->valueForKey('name') . ' successfully deleted.'
                    )
                );
        file_put_contents($moduleDir . '/deleteSuccess.yaml', WFYaml::dump($deleteSuccessYaml));
        file_put_contents($moduleDir . '/deleteSuccess.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/deleteSuccess.tpl'));

        // detail page
        $detailYaml = array();
        $widgets = array();
        foreach ($entity->getProperties() as $property) {
            $widgetID = $property->valueForKey('name');
            $widgets[$widgetID] = $property;
            $detailYaml[$widgetID] = array(
                    'class' => 'WFLabel',
                    'bindings' => array(
                        'value' => array(
                            'instanceID' => $sharedEntityId,
                            'controllerKey' => 'selection',
                            'modelKeyPath' => $widgetID
                            )
                        )
                    );
        }
        file_put_contents($moduleDir . '/detail.yaml', WFYaml::dump($detailYaml));
       
        // build detail.tpl
        $this->smarty->assign('widgets', $widgets);
        file_put_contents($moduleDir . '/detail.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/detail.tpl'));
    }
}
]]></response>
After this, there is only one more entry in the connection log, a SEND of:
context_names -d 0 -i 28
Then it's hung.
I have screenshots if you like; I didn't see a way to attach them to the ticket.
It seems to be repeatable; that is if you completely restart MacGDBp it will hang in the exact same spot.
I've gotten some info from the connection log for you that will hopefully help.
This is the XML of the last successful RECV.
<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1"
xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="source"
transaction_id="27"
encoding="base64"><![CDATA[<?php

interface WFModelBuilder
{
    // get a WFModelEntity for the given entity name
    function buildEntityModel($entity);
}

// PHOCOA WFModel Class Structure -- internal representation of the object model. Decoupled from the implementations.
class WFModel extends WFObject
{
    protected $builder = NULL;

    protected $entities = array();
    static private $_instance = NULL;

    function sharedModel()
    {
        if (!self::$_instance)
        {
            self::$_instance = new WFModel;
        }
        return self::$_instance;
    }

    function __toString()
    {
        $str = NULL;
        foreach ($this->entities as $entity) {
            $str .= "\n" . $entity->valueForKey('name');
            foreach ($entity->getProperties() as $property) {
                $str .= "\n - " . $property->valueForKey('name') . " (" . $property->valueForKey('type') . ")";
            }
            foreach ($entity->getRelationships() as $rel) {
                $str .= "\n > " . $rel->valueForKey('name') . " (" . ($rel->valueForKey('toOne') ? 'to-one' : 'to-many') . ($rel->valueForKey('isExtension') ? ' [EXT]' : NULL) . ", " . ($rel->valueForKey('required') ? 'required' : 'optional') . ")";
            }
        }
        $str .= "\n\n";
        return $str;
    }

    public function addEntity($entity)
    {
        $this->entities[$entity->valueForKey('name')] = $entity;
    }

    public function entities()
    {
        return $this->entities;
    }

    public function getEntity($name)
    {
        if (isset($this->entities[$name])) return $this->entities[$name];
        return NULL;
    }

    public function buildEntity($entityName)
    {
        if (isset($this->entities[$entityName]))
        {
            throw( new WFException("Entity {$entityName} is already built. Use WFModel::getEntity().") );
            return $this->getEntity($entityName);
        }

        // create entity
        $entity = new WFModelEntity;
        $entity->setValueForKey($entityName, 'name');
        $this->addEntity($entity);
        $this->builder->buildEntityModel($entity);

        return $entity;
    }

    public function buildModel($adapter, $configFile, $buildEntities)
    {
        // bootstrap
        $builderClass = 'WFModelBuilder' . $adapter;
        $this->builder = new $builderClass;
        $this->builder->setup();
        foreach ($buildEntities as $entity) {
            $this->buildEntity($entity);
        }

        if (file_exists($configFile))
        {
            // READ CONFIG - read a config YAML file and "override" settings in various entities, such as descriptiveColumnName, or cardinality:
            $config = WFYaml::load($configFile);
            // Blog:
            //   descriptiveColumnName: name
            //   relationships:
            //     BlogPreferences:
            //       minCount: 0
            //       maxCount: NULL
            //       isExtension: true

            // apply config
            foreach ($config as $entityName => $entityConfig) {
                try {
                    $entity = $this->getEntity($entityName);
                } catch (WFException $e) {
                    print "WARNING: Entity {$entityName} not loaded...\n";
                    continue;
                }
                foreach ($entityConfig as $key => $config) {
                    switch ($key) {
                        case 'relationships':
                            foreach ($config as $relationshipName => $relationshipConfig) {
                                $rel = $entity->getRelationship($relationshipName);
                                if (!$rel)
                                {
                                    print "WARNING: Relationship: {$relationshipName} of Entity {$entityName} not loaded...\n";
                                    continue;
                                }
                                foreach ($relationshipConfig as $key => $value) {
                                    if ($key === 'inverseRelationship')
                                    {
                                        list($entityName, $relName) = explode('.', $value);
                                        if (!$entityName or !$relName) throw( new WFException("inverseRelationship format must be <entityName>.<relationshipName>") );
                                        if (!$this->getEntity($entityName))
                                        {
                                            $invEntity = new WFModelEntity;
                                            $invEntity->setValueForKey($entityName, 'name');
                                            $this->builder->buildEntityModel($invEntity);
                                            $this->addEntity($invEntity);
                                        }
                                        $rel->setInverseRelationship($this->getEntity($entityName)->getRelationship('relName'));
                                    }
                                    else
                                    {
                                        $rel->setValueForKey($value, $key);
                                    }
                                }
                            }
                            break;
                        case 'properties':
                            foreach ($config as $propertyName => $propertyConfig) {
                                $property = $entity->getProperty($propertyName);
                                if (!$property)
                                {
                                    print "WARNING: Property: {$propertyName} of Entity {$entityName} not loaded...\n";
                                    continue;
                                }
                                foreach ($propertyConfig as $key => $value) {
                                    switch ($key) {
                                        case 'type':
                                            $value = eval("return {$value};");
                                            break;
                                    }
                                    $property->setValueForKey($value, $key);
                                }
                            }
                            break;
                        default:
                            $entity->setValueForKey($config, $key);
                            break;
                    }
                }
            }
        }
    }
}

class WFModelEntity extends WFObject
{
    protected $name = NULL;
    protected $primaryKeyProperty = NULL;
    protected $descriptiveColumnName = NULL;
    protected $properties = array();
    protected $relationships = array();

    public function addProperty($property)
    {
        if (!($property instanceof WFModelEntityProperty)) throw( new WFException("addProperty parameter must be a WFModelEntityProperty.") );
        $this->properties[$property->valueForKey('name')] = $property;
        return $this;
    }
    public function getProperty($name)
    {
        if (isset($this->properties[$name])) return $this->properties[$name];
        return NULL;
    }
    public function getProperties()
    {
        return $this->properties;
    }

    public function addRelationship($rel)
    {
        if (!$rel->valueForKey('name')) throw( new WFException("Relationships must have a name before being added.") );
        if (!($rel instanceof WFModelEntityRelationship)) throw( new WFException("addRelationship parameter must be a WFModelEntityRelationship.") );
        if (isset($this->relationships[$rel->valueForKey('name')])) throw( new WFException("Relationship " . $rel->valueForKey('name') . " already exists for entity " . $this->valueForKey('name')) );
        $this->relationships[$rel->valueForKey('name')] = $rel;
        return $this;
    }
    public function getRelationship($name)
    {
        if (isset($this->relationships[$name])) return $this->relationships[$name];
        return NULL;
    }
    public function getRelationships()
    {
        return $this->relationships;
    }
}
class WFModelEntityProperty extends WFObject
{
    protected $name = NULL;
    protected $type = WFModelEntityProperty::TYPE_STRING;
    protected $defaultValue = NULL;

    const TYPE_STRING = 'string';
    const TYPE_TEXT = 'text';
    const TYPE_NUMBER = 'number';
    const TYPE_DATETIME = 'datetime';
    const TYPE_TIME = 'time';
    const TYPE_DATE = 'date';
    const TYPE_BOOLEAN = 'boolean';
}
class WFModelEntityRelationship extends WFObject
{
    protected $name = NULL;     // a call to get{$name} on the entity should fetch the related object(s)
    protected $isExtension = false; // extensions are to-one relationships that use the same id field in both tables and the related table stores "extended" properties. The extended table is basically a "grouping" of properties for the primary entity.
    protected $toOne = true;    // TRUE = to-one, FALSE = to-many
    protected $required = false;    // orthogonal to minCount; minCount is only enforced if there is a relationship. Required disallows lack of related object(s).
    protected $minCount = 1;
    protected $maxCount = 1;
    protected $inverseRelationship = NULL;

    function setToOne($isToOne)
    {
        if (!is_bool($isToOne)) throw( new WFException("boolean expected.") );
        $this->toOne = $isToOne;
        $this->minCount = $this->maxCount = ($this->toOne ? 1 : NULL);
    }
    function setMinCount($num)
    {
        if ($this->toOne) throw( new WFException("Can't set minCount on to-one relationships.") );
        $this->minCount = $num;
    }
    function setMaxCount($num)
    {
        if ($this->toOne) throw( new WFException("Can't set maxCount on to-one relationships.") );
        $this->maxCount = $num;
    }
    function setInverseRelationship($r)
    {
        if (!($r instanceof WFModelEntityRelationship)) throw( new WFException("Relationship must be a WFModelEntityRelationship.") );
        $this->inverseRelationship = $r;
    }
}

// PHOCOA Code-Gen Classes
// Right now, hard-coded for Propel; refactor later to call out to builder classes for things like entity lookup code (any ORM-specific stuff)
class WFModelCodeGenPropel extends WFObject
{
    protected $smarty = NULL;
    protected $modulePath = NULL;

    function __construct()
    {
        $this->smarty = new WFSmarty;
        $this->smarty->left_delimiter = '{{';
        $this->smarty->right_delimiter = '}}';

        // figure out modulePath
        // walk up PWD until we hit "modules" and use that.
        $dir = getcwd();
        $parts = explode('/', $dir);
        $this->modulePath = NULL;
        foreach ($parts as $part) {
            if ($this->modulePath === NULL)
            {
                if ($part == 'modules')
                {
                    $this->modulePath = WWW_ROOT;
                    continue;
                }
            }
            else
            {
                $this->modulePath .= '/' . $part;
            }
        }
        $this->modulePath .= '/';
    }

    function generateModuleForEntity($entity)
    {
        print "Generating module for entity '" . $entity->valueForKey('name') . "'\n";
        $cwd = getcwd();
        $moduleName = strtolower( $entity->valueForKey('name') );
        $moduleDir = $cwd . '/' . $moduleName;
        if (file_exists($moduleDir))
        {
            print "WARNING: Module $moduleName already exists. Skipping\n";
            return;
        }

        mkdir($moduleDir); // module dir
        $this->modulePath .= $moduleName;

        // setup shared instances
        $sharedYaml[$entity->valueForKey('name')] = array(
                'class' => 'WFArrayController',
                'properties' => array(
                    'class' => $entity->valueForKey('name'),
                    'classIdentifiers' => $entity->valueForKey('primaryKeyProperty'),
                    'selectOnInsert' => true,
                    'automaticallyPreparesContent' => false
                    )
                );
        $sharedYaml['paginator'] = array(
                'class' => 'WFPaginator',
                'properties' => array(
                    'modeForm' => 'search',
                    'pageSize' => 25,
                    'itemPhraseSingular' => $entity->valueForKey('name'),
                    'itemPhrasePlural' => $entity->valueForKey('name') . 's'
                    )
                );
        file_put_contents($moduleDir . '/shared.yaml', WFYaml::dump($sharedYaml));

        $sharedEntityId = $entity->valueForKey('name');

        // build module code
        $this->smarty->assign('moduleName', $moduleName);
        $this->smarty->assign('entity', $entity);
        $this->smarty->assign('entityName', $entity->valueForKey('name'));
        $this->smarty->assign('sharedEntityId', $sharedEntityId);
        $this->smarty->assign('sharedEntityPrimaryKeyProperty', $entity->valueForKey('primaryKeyProperty'));
        $this->smarty->assign('descriptiveColumnName', $entity->valueForKey('descriptiveColumnName'));

        // look up Peer column constant name from the PHP name; call ObjPeer::translateFieldName($name, $fromType, $toType)
        $translateF = array($entity->valueForKey('name') . 'Peer', 'translateFieldName');
        $peerColName = call_user_func($translateF, ucfirst($entity->valueForKey('descriptiveColumnName')), BasePeer::TYPE_PHPNAME, BasePeer::TYPE_FIELDNAME);
        $this->smarty->assign('descriptiveColumnConstantName', strtoupper($peerColName));

        $moduleCode = $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/module.tpl');
        file_put_contents($moduleDir . '/' . $moduleName . '.php', $moduleCode);

        // build list page
        // list.yaml
        $listYaml = array();
        $listFormId = 'search' . $entity->valueForKey('name') . 'Form';
        $listYaml[$listFormId] = array(
                'class' => 'WFForm', 'children' => array(
                    'search' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Search'
                            ),
                        ),
                    'clear' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Clear'
                            ),
                        ),
                    'paginatorState' => array(
                        'class' => 'WFPaginatorState',
                        'properties' => array('paginator' => '#module#paginator')
                        ),
                    'query' => array('class' => 'WFTextField'),
                    )
                );
        $listYaml['paginatorNavigation'] = array(
                'class' => 'WFPaginatorNavigation',
                'properties' => array('paginator' => '#module#paginator'),
                );
        $listYaml['paginatorPageInfo'] = array(
                'class' => 'WFPaginatorPageInfo',
                'properties' => array('paginator' => '#module#paginator'),
                );

        $descriptiveColumnName = $entity->valueForKey('descriptiveColumnName');
        $listYaml[$descriptiveColumnName] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "{$descriptiveColumnName}Prototype" => array(
                        'class' => 'WFLink',
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/detail/%1%')
                                ),
                            'label' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('descriptiveColumnName')
                                )
                            )
                        )
                    )
                    );
        $listYaml['editLink'] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "editLinkPrototype" => array(
                        'class' => 'WFLink',
                        'properties' => array('label' => 'Edit'),
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/edit/%1%')
                                )
                            )
                        ) 
                    )
                );
        $listYaml['deleteLink'] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "deleteLinkPrototype" => array(
                        'class' => 'WFLink',
                        'properties' => array('label' => 'Delete'),
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/confirmDelete/%1%')
                                )
                            )
                        ) 
                    )
                );
        file_put_contents($moduleDir . '/list.yaml', WFYaml::dump($listYaml));

        // build list.tpl
        $this->smarty->assign('listFormId', $listFormId);
        file_put_contents($moduleDir . '/list.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/list.tpl'));

        // build edit page
        // build edit.yaml
        $editYaml = array();
        $editFormId = 'edit' . $entity->valueForKey('name') . 'Form';
        $editYaml[$editFormId] = array('class' => 'WFForm', 'children' => array());

        $widgets = array();
        foreach ($entity->getProperties() as $property) {
            $widgetID = $property->valueForKey('name');
            $widgets[$widgetID] = $property;

            if ($property->valueForKey('name') === $entity->valueForKey('primaryKeyProperty'))
            {
                $class = 'WFHidden';
            }
            else
            {
                switch ($property->valueForKey('type')) {
                    case WFModelEntityProperty::TYPE_TEXT;
                        $class = 'WFTextArea';
                        break;
                    case WFModelEntityProperty::TYPE_NUMBER;
                    case WFModelEntityProperty::TYPE_STRING;
                    case WFModelEntityProperty::TYPE_DATETIME;
                    case WFModelEntityProperty::TYPE_TIME;
                    case WFModelEntityProperty::TYPE_DATE;
                        $class = 'WFTextField';
                        break;
                    case WFModelEntityProperty::TYPE_BOOLEAN;
                        $class = 'WFCheckbox';
                        break;
                    default:
                        $class = 'WFTextField';
                }
            }
            $editYaml[$editFormId]['children'][$widgetID] = array(
                    'class' => $class,
                    'bindings' => array(
                        'value' => array(
                            'instanceID' => $sharedEntityId,
                            'controllerKey' => 'selection',
                            'modelKeyPath' => $widgetID
                            )
                        )
                    );

        }
        // status message
        $editYaml['statusMessage'] = array('class' => 'WFMessageBox');
        $editYaml[$editFormId]['children']['saveNew'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Create ' . $entity->valueForKey('name'),
                    'action' => 'save'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        'options' => array(
                            'valueTransformer' => 'WFNegateBoolean',
                            )
                        )
                    )
                );
        $editYaml[$editFormId]['children']['save'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Save'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        )
                    )
                );
        $editYaml[$editFormId]['children']['deleteObj'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Delete'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        )
                    )
                );
        file_put_contents($moduleDir . '/edit.yaml', WFYaml::dump($editYaml));

        // build edit.tpl
        $this->smarty->assign('editFormId', $editFormId);
        $this->smarty->assign('widgets', $widgets);
        file_put_contents($moduleDir . '/edit.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/edit.tpl'));

        // build confirmDelete page
        $confirmDeleteYaml = array();
        $confirmDeleteFormId = 'confirmDelete' . $entity->valueForKey('name')  . 'Form';
        $pkId = $entity->valueForKey('primaryKeyProperty');
        $confirmDeleteYaml[$confirmDeleteFormId] = array(
                'class' => 'WFForm',
                'children' => array(
                    $pkId => array(
                        'class' => 'WFHidden',
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => 'selection',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                )
                            )
                        ),
                    'cancel' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Cancel'
                            )
                        ),
                    'deleteObj' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Delete'
                            )
                        )
                    ),
                    );
        $confirmDeleteYaml['confirmMessage'] = array(
                'class' => 'WFMessageBox',
                'bindings' => array(
                    'value' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => $descriptiveColumnName,
                        'options' => array(
                            'ValuePattern' => 'Are you sure you want to delete ' . $entity->valueForKey('name') . ' "%1%"?'
                            )
                        )
                    )
                );
        file_put_contents($moduleDir . '/confirmDelete.yaml', WFYaml::dump($confirmDeleteYaml));
        
        // confirmDelete.tpl file
        $this->smarty->assign('confirmDeleteFormId', $confirmDeleteFormId);
        file_put_contents($moduleDir . '/confirmDelete.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/confirmDelete.tpl'));

        // delete success
        $deleteSuccessYaml = array();
        $deleteSuccessYaml['statusMessage'] = array(
                'class' => 'WFMessageBox',
                'properties' => array(
                    'value' => $entity->valueForKey('name') . ' successfully deleted.'
                    )
                );
        file_put_contents($moduleDir . '/deleteSuccess.yaml', WFYaml::dump($deleteSuccessYaml));
        file_put_contents($moduleDir . '/deleteSuccess.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/deleteSuccess.tpl'));

        // detail page
        $detailYaml = array();
        $widgets = array();
        foreach ($entity->getProperties() as $property) {
            $widgetID = $property->valueForKey('name');
            $widgets[$widgetID] = $property;
            $detailYaml[$widgetID] = array(
                    'class' => 'WFLabel',
                    'bindings' => array(
                        'value' => array(
                            'instanceID' => $sharedEntityId,
                            'controllerKey' => 'selection',
                            'modelKeyPath' => $widgetID
                            )
                        )
                    );
        }
        file_put_contents($moduleDir . '/detail.yaml', WFYaml::dump($detailYaml));
       
        // build detail.tpl
        $this->smarty->assign('widgets', $widgets);
        file_put_contents($moduleDir . '/detail.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/detail.tpl'));
    }
}
]]></response>
After this, there is only one more entry in the connection log, a SEND of:
context_names -d 0 -i 28
Then it's hung.
I have screenshots if you like; I didn't see a way to attach them to the ticket.
March 18, 2011 03:24 PM
Alan Pinstein
The last successful RECV:
<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1"
xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="source"
transaction_id="27"
encoding="base64"><![CDATA[<?php

interface WFModelBuilder
{
    // get a WFModelEntity for the given entity name
    function buildEntityModel($entity);
}

// PHOCOA WFModel Class Structure -- internal representation of the object model. Decoupled from the implementations.
class WFModel extends WFObject
{
    protected $builder = NULL;

    protected $entities = array();
    static private $_instance = NULL;

    function sharedModel()
    {
        if (!self::$_instance)
        {
            self::$_instance = new WFModel;
        }
        return self::$_instance;
    }

    function __toString()
    {
        $str = NULL;
        foreach ($this->entities as $entity) {
            $str .= "\n" . $entity->valueForKey('name');
            foreach ($entity->getProperties() as $property) {
                $str .= "\n - " . $property->valueForKey('name') . " (" . $property->valueForKey('type') . ")";
            }
            foreach ($entity->getRelationships() as $rel) {
                $str .= "\n > " . $rel->valueForKey('name') . " (" . ($rel->valueForKey('toOne') ? 'to-one' : 'to-many') . ($rel->valueForKey('isExtension') ? ' [EXT]' : NULL) . ", " . ($rel->valueForKey('required') ? 'required' : 'optional') . ")";
            }
        }
        $str .= "\n\n";
        return $str;
    }

    public function addEntity($entity)
    {
        $this->entities[$entity->valueForKey('name')] = $entity;
    }

    public function entities()
    {
        return $this->entities;
    }

    public function getEntity($name)
    {
        if (isset($this->entities[$name])) return $this->entities[$name];
        return NULL;
    }

    public function buildEntity($entityName)
    {
        if (isset($this->entities[$entityName]))
        {
            throw( new WFException("Entity {$entityName} is already built. Use WFModel::getEntity().") );
            return $this->getEntity($entityName);
        }

        // create entity
        $entity = new WFModelEntity;
        $entity->setValueForKey($entityName, 'name');
        $this->addEntity($entity);
        $this->builder->buildEntityModel($entity);

        return $entity;
    }

    public function buildModel($adapter, $configFile, $buildEntities)
    {
        // bootstrap
        $builderClass = 'WFModelBuilder' . $adapter;
        $this->builder = new $builderClass;
        $this->builder->setup();
        foreach ($buildEntities as $entity) {
            $this->buildEntity($entity);
        }

        if (file_exists($configFile))
        {
            // READ CONFIG - read a config YAML file and "override" settings in various entities, such as descriptiveColumnName, or cardinality:
            $config = WFYaml::load($configFile);
            // Blog:
            //   descriptiveColumnName: name
            //   relationships:
            //     BlogPreferences:
            //       minCount: 0
            //       maxCount: NULL
            //       isExtension: true

            // apply config
            foreach ($config as $entityName => $entityConfig) {
                try {
                    $entity = $this->getEntity($entityName);
                } catch (WFException $e) {
                    print "WARNING: Entity {$entityName} not loaded...\n";
                    continue;
                }
                foreach ($entityConfig as $key => $config) {
                    switch ($key) {
                        case 'relationships':
                            foreach ($config as $relationshipName => $relationshipConfig) {
                                $rel = $entity->getRelationship($relationshipName);
                                if (!$rel)
                                {
                                    print "WARNING: Relationship: {$relationshipName} of Entity {$entityName} not loaded...\n";
                                    continue;
                                }
                                foreach ($relationshipConfig as $key => $value) {
                                    if ($key === 'inverseRelationship')
                                    {
                                        list($entityName, $relName) = explode('.', $value);
                                        if (!$entityName or !$relName) throw( new WFException("inverseRelationship format must be <entityName>.<relationshipName>") );
                                        if (!$this->getEntity($entityName))
                                        {
                                            $invEntity = new WFModelEntity;
                                            $invEntity->setValueForKey($entityName, 'name');
                                            $this->builder->buildEntityModel($invEntity);
                                            $this->addEntity($invEntity);
                                        }
                                        $rel->setInverseRelationship($this->getEntity($entityName)->getRelationship('relName'));
                                    }
                                    else
                                    {
                                        $rel->setValueForKey($value, $key);
                                    }
                                }
                            }
                            break;
                        case 'properties':
                            foreach ($config as $propertyName => $propertyConfig) {
                                $property = $entity->getProperty($propertyName);
                                if (!$property)
                                {
                                    print "WARNING: Property: {$propertyName} of Entity {$entityName} not loaded...\n";
                                    continue;
                                }
                                foreach ($propertyConfig as $key => $value) {
                                    switch ($key) {
                                        case 'type':
                                            $value = eval("return {$value};");
                                            break;
                                    }
                                    $property->setValueForKey($value, $key);
                                }
                            }
                            break;
                        default:
                            $entity->setValueForKey($config, $key);
                            break;
                    }
                }
            }
        }
    }
}

class WFModelEntity extends WFObject
{
    protected $name = NULL;
    protected $primaryKeyProperty = NULL;
    protected $descriptiveColumnName = NULL;
    protected $properties = array();
    protected $relationships = array();

    public function addProperty($property)
    {
        if (!($property instanceof WFModelEntityProperty)) throw( new WFException("addProperty parameter must be a WFModelEntityProperty.") );
        $this->properties[$property->valueForKey('name')] = $property;
        return $this;
    }
    public function getProperty($name)
    {
        if (isset($this->properties[$name])) return $this->properties[$name];
        return NULL;
    }
    public function getProperties()
    {
        return $this->properties;
    }

    public function addRelationship($rel)
    {
        if (!$rel->valueForKey('name')) throw( new WFException("Relationships must have a name before being added.") );
        if (!($rel instanceof WFModelEntityRelationship)) throw( new WFException("addRelationship parameter must be a WFModelEntityRelationship.") );
        if (isset($this->relationships[$rel->valueForKey('name')])) throw( new WFException("Relationship " . $rel->valueForKey('name') . " already exists for entity " . $this->valueForKey('name')) );
        $this->relationships[$rel->valueForKey('name')] = $rel;
        return $this;
    }
    public function getRelationship($name)
    {
        if (isset($this->relationships[$name])) return $this->relationships[$name];
        return NULL;
    }
    public function getRelationships()
    {
        return $this->relationships;
    }
}
class WFModelEntityProperty extends WFObject
{
    protected $name = NULL;
    protected $type = WFModelEntityProperty::TYPE_STRING;
    protected $defaultValue = NULL;

    const TYPE_STRING = 'string';
    const TYPE_TEXT = 'text';
    const TYPE_NUMBER = 'number';
    const TYPE_DATETIME = 'datetime';
    const TYPE_TIME = 'time';
    const TYPE_DATE = 'date';
    const TYPE_BOOLEAN = 'boolean';
}
class WFModelEntityRelationship extends WFObject
{
    protected $name = NULL;     // a call to get{$name} on the entity should fetch the related object(s)
    protected $isExtension = false; // extensions are to-one relationships that use the same id field in both tables and the related table stores "extended" properties. The extended table is basically a "grouping" of properties for the primary entity.
    protected $toOne = true;    // TRUE = to-one, FALSE = to-many
    protected $required = false;    // orthogonal to minCount; minCount is only enforced if there is a relationship. Required disallows lack of related object(s).
    protected $minCount = 1;
    protected $maxCount = 1;
    protected $inverseRelationship = NULL;

    function setToOne($isToOne)
    {
        if (!is_bool($isToOne)) throw( new WFException("boolean expected.") );
        $this->toOne = $isToOne;
        $this->minCount = $this->maxCount = ($this->toOne ? 1 : NULL);
    }
    function setMinCount($num)
    {
        if ($this->toOne) throw( new WFException("Can't set minCount on to-one relationships.") );
        $this->minCount = $num;
    }
    function setMaxCount($num)
    {
        if ($this->toOne) throw( new WFException("Can't set maxCount on to-one relationships.") );
        $this->maxCount = $num;
    }
    function setInverseRelationship($r)
    {
        if (!($r instanceof WFModelEntityRelationship)) throw( new WFException("Relationship must be a WFModelEntityRelationship.") );
        $this->inverseRelationship = $r;
    }
}

// PHOCOA Code-Gen Classes
// Right now, hard-coded for Propel; refactor later to call out to builder classes for things like entity lookup code (any ORM-specific stuff)
class WFModelCodeGenPropel extends WFObject
{
    protected $smarty = NULL;
    protected $modulePath = NULL;

    function __construct()
    {
        $this->smarty = new WFSmarty;
        $this->smarty->left_delimiter = '{{';
        $this->smarty->right_delimiter = '}}';

        // figure out modulePath
        // walk up PWD until we hit "modules" and use that.
        $dir = getcwd();
        $parts = explode('/', $dir);
        $this->modulePath = NULL;
        foreach ($parts as $part) {
            if ($this->modulePath === NULL)
            {
                if ($part == 'modules')
                {
                    $this->modulePath = WWW_ROOT;
                    continue;
                }
            }
            else
            {
                $this->modulePath .= '/' . $part;
            }
        }
        $this->modulePath .= '/';
    }

    function generateModuleForEntity($entity)
    {
        print "Generating module for entity '" . $entity->valueForKey('name') . "'\n";
        $cwd = getcwd();
        $moduleName = strtolower( $entity->valueForKey('name') );
        $moduleDir = $cwd . '/' . $moduleName;
        if (file_exists($moduleDir))
        {
            print "WARNING: Module $moduleName already exists. Skipping\n";
            return;
        }

        mkdir($moduleDir); // module dir
        $this->modulePath .= $moduleName;

        // setup shared instances
        $sharedYaml[$entity->valueForKey('name')] = array(
                'class' => 'WFArrayController',
                'properties' => array(
                    'class' => $entity->valueForKey('name'),
                    'classIdentifiers' => $entity->valueForKey('primaryKeyProperty'),
                    'selectOnInsert' => true,
                    'automaticallyPreparesContent' => false
                    )
                );
        $sharedYaml['paginator'] = array(
                'class' => 'WFPaginator',
                'properties' => array(
                    'modeForm' => 'search',
                    'pageSize' => 25,
                    'itemPhraseSingular' => $entity->valueForKey('name'),
                    'itemPhrasePlural' => $entity->valueForKey('name') . 's'
                    )
                );
        file_put_contents($moduleDir . '/shared.yaml', WFYaml::dump($sharedYaml));

        $sharedEntityId = $entity->valueForKey('name');

        // build module code
        $this->smarty->assign('moduleName', $moduleName);
        $this->smarty->assign('entity', $entity);
        $this->smarty->assign('entityName', $entity->valueForKey('name'));
        $this->smarty->assign('sharedEntityId', $sharedEntityId);
        $this->smarty->assign('sharedEntityPrimaryKeyProperty', $entity->valueForKey('primaryKeyProperty'));
        $this->smarty->assign('descriptiveColumnName', $entity->valueForKey('descriptiveColumnName'));

        // look up Peer column constant name from the PHP name; call ObjPeer::translateFieldName($name, $fromType, $toType)
        $translateF = array($entity->valueForKey('name') . 'Peer', 'translateFieldName');
        $peerColName = call_user_func($translateF, ucfirst($entity->valueForKey('descriptiveColumnName')), BasePeer::TYPE_PHPNAME, BasePeer::TYPE_FIELDNAME);
        $this->smarty->assign('descriptiveColumnConstantName', strtoupper($peerColName));

        $moduleCode = $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/module.tpl');
        file_put_contents($moduleDir . '/' . $moduleName . '.php', $moduleCode);

        // build list page
        // list.yaml
        $listYaml = array();
        $listFormId = 'search' . $entity->valueForKey('name') . 'Form';
        $listYaml[$listFormId] = array(
                'class' => 'WFForm', 'children' => array(
                    'search' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Search'
                            ),
                        ),
                    'clear' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Clear'
                            ),
                        ),
                    'paginatorState' => array(
                        'class' => 'WFPaginatorState',
                        'properties' => array('paginator' => '#module#paginator')
                        ),
                    'query' => array('class' => 'WFTextField'),
                    )
                );
        $listYaml['paginatorNavigation'] = array(
                'class' => 'WFPaginatorNavigation',
                'properties' => array('paginator' => '#module#paginator'),
                );
        $listYaml['paginatorPageInfo'] = array(
                'class' => 'WFPaginatorPageInfo',
                'properties' => array('paginator' => '#module#paginator'),
                );

        $descriptiveColumnName = $entity->valueForKey('descriptiveColumnName');
        $listYaml[$descriptiveColumnName] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "{$descriptiveColumnName}Prototype" => array(
                        'class' => 'WFLink',
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/detail/%1%')
                                ),
                            'label' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('descriptiveColumnName')
                                )
                            )
                        )
                    )
                    );
        $listYaml['editLink'] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "editLinkPrototype" => array(
                        'class' => 'WFLink',
                        'properties' => array('label' => 'Edit'),
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/edit/%1%')
                                )
                            )
                        ) 
                    )
                );
        $listYaml['deleteLink'] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "deleteLinkPrototype" => array(
                        'class' => 'WFLink',
                        'properties' => array('label' => 'Delete'),
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/confirmDelete/%1%')
                                )
                            )
                        ) 
                    )
                );
        file_put_contents($moduleDir . '/list.yaml', WFYaml::dump($listYaml));

        // build list.tpl
        $this->smarty->assign('listFormId', $listFormId);
        file_put_contents($moduleDir . '/list.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/list.tpl'));

        // build edit page
        // build edit.yaml
        $editYaml = array();
        $editFormId = 'edit' . $entity->valueForKey('name') . 'Form';
        $editYaml[$editFormId] = array('class' => 'WFForm', 'children' => array());

        $widgets = array();
        foreach ($entity->getProperties() as $property) {
            $widgetID = $property->valueForKey('name');
            $widgets[$widgetID] = $property;

            if ($property->valueForKey('name') === $entity->valueForKey('primaryKeyProperty'))
            {
                $class = 'WFHidden';
            }
            else
            {
                switch ($property->valueForKey('type')) {
                    case WFModelEntityProperty::TYPE_TEXT;
                        $class = 'WFTextArea';
                        break;
                    case WFModelEntityProperty::TYPE_NUMBER;
                    case WFModelEntityProperty::TYPE_STRING;
                    case WFModelEntityProperty::TYPE_DATETIME;
                    case WFModelEntityProperty::TYPE_TIME;
                    case WFModelEntityProperty::TYPE_DATE;
                        $class = 'WFTextField';
                        break;
                    case WFModelEntityProperty::TYPE_BOOLEAN;
                        $class = 'WFCheckbox';
                        break;
                    default:
                        $class = 'WFTextField';
                }
            }
            $editYaml[$editFormId]['children'][$widgetID] = array(
                    'class' => $class,
                    'bindings' => array(
                        'value' => array(
                            'instanceID' => $sharedEntityId,
                            'controllerKey' => 'selection',
                            'modelKeyPath' => $widgetID
                            )
                        )
                    );

        }
        // status message
        $editYaml['statusMessage'] = array('class' => 'WFMessageBox');
        $editYaml[$editFormId]['children']['saveNew'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Create ' . $entity->valueForKey('name'),
                    'action' => 'save'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        'options' => array(
                            'valueTransformer' => 'WFNegateBoolean',
                            )
                        )
                    )
                );
        $editYaml[$editFormId]['children']['save'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Save'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        )
                    )
                );
        $editYaml[$editFormId]['children']['deleteObj'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Delete'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        )
                    )
                );
        file_put_contents($moduleDir . '/edit.yaml', WFYaml::dump($editYaml));

        // build edit.tpl
        $this->smarty->assign('editFormId', $editFormId);
        $this->smarty->assign('widgets', $widgets);
        file_put_contents($moduleDir . '/edit.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/edit.tpl'));

        // build confirmDelete page
        $confirmDeleteYaml = array();
        $confirmDeleteFormId = 'confirmDelete' . $entity->valueForKey('name')  . 'Form';
        $pkId = $entity->valueForKey('primaryKeyProperty');
        $confirmDeleteYaml[$confirmDeleteFormId] = array(
                'class' => 'WFForm',
                'children' => array(
                    $pkId => array(
                        'class' => 'WFHidden',
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => 'selection',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                )
                            )
                        ),
                    'cancel' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Cancel'
                            )
                        ),
                    'deleteObj' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Delete'
                            )
                        )
                    ),
                    );
        $confirmDeleteYaml['confirmMessage'] = array(
                'class' => 'WFMessageBox',
                'bindings' => array(
                    'value' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => $descriptiveColumnName,
                        'options' => array(
                            'ValuePattern' => 'Are you sure you want to delete ' . $entity->valueForKey('name') . ' "%1%"?'
                            )
                        )
                    )
                );
        file_put_contents($moduleDir . '/confirmDelete.yaml', WFYaml::dump($confirmDeleteYaml));
        
        // confirmDelete.tpl file
        $this->smarty->assign('confirmDeleteFormId', $confirmDeleteFormId);
        file_put_contents($moduleDir . '/confirmDelete.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/confirmDelete.tpl'));

        // delete success
        $deleteSuccessYaml = array();
        $deleteSuccessYaml['statusMessage'] = array(
                'class' => 'WFMessageBox',
                'properties' => array(
                    'value' => $entity->valueForKey('name') . ' successfully deleted.'
                    )
                );
        file_put_contents($moduleDir . '/deleteSuccess.yaml', WFYaml::dump($deleteSuccessYaml));
        file_put_contents($moduleDir . '/deleteSuccess.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/deleteSuccess.tpl'));

        // detail page
        $detailYaml = array();
        $widgets = array();
        foreach ($entity->getProperties() as $property) {
            $widgetID = $property->valueForKey('name');
            $widgets[$widgetID] = $property;
            $detailYaml[$widgetID] = array(
                    'class' => 'WFLabel',
                    'bindings' => array(
                        'value' => array(
                            'instanceID' => $sharedEntityId,
                            'controllerKey' => 'selection',
                            'modelKeyPath' => $widgetID
                            )
                        )
                    );
        }
        file_put_contents($moduleDir . '/detail.yaml', WFYaml::dump($detailYaml));
       
        // build detail.tpl
        $this->smarty->assign('widgets', $widgets);
        file_put_contents($moduleDir . '/detail.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/detail.tpl'));
    }
}
]]></response>
<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1"
xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="source"
transaction_id="27"
encoding="base64"><![CDATA[<?php

interface WFModelBuilder
{
    // get a WFModelEntity for the given entity name
    function buildEntityModel($entity);
}

// PHOCOA WFModel Class Structure -- internal representation of the object model. Decoupled from the implementations.
class WFModel extends WFObject
{
    protected $builder = NULL;

    protected $entities = array();
    static private $_instance = NULL;

    function sharedModel()
    {
        if (!self::$_instance)
        {
            self::$_instance = new WFModel;
        }
        return self::$_instance;
    }

    function __toString()
    {
        $str = NULL;
        foreach ($this->entities as $entity) {
            $str .= "\n" . $entity->valueForKey('name');
            foreach ($entity->getProperties() as $property) {
                $str .= "\n - " . $property->valueForKey('name') . " (" . $property->valueForKey('type') . ")";
            }
            foreach ($entity->getRelationships() as $rel) {
                $str .= "\n > " . $rel->valueForKey('name') . " (" . ($rel->valueForKey('toOne') ? 'to-one' : 'to-many') . ($rel->valueForKey('isExtension') ? ' [EXT]' : NULL) . ", " . ($rel->valueForKey('required') ? 'required' : 'optional') . ")";
            }
        }
        $str .= "\n\n";
        return $str;
    }

    public function addEntity($entity)
    {
        $this->entities[$entity->valueForKey('name')] = $entity;
    }

    public function entities()
    {
        return $this->entities;
    }

    public function getEntity($name)
    {
        if (isset($this->entities[$name])) return $this->entities[$name];
        return NULL;
    }

    public function buildEntity($entityName)
    {
        if (isset($this->entities[$entityName]))
        {
            throw( new WFException("Entity {$entityName} is already built. Use WFModel::getEntity().") );
            return $this->getEntity($entityName);
        }

        // create entity
        $entity = new WFModelEntity;
        $entity->setValueForKey($entityName, 'name');
        $this->addEntity($entity);
        $this->builder->buildEntityModel($entity);

        return $entity;
    }

    public function buildModel($adapter, $configFile, $buildEntities)
    {
        // bootstrap
        $builderClass = 'WFModelBuilder' . $adapter;
        $this->builder = new $builderClass;
        $this->builder->setup();
        foreach ($buildEntities as $entity) {
            $this->buildEntity($entity);
        }

        if (file_exists($configFile))
        {
            // READ CONFIG - read a config YAML file and "override" settings in various entities, such as descriptiveColumnName, or cardinality:
            $config = WFYaml::load($configFile);
            // Blog:
            //   descriptiveColumnName: name
            //   relationships:
            //     BlogPreferences:
            //       minCount: 0
            //       maxCount: NULL
            //       isExtension: true

            // apply config
            foreach ($config as $entityName => $entityConfig) {
                try {
                    $entity = $this->getEntity($entityName);
                } catch (WFException $e) {
                    print "WARNING: Entity {$entityName} not loaded...\n";
                    continue;
                }
                foreach ($entityConfig as $key => $config) {
                    switch ($key) {
                        case 'relationships':
                            foreach ($config as $relationshipName => $relationshipConfig) {
                                $rel = $entity->getRelationship($relationshipName);
                                if (!$rel)
                                {
                                    print "WARNING: Relationship: {$relationshipName} of Entity {$entityName} not loaded...\n";
                                    continue;
                                }
                                foreach ($relationshipConfig as $key => $value) {
                                    if ($key === 'inverseRelationship')
                                    {
                                        list($entityName, $relName) = explode('.', $value);
                                        if (!$entityName or !$relName) throw( new WFException("inverseRelationship format must be <entityName>.<relationshipName>") );
                                        if (!$this->getEntity($entityName))
                                        {
                                            $invEntity = new WFModelEntity;
                                            $invEntity->setValueForKey($entityName, 'name');
                                            $this->builder->buildEntityModel($invEntity);
                                            $this->addEntity($invEntity);
                                        }
                                        $rel->setInverseRelationship($this->getEntity($entityName)->getRelationship('relName'));
                                    }
                                    else
                                    {
                                        $rel->setValueForKey($value, $key);
                                    }
                                }
                            }
                            break;
                        case 'properties':
                            foreach ($config as $propertyName => $propertyConfig) {
                                $property = $entity->getProperty($propertyName);
                                if (!$property)
                                {
                                    print "WARNING: Property: {$propertyName} of Entity {$entityName} not loaded...\n";
                                    continue;
                                }
                                foreach ($propertyConfig as $key => $value) {
                                    switch ($key) {
                                        case 'type':
                                            $value = eval("return {$value};");
                                            break;
                                    }
                                    $property->setValueForKey($value, $key);
                                }
                            }
                            break;
                        default:
                            $entity->setValueForKey($config, $key);
                            break;
                    }
                }
            }
        }
    }
}

class WFModelEntity extends WFObject
{
    protected $name = NULL;
    protected $primaryKeyProperty = NULL;
    protected $descriptiveColumnName = NULL;
    protected $properties = array();
    protected $relationships = array();

    public function addProperty($property)
    {
        if (!($property instanceof WFModelEntityProperty)) throw( new WFException("addProperty parameter must be a WFModelEntityProperty.") );
        $this->properties[$property->valueForKey('name')] = $property;
        return $this;
    }
    public function getProperty($name)
    {
        if (isset($this->properties[$name])) return $this->properties[$name];
        return NULL;
    }
    public function getProperties()
    {
        return $this->properties;
    }

    public function addRelationship($rel)
    {
        if (!$rel->valueForKey('name')) throw( new WFException("Relationships must have a name before being added.") );
        if (!($rel instanceof WFModelEntityRelationship)) throw( new WFException("addRelationship parameter must be a WFModelEntityRelationship.") );
        if (isset($this->relationships[$rel->valueForKey('name')])) throw( new WFException("Relationship " . $rel->valueForKey('name') . " already exists for entity " . $this->valueForKey('name')) );
        $this->relationships[$rel->valueForKey('name')] = $rel;
        return $this;
    }
    public function getRelationship($name)
    {
        if (isset($this->relationships[$name])) return $this->relationships[$name];
        return NULL;
    }
    public function getRelationships()
    {
        return $this->relationships;
    }
}
class WFModelEntityProperty extends WFObject
{
    protected $name = NULL;
    protected $type = WFModelEntityProperty::TYPE_STRING;
    protected $defaultValue = NULL;

    const TYPE_STRING = 'string';
    const TYPE_TEXT = 'text';
    const TYPE_NUMBER = 'number';
    const TYPE_DATETIME = 'datetime';
    const TYPE_TIME = 'time';
    const TYPE_DATE = 'date';
    const TYPE_BOOLEAN = 'boolean';
}
class WFModelEntityRelationship extends WFObject
{
    protected $name = NULL;     // a call to get{$name} on the entity should fetch the related object(s)
    protected $isExtension = false; // extensions are to-one relationships that use the same id field in both tables and the related table stores "extended" properties. The extended table is basically a "grouping" of properties for the primary entity.
    protected $toOne = true;    // TRUE = to-one, FALSE = to-many
    protected $required = false;    // orthogonal to minCount; minCount is only enforced if there is a relationship. Required disallows lack of related object(s).
    protected $minCount = 1;
    protected $maxCount = 1;
    protected $inverseRelationship = NULL;

    function setToOne($isToOne)
    {
        if (!is_bool($isToOne)) throw( new WFException("boolean expected.") );
        $this->toOne = $isToOne;
        $this->minCount = $this->maxCount = ($this->toOne ? 1 : NULL);
    }
    function setMinCount($num)
    {
        if ($this->toOne) throw( new WFException("Can't set minCount on to-one relationships.") );
        $this->minCount = $num;
    }
    function setMaxCount($num)
    {
        if ($this->toOne) throw( new WFException("Can't set maxCount on to-one relationships.") );
        $this->maxCount = $num;
    }
    function setInverseRelationship($r)
    {
        if (!($r instanceof WFModelEntityRelationship)) throw( new WFException("Relationship must be a WFModelEntityRelationship.") );
        $this->inverseRelationship = $r;
    }
}

// PHOCOA Code-Gen Classes
// Right now, hard-coded for Propel; refactor later to call out to builder classes for things like entity lookup code (any ORM-specific stuff)
class WFModelCodeGenPropel extends WFObject
{
    protected $smarty = NULL;
    protected $modulePath = NULL;

    function __construct()
    {
        $this->smarty = new WFSmarty;
        $this->smarty->left_delimiter = '{{';
        $this->smarty->right_delimiter = '}}';

        // figure out modulePath
        // walk up PWD until we hit "modules" and use that.
        $dir = getcwd();
        $parts = explode('/', $dir);
        $this->modulePath = NULL;
        foreach ($parts as $part) {
            if ($this->modulePath === NULL)
            {
                if ($part == 'modules')
                {
                    $this->modulePath = WWW_ROOT;
                    continue;
                }
            }
            else
            {
                $this->modulePath .= '/' . $part;
            }
        }
        $this->modulePath .= '/';
    }

    function generateModuleForEntity($entity)
    {
        print "Generating module for entity '" . $entity->valueForKey('name') . "'\n";
        $cwd = getcwd();
        $moduleName = strtolower( $entity->valueForKey('name') );
        $moduleDir = $cwd . '/' . $moduleName;
        if (file_exists($moduleDir))
        {
            print "WARNING: Module $moduleName already exists. Skipping\n";
            return;
        }

        mkdir($moduleDir); // module dir
        $this->modulePath .= $moduleName;

        // setup shared instances
        $sharedYaml[$entity->valueForKey('name')] = array(
                'class' => 'WFArrayController',
                'properties' => array(
                    'class' => $entity->valueForKey('name'),
                    'classIdentifiers' => $entity->valueForKey('primaryKeyProperty'),
                    'selectOnInsert' => true,
                    'automaticallyPreparesContent' => false
                    )
                );
        $sharedYaml['paginator'] = array(
                'class' => 'WFPaginator',
                'properties' => array(
                    'modeForm' => 'search',
                    'pageSize' => 25,
                    'itemPhraseSingular' => $entity->valueForKey('name'),
                    'itemPhrasePlural' => $entity->valueForKey('name') . 's'
                    )
                );
        file_put_contents($moduleDir . '/shared.yaml', WFYaml::dump($sharedYaml));

        $sharedEntityId = $entity->valueForKey('name');

        // build module code
        $this->smarty->assign('moduleName', $moduleName);
        $this->smarty->assign('entity', $entity);
        $this->smarty->assign('entityName', $entity->valueForKey('name'));
        $this->smarty->assign('sharedEntityId', $sharedEntityId);
        $this->smarty->assign('sharedEntityPrimaryKeyProperty', $entity->valueForKey('primaryKeyProperty'));
        $this->smarty->assign('descriptiveColumnName', $entity->valueForKey('descriptiveColumnName'));

        // look up Peer column constant name from the PHP name; call ObjPeer::translateFieldName($name, $fromType, $toType)
        $translateF = array($entity->valueForKey('name') . 'Peer', 'translateFieldName');
        $peerColName = call_user_func($translateF, ucfirst($entity->valueForKey('descriptiveColumnName')), BasePeer::TYPE_PHPNAME, BasePeer::TYPE_FIELDNAME);
        $this->smarty->assign('descriptiveColumnConstantName', strtoupper($peerColName));

        $moduleCode = $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/module.tpl');
        file_put_contents($moduleDir . '/' . $moduleName . '.php', $moduleCode);

        // build list page
        // list.yaml
        $listYaml = array();
        $listFormId = 'search' . $entity->valueForKey('name') . 'Form';
        $listYaml[$listFormId] = array(
                'class' => 'WFForm', 'children' => array(
                    'search' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Search'
                            ),
                        ),
                    'clear' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Clear'
                            ),
                        ),
                    'paginatorState' => array(
                        'class' => 'WFPaginatorState',
                        'properties' => array('paginator' => '#module#paginator')
                        ),
                    'query' => array('class' => 'WFTextField'),
                    )
                );
        $listYaml['paginatorNavigation'] = array(
                'class' => 'WFPaginatorNavigation',
                'properties' => array('paginator' => '#module#paginator'),
                );
        $listYaml['paginatorPageInfo'] = array(
                'class' => 'WFPaginatorPageInfo',
                'properties' => array('paginator' => '#module#paginator'),
                );

        $descriptiveColumnName = $entity->valueForKey('descriptiveColumnName');
        $listYaml[$descriptiveColumnName] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "{$descriptiveColumnName}Prototype" => array(
                        'class' => 'WFLink',
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/detail/%1%')
                                ),
                            'label' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('descriptiveColumnName')
                                )
                            )
                        )
                    )
                    );
        $listYaml['editLink'] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "editLinkPrototype" => array(
                        'class' => 'WFLink',
                        'properties' => array('label' => 'Edit'),
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/edit/%1%')
                                )
                            )
                        ) 
                    )
                );
        $listYaml['deleteLink'] = array(
                'class' => 'WFDynamic',
                'properties' => array(
                    'arrayController' => "#module#{$sharedEntityId}",
                    ),
                'children' => array(
                    "deleteLinkPrototype" => array(
                        'class' => 'WFLink',
                        'properties' => array('label' => 'Delete'),
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => '#current#',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                'options' => array('ValuePattern' => $this->modulePath . '/confirmDelete/%1%')
                                )
                            )
                        ) 
                    )
                );
        file_put_contents($moduleDir . '/list.yaml', WFYaml::dump($listYaml));

        // build list.tpl
        $this->smarty->assign('listFormId', $listFormId);
        file_put_contents($moduleDir . '/list.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/list.tpl'));

        // build edit page
        // build edit.yaml
        $editYaml = array();
        $editFormId = 'edit' . $entity->valueForKey('name') . 'Form';
        $editYaml[$editFormId] = array('class' => 'WFForm', 'children' => array());

        $widgets = array();
        foreach ($entity->getProperties() as $property) {
            $widgetID = $property->valueForKey('name');
            $widgets[$widgetID] = $property;

            if ($property->valueForKey('name') === $entity->valueForKey('primaryKeyProperty'))
            {
                $class = 'WFHidden';
            }
            else
            {
                switch ($property->valueForKey('type')) {
                    case WFModelEntityProperty::TYPE_TEXT;
                        $class = 'WFTextArea';
                        break;
                    case WFModelEntityProperty::TYPE_NUMBER;
                    case WFModelEntityProperty::TYPE_STRING;
                    case WFModelEntityProperty::TYPE_DATETIME;
                    case WFModelEntityProperty::TYPE_TIME;
                    case WFModelEntityProperty::TYPE_DATE;
                        $class = 'WFTextField';
                        break;
                    case WFModelEntityProperty::TYPE_BOOLEAN;
                        $class = 'WFCheckbox';
                        break;
                    default:
                        $class = 'WFTextField';
                }
            }
            $editYaml[$editFormId]['children'][$widgetID] = array(
                    'class' => $class,
                    'bindings' => array(
                        'value' => array(
                            'instanceID' => $sharedEntityId,
                            'controllerKey' => 'selection',
                            'modelKeyPath' => $widgetID
                            )
                        )
                    );

        }
        // status message
        $editYaml['statusMessage'] = array('class' => 'WFMessageBox');
        $editYaml[$editFormId]['children']['saveNew'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Create ' . $entity->valueForKey('name'),
                    'action' => 'save'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        'options' => array(
                            'valueTransformer' => 'WFNegateBoolean',
                            )
                        )
                    )
                );
        $editYaml[$editFormId]['children']['save'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Save'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        )
                    )
                );
        $editYaml[$editFormId]['children']['deleteObj'] = array(
                'class' => 'WFSubmit',
                'properties' => array(
                    'label' => 'Delete'
                    ),
                'bindings' => array(
                    'hidden' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => 'isNew',
                        )
                    )
                );
        file_put_contents($moduleDir . '/edit.yaml', WFYaml::dump($editYaml));

        // build edit.tpl
        $this->smarty->assign('editFormId', $editFormId);
        $this->smarty->assign('widgets', $widgets);
        file_put_contents($moduleDir . '/edit.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/edit.tpl'));

        // build confirmDelete page
        $confirmDeleteYaml = array();
        $confirmDeleteFormId = 'confirmDelete' . $entity->valueForKey('name')  . 'Form';
        $pkId = $entity->valueForKey('primaryKeyProperty');
        $confirmDeleteYaml[$confirmDeleteFormId] = array(
                'class' => 'WFForm',
                'children' => array(
                    $pkId => array(
                        'class' => 'WFHidden',
                        'bindings' => array(
                            'value' => array(
                                'instanceID' => $sharedEntityId,
                                'controllerKey' => 'selection',
                                'modelKeyPath' => $entity->valueForKey('primaryKeyProperty'),
                                )
                            )
                        ),
                    'cancel' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Cancel'
                            )
                        ),
                    'deleteObj' => array(
                        'class' => 'WFSubmit',
                        'properties' => array(
                            'label' => 'Delete'
                            )
                        )
                    ),
                    );
        $confirmDeleteYaml['confirmMessage'] = array(
                'class' => 'WFMessageBox',
                'bindings' => array(
                    'value' => array(
                        'instanceID' => $sharedEntityId,
                        'controllerKey' => 'selection',
                        'modelKeyPath' => $descriptiveColumnName,
                        'options' => array(
                            'ValuePattern' => 'Are you sure you want to delete ' . $entity->valueForKey('name') . ' "%1%"?'
                            )
                        )
                    )
                );
        file_put_contents($moduleDir . '/confirmDelete.yaml', WFYaml::dump($confirmDeleteYaml));
        
        // confirmDelete.tpl file
        $this->smarty->assign('confirmDeleteFormId', $confirmDeleteFormId);
        file_put_contents($moduleDir . '/confirmDelete.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/confirmDelete.tpl'));

        // delete success
        $deleteSuccessYaml = array();
        $deleteSuccessYaml['statusMessage'] = array(
                'class' => 'WFMessageBox',
                'properties' => array(
                    'value' => $entity->valueForKey('name') . ' successfully deleted.'
                    )
                );
        file_put_contents($moduleDir . '/deleteSuccess.yaml', WFYaml::dump($deleteSuccessYaml));
        file_put_contents($moduleDir . '/deleteSuccess.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/deleteSuccess.tpl'));

        // detail page
        $detailYaml = array();
        $widgets = array();
        foreach ($entity->getProperties() as $property) {
            $widgetID = $property->valueForKey('name');
            $widgets[$widgetID] = $property;
            $detailYaml[$widgetID] = array(
                    'class' => 'WFLabel',
                    'bindings' => array(
                        'value' => array(
                            'instanceID' => $sharedEntityId,
                            'controllerKey' => 'selection',
                            'modelKeyPath' => $widgetID
                            )
                        )
                    );
        }
        file_put_contents($moduleDir . '/detail.yaml', WFYaml::dump($detailYaml));
       
        // build detail.tpl
        $this->smarty->assign('widgets', $widgets);
        file_put_contents($moduleDir . '/detail.tpl', $this->smarty->fetch(FRAMEWORK_DIR . '/framework/generator/detail.tpl'));
    }
}
]]></response>
March 18, 2011 03:24 PM
Alan Pinstein
The last successful send.
Content:
context_names -d 0 -i 28
Content:
context_names -d 0 -i 28
March 18, 2011 03:25 PM
Robert
Two things:
1) When it's hung, can you go to /Applications/Utilities/Activity Monitor.app, find MacGDBp, and click Sample Process. Upload the sample here.
2) Check /Applications/Utilities/Console.app and see if there are any messages from MacGDBp when it gets hung.
1) When it's hung, can you go to /Applications/Utilities/Activity Monitor.app, find MacGDBp, and click Sample Process. Upload the sample here.
2) Check /Applications/Utilities/Console.app and see if there are any messages from MacGDBp when it gets hung.
March 18, 2011 03:31 PM
Alan Pinstein
1) There are 2 entries in the console log:
3/18/11 11:27:39 AM MacGDBp[29028] tx = 0 vs 27
3/18/11 11:27:39 AM MacGDBp[29028] out of date transaction 273
2) The "Sample Process" output:
NOTE: I am not sure this is the right "place" as we might've hit a UI button after the hang. It's hard to tell exactly when it hangs.
Sampling process 29028 for 3 seconds with 1 millisecond of run time
between samples
Sampling completed, processing symbols...
Analysis of sampling MacGDBp (pid 29028) every 1 millisecond
Process: MacGDBp [29028]
Path: /Users/ardell/Downloads/MacGDBp 1.4.app/Contents/MacOS/MacGDBp
Load Address: 0x1000
Identifier: org.bluestatic.macgdbp
Version: 1.4 (85)
Code Type: X86 (Native)
Parent Process: launchd [348]
Date/Time: 2011-03-18 11:30:05.903 -0400
OS Version: Mac OS X 10.6.6 (10J567)
Report Version: 6
Call graph:
2411 Thread_1676663 DispatchQueue_1: com.apple.main-thread (serial)
2411 start
2411 NSApplicationMain
2411 -[NSApplication run]
2411 -[NSApplication
nextEventMatchingMask:untilDate:inMode:dequeue:]
2411 _DPSNextEvent
2411 BlockUntilNextEventMatchingListInMode
2411 ReceiveNextEventCommon
2411 RunCurrentEventLoopInMode
2411 CFRunLoopRunInMode
2411 CFRunLoopRunSpecific
2411 __CFRunLoopRun
2411 mach_msg
2411 mach_msg_trap
2411 Thread_1676666 DispatchQueue_2:
com.apple.libdispatch-manager (serial)
2411 start_wqthread
2411 _pthread_wqthread
2411 _dispatch_worker_thread2
2411 _dispatch_queue_invoke
2411 _dispatch_mgr_invoke
2411 kevent
2411 Thread_1676670
2411 thread_start
2411 _pthread_start
2411 __NSThread__main__
2411 -[NSThread main]
2411 -[NetworkConnection runNetworkThread]
2411 CFRunLoopRun
2411 CFRunLoopRunSpecific
2411 __CFRunLoopRun
2411 mach_msg
2411 mach_msg_trap
2411 Thread_1676671: com.apple.CFSocket.private
2411 thread_start
2411 _pthread_start
2411 __CFSocketManager
2411 select$DARWIN_EXTSN
2411 Thread_1677665
2411 start_wqthread
2411 _pthread_wqthread
2411 __workq_kernreturn
Total number in stack (recursive counted multiple, when >=5):
Sort by top of stack, same collapsed (when >= 5):
mach_msg_trap 4822
__workq_kernreturn 2411
kevent 2411
select$DARWIN_EXTSN 2411
Binary Images:
0x1000 - 0x10ffb +org.bluestatic.macgdbp 1.4 (85)
<4381E03F-895D-DA10-7748-88174BDD8EB2> /Users/ardell/Downloads/MacGDBp
1.4.app/Contents/MacOS/MacGDBp
0x1b000 - 0x2efff +org.andymatuschak.Sparkle 1.5 Beta 6 (313)
<5DF2B8A3-560D-4500-6B85-4215644DE532> /Users/ardell/Downloads/MacGDBp
1.4.app/Contents/Frameworks/Sparkle.framework/Versions/A/Sparkle
0x3c000 - 0xf1fe7 libcrypto.0.9.7.dylib 0.9.7 (compatibility
0.9.7) <AACC86C0-86B4-B1A7-003F-2A0AF68973A2>
/usr/lib/libcrypto.0.9.7.dylib
0x8fe00000 - 0x8fe4162b dyld 132.1 (???)
<749D24EE-54BD-D74B-D305-C13F5E6C95D8> /usr/lib/dyld
0x9008b000 - 0x901b9fe7 com.apple.CoreData 102.1 (251)
<87FE6861-F2D6-773D-ED45-345272E56463>
/System/Library/Frameworks/CoreData.framework/Versions/A/CoreData
0x901ba000 - 0x901baff7 com.apple.Accelerate.vecLib 3.6 (vecLib 3.6)
<ABF97DA4-3BDF-6FFD-6239-B023CA1F7974>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/vecLib
0x901bb000 - 0x901c1fff com.apple.CommonPanels 1.2.4 (91)
<2438AF5D-067B-B9FD-1248-2C9987F360BA>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/CommonPanels.framework/Versions/A/CommonPanels
0x901c2000 - 0x901e2fe7 libresolv.9.dylib 41.0.0 (compatibility
1.0.0) <BF7FF2F6-5FD3-D78F-77BC-9E2CB2A5E309>
/usr/lib/libresolv.9.dylib
0x90266000 - 0x90276ff7 libsasl2.2.dylib 3.15.0 (compatibility 3.0.0)
<C8744EA3-0AB7-CD03-E639-C4F2B910BE5D> /usr/lib/libsasl2.2.dylib
0x90301000 - 0x90305ff7 libGIF.dylib ??? (???)
<FA466D54-68CF-D1AB-47A0-4134C8B1B6FD>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libGIF.dylib
0x90314000 - 0x90347ff7 com.apple.AE 496.4 (496.4)
<C73D124C-C722-41D8-3465-4CE0D0BA9307>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/AE.framework/Versions/A/AE
0x9037b000 - 0x903beff7 libGLU.dylib ??? (???)
<BB66EDB2-D5FE-61C9-21BE-747F9862819C>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGLU.dylib
0x903bf000 - 0x90489fef com.apple.CoreServices.OSServices 357 (357)
<F66F783A-9B51-953F-CAC9-509E1F550B4B>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/OSServices.framework/Versions/A/OSServices
0x9048a000 - 0x904a5ff7 libPng.dylib ??? (???)
<DF9BC42C-13E0-3080-A106-75121FD577CF>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libPng.dylib
0x904a6000 - 0x90515ff7 libvMisc.dylib 268.0.1 (compatibility 1.0.0)
<595A5539-9F54-63E6-7AAC-C04E1574B050>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvMisc.dylib
0x90516000 - 0x90518ff7 com.apple.securityhi 4.0 (36638)
<C7DA80C1-DCFD-C321-08DA-5E6946CA66E0>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/SecurityHI.framework/Versions/A/SecurityHI
0x90721000 - 0x90765fe7 com.apple.Metadata 10.6.3 (507.15)
<A23633F1-E913-66C2-A073-E2B174C09B18>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/Metadata.framework/Versions/A/Metadata
0x907d5000 - 0x90af9fef com.apple.HIToolbox 1.6.4 (???)
<4699C8BB-DE74-C530-564B-D131F74C9B54>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/HIToolbox.framework/Versions/A/HIToolbox
0x90c8d000 - 0x90e46feb com.apple.ImageIO.framework 3.0.4 (3.0.4)
<6D8C6C54-9F39-0D0F-564D-2ABA12E97BBC>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/ImageIO
0x90e47000 - 0x90eabffb com.apple.htmlrendering 72 (1.1.4)
<4D451A35-FAB6-1288-71F6-F24A4B6E2371>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/HTMLRendering.framework/Versions/A/HTMLRendering
0x90f03000 - 0x90f9eff7 com.apple.ApplicationServices.ATS 4.4 (???)
<ECB16606-4DF8-4AFB-C91D-F7947C26040F>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ATS.framework/Versions/A/ATS
0x91102000 - 0x9115fff7 com.apple.framework.IOKit 2.0 (???)
<A769737F-E0D6-FB06-29B4-915CF4F43420>
/System/Library/Frameworks/IOKit.framework/Versions/A/IOKit
0x9127a000 - 0x91660ffb com.apple.RawCamera.bundle 3.4.1 (546)
<D966727B-B687-3029-067F-87FC6CCEBB55>
/System/Library/CoreServices/RawCamera.bundle/Contents/MacOS/RawCamera
0x91661000 - 0x917e3fe7 libicucore.A.dylib 40.0.0 (compatibility
1.0.0) <35DB7644-0780-D2AB-F6A9-45F28D2D434A>
/usr/lib/libicucore.A.dylib
0x91899000 - 0x918bfffb com.apple.DictionaryServices 1.1.2 (1.1.2)
<43E1D565-6E01-3681-F2E5-72AE4C3A097A>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/DictionaryServices.framework/Versions/A/DictionaryServices
0x918f0000 - 0x91951fe7 com.apple.CoreText 3.5.0 (???)
<BB50C045-25F5-65B8-B1DB-8CDAEF45EB46>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreText.framework/Versions/A/CoreText
0x9195a000 - 0x9199eff3 com.apple.coreui 2 (114)
<2234855E-3BED-717F-0BFA-D1A289ECDBDA>
/System/Library/PrivateFrameworks/CoreUI.framework/Versions/A/CoreUI
0x9199f000 - 0x91cbfff3 com.apple.CoreServices.CarbonCore 861.23
(861.23) <96534EF7-C22E-0C01-C56F-FF7047E41224>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/CarbonCore.framework/Versions/A/CarbonCore
0x91cc0000 - 0x91d6afe7 com.apple.CFNetwork 454.11.5 (454.11.5)
<DD575760-7A29-111D-5A69-EAFD3410F74D>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/CFNetwork.framework/Versions/A/CFNetwork
0x91d6b000 - 0x91e48ff7 com.apple.vImage 4.0 (4.0)
<64597E4B-F144-DBB3-F428-0EC3D9A1219E>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vImage.framework/Versions/A/vImage
0x91e71000 - 0x91ea2ff7 libGLImage.dylib ??? (???)
<E3EC8E92-4DDD-E7B8-3D38-C5A5160A4930>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGLImage.dylib
0x91ea3000 - 0x91eb4ff7 com.apple.LangAnalysis 1.6.6 (1.6.6)
<3036AD83-4F1D-1028-54EE-54165E562650>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/LangAnalysis.framework/Versions/A/LangAnalysis
0x91ee1000 - 0x91ee4ff7 libCoreVMClient.dylib ??? (???)
<973B9E1F-70B3-2E76-B14B-E57F306AD2DF>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libCoreVMClient.dylib
0x91ee5000 - 0x91f27ff7 libvDSP.dylib 268.0.1 (compatibility 1.0.0)
<8A4721DE-25C4-C8AA-EA90-9DA7812E3EBA>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvDSP.dylib
0x92105000 - 0x92111ff7 libkxld.dylib ??? (???)
<9D8378E0-1C58-EED8-EA00-F4515B8BE7A3> /usr/lib/system/libkxld.dylib
0x92112000 - 0x92134fef com.apple.DirectoryService.Framework 3.6
(621.9) <3171B16F-E4E1-89AA-B846-D698E3D6D457>
/System/Library/Frameworks/DirectoryService.framework/Versions/A/DirectoryService
0x92135000 - 0x92156fe7 com.apple.opencl 12.3 (12.3)
<DEA600BF-4F54-66B5-DB2F-DC57FD518543>
/System/Library/Frameworks/OpenCL.framework/Versions/A/OpenCL
0x92157000 - 0x921a7ff7 com.apple.framework.familycontrols 2.0.2
(2020) <AF7F86F1-F7BF-CBA8-7A4A-D8F7A19F9601>
/System/Library/PrivateFrameworks/FamilyControls.framework/Versions/A/FamilyControls
0x921a8000 - 0x9234fff7 libSystem.B.dylib 125.2.1 (compatibility
1.0.0) <4FFBF71A-D603-3C64-2BC6-BFBFFFD562F0>
/usr/lib/libSystem.B.dylib
0x92350000 - 0x923d2ffb SecurityFoundation ??? (???)
<2E1F1AF0-A258-D215-2600-5DF03896D1F1>
/System/Library/Frameworks/SecurityFoundation.framework/Versions/A/SecurityFoundation
0x923d3000 - 0x9246bfe7 edu.mit.Kerberos 6.5.10 (6.5.10)
<DC19F49B-184E-FD0F-13F8-3A31924A3B66>
/System/Library/Frameworks/Kerberos.framework/Versions/A/Kerberos
0x925ad000 - 0x929e2ff7 libLAPACK.dylib 219.0.0 (compatibility 1.0.0)
<5E2D2283-57DE-9A49-1DB0-CD027FEFA6C2>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libLAPACK.dylib
0x929e3000 - 0x929e7ff7 libGFXShared.dylib ??? (???)
<9E14BE2F-C863-40E9-41A6-1BE9045663A0>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGFXShared.dylib
0x92a17000 - 0x92a1bff7 IOSurface ??? (???)
<235E7E3D-B6E5-0AAA-C41A-7AC1F54A7EBF>
/System/Library/Frameworks/IOSurface.framework/Versions/A/IOSurface
0x92a1c000 - 0x92a52fff libtidy.A.dylib ??? (???)
<0FD72C68-4803-4C5B-3A63-05D7394BFD71> /usr/lib/libtidy.A.dylib
0x92cb0000 - 0x92d4dfe3 com.apple.LaunchServices 362.2 (362.2)
<F3952CAB-322F-A12F-57AF-8B91B1D76DDE>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/LaunchServices.framework/Versions/A/LaunchServices
0x92e1d000 - 0x92e1eff7 com.apple.TrustEvaluationAgent 1.1 (1)
<2D970A9B-77E8-EDC0-BEC6-7580D78B2843>
/System/Library/PrivateFrameworks/TrustEvaluationAgent.framework/Versions/A/TrustEvaluationAgent
0x92e1f000 - 0x92e3eff7 com.apple.CoreVideo 1.6.2 (45.6)
<EB53CAA4-5EE2-C356-A954-5775F7DDD493>
/System/Library/Frameworks/CoreVideo.framework/Versions/A/CoreVideo
0x92eae000 - 0x92ed6ff7 libxslt.1.dylib 3.24.0 (compatibility 3.0.0)
<769EF4B2-C1AD-73D5-AAAD-1564DAEA77AF> /usr/lib/libxslt.1.dylib
0x92f59000 - 0x9305dfe7 libcrypto.0.9.8.dylib 0.9.8 (compatibility
0.9.8) <BDEFA030-5E75-7C47-2904-85AB16937F45>
/usr/lib/libcrypto.0.9.8.dylib
0x9305e000 - 0x930a1ff7 com.apple.NavigationServices 3.5.4 (182)
<8DC6FD4A-6C74-9C23-A4C3-715B44A8D28C>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/NavigationServices.framework/Versions/A/NavigationServices
0x930a2000 - 0x93299feb com.apple.JavaScriptCore 6533.18 (6533.18.1)
<F740BA2B-EFCF-98E2-FFC2-361BD7D41330>
/System/Library/Frameworks/JavaScriptCore.framework/Versions/A/JavaScriptCore
0x9329a000 - 0x932e7feb
com.apple.DirectoryService.PasswordServerFramework 6.0 (6.0)
<BF66BA5D-BBC8-78A5-DBE2-F9DE3DD1D775>
/System/Library/PrivateFrameworks/PasswordServer.framework/Versions/A/PasswordServer
0x9333f000 - 0x93363ff7 libJPEG.dylib ??? (???)
<E064CF03-8CC2-C83E-C951-D46610834D1C>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libJPEG.dylib
0x93369000 - 0x93422fe7 libsqlite3.dylib 9.6.0 (compatibility 9.0.0)
<52438E77-55D1-C231-1936-76F1369518E4> /usr/lib/libsqlite3.dylib
0x93423000 - 0x93c12557 com.apple.CoreGraphics 1.545.0 (???)
<1AB39678-00D5-FB88-3B41-93D78348E0DE>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/CoreGraphics
0x93c31000 - 0x93cc3fe7 com.apple.print.framework.PrintCore 6.3
(312.7) <7410D1B2-655D-68DA-D4B9-2C65747B6817>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/PrintCore.framework/Versions/A/PrintCore
0x93cc4000 - 0x93cdcff7 com.apple.CFOpenDirectory 10.6 (10.6)
<F9AFC571-3539-6B46-ABF9-46DA2B608819>
/System/Library/Frameworks/OpenDirectory.framework/Versions/A/Frameworks/CFOpenDirectory.framework/Versions/A/CFOpenDirectory
0x93cdd000 - 0x93cddff7 com.apple.ApplicationServices 38 (38)
<8012B504-3D83-BFBB-DA65-065E061CFE03>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/ApplicationServices
0x93cdf000 - 0x93e0efe3 com.apple.audio.toolbox.AudioToolbox 1.6.5
(1.6.5) <0A0F68E5-4806-DB51-764B-D97554B801AD>
/System/Library/Frameworks/AudioToolbox.framework/Versions/A/AudioToolbox
0x94109000 - 0x94109ff7 com.apple.Carbon 150 (152)
<734BDB59-8B13-54FA-0653-AA8623DF9846>
/System/Library/Frameworks/Carbon.framework/Versions/A/Carbon
0x941c5000 - 0x9423ffff com.apple.audio.CoreAudio 3.2.6 (3.2.6)
<A02CEAE9-943A-CBE2-2350-4631C1E7B0A7>
/System/Library/Frameworks/CoreAudio.framework/Versions/A/CoreAudio
0x9475f000 - 0x9486bff7 libGLProgrammability.dylib ??? (???)
<A077BFEA-19C6-9F48-2F36-8E4E55376F49>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGLProgrammability.dylib
0x9486c000 - 0x94876fe7 com.apple.audio.SoundManager 3.9.3 (3.9.3)
<5F494955-7290-2D91-DA94-44B590191771>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/CarbonSound.framework/Versions/A/CarbonSound
0x9487f000 - 0x948a9ff7 com.apple.shortcut 1.1 (1.1)
<B0514FA9-7CAE-AD94-93CA-7B2A2C5F7B8A>
/System/Library/PrivateFrameworks/Shortcut.framework/Versions/A/Shortcut
0x948aa000 - 0x948dcfe3 libTrueTypeScaler.dylib ??? (???)
<6E9D1A50-330E-F1F4-F93D-9ECC8A61B21A>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ATS.framework/Versions/A/Resources/libTrueTypeScaler.dylib
0x948dd000 - 0x9495dfeb com.apple.SearchKit 1.3.0 (1.3.0)
<9E18AEA5-F4B4-8BE5-EEA9-818FC4F46FD9>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/SearchKit.framework/Versions/A/SearchKit
0x9495e000 - 0x94968ffb com.apple.speech.recognition.framework 3.11.1
(3.11.1) <7486003F-8FDB-BD6C-CB34-DE45315BD82C>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/SpeechRecognition.framework/Versions/A/SpeechRecognition
0x94969000 - 0x94970ff3 com.apple.print.framework.Print 6.1 (237.1)
<F5AAE53D-5530-9004-A9E3-2C1690C5328E>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/Print.framework/Versions/A/Print
0x94971000 - 0x9497cff7 libCSync.A.dylib 545.0.0 (compatibility
64.0.0) <CB2510BD-A5B3-9D90-5917-C73F6ECAC913>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/Resources/libCSync.A.dylib
0x94c0d000 - 0x94c48feb libFontRegistry.dylib ??? (???)
<4FB144ED-8AF9-27CF-B315-DCE5575D5231>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ATS.framework/Versions/A/Resources/libFontRegistry.dylib
0x94c49000 - 0x94c82ff7 libcups.2.dylib 2.8.0 (compatibility 2.0.0)
<E0D512DD-365D-46A0-F50C-435BC250424F> /usr/lib/libcups.2.dylib
0x94d62000 - 0x950cdff7 com.apple.QuartzCore 1.6.3 (227.34)
<0B59EAF1-4892-C5CE-4A67-66EBD383359E>
/System/Library/Frameworks/QuartzCore.framework/Versions/A/QuartzCore
0x9511c000 - 0x9511cff7 com.apple.Cocoa 6.6 (???)
<EA27B428-5904-B00B-397A-185588698BCC>
/System/Library/Frameworks/Cocoa.framework/Versions/A/Cocoa
0x95176000 - 0x95184ff7 com.apple.opengl 1.6.12 (1.6.12)
<9F13B279-F289-18AC-5D86-DCD52BAF087D>
/System/Library/Frameworks/OpenGL.framework/Versions/A/OpenGL
0x9527c000 - 0x9527cff7 com.apple.Accelerate 1.6 (Accelerate 1.6)
<3891A689-4F38-FACD-38B2-4BF937DE30CF>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Accelerate
0x9527d000 - 0x9532dff3 com.apple.ColorSync 4.6.3 (4.6.3)
<0354B408-665F-8B3F-87FF-64E6322276F0>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ColorSync.framework/Versions/A/ColorSync
0x9532e000 - 0x9532eff7 com.apple.CoreServices 44 (44)
<51CFA89A-33DB-90ED-26A8-67D461718A4A>
/System/Library/Frameworks/CoreServices.framework/Versions/A/CoreServices
0x9532f000 - 0x95378fe7 libTIFF.dylib ??? (???)
<72AC8D6B-F187-1462-901F-999E68C24848>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libTIFF.dylib
0x9584f000 - 0x9629aff7 com.apple.WebCore 6533.18 (6533.18.1)
<55C5330D-DB7D-56B3-E31A-5FF98BD9A3A8>
/System/Library/Frameworks/WebKit.framework/Versions/A/Frameworks/WebCore.framework/Versions/A/WebCore
0x9629b000 - 0x96416fe7 com.apple.CoreFoundation 6.6.4 (550.42)
<C78D5079-663E-9734-7AFA-6CE79A0539F1>
/System/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation
0x96460000 - 0x96466fe7 com.apple.CommerceCore 1.0 (6)
<41C2A87D-93D8-56C1-9292-0400699F23C1>
/System/Library/PrivateFrameworks/CommerceKit.framework/Versions/A/Frameworks/CommerceCore.framework/Versions/A/CommerceCore
0x964ac000 - 0x96d8cff7 com.apple.AppKit 6.6.7 (1038.35)
<ABC7783C-E4D5-B848-BED6-99451D94D120>
/System/Library/Frameworks/AppKit.framework/Versions/C/AppKit
0x96d8d000 - 0x96d8dff7 liblangid.dylib ??? (???)
<B99607FC-5646-32C8-2C16-AFB5EA9097C2> /usr/lib/liblangid.dylib
0x96e38000 - 0x96f13feb com.apple.DesktopServices 1.5.9 (1.5.9)
<CED00AC1-924B-0E45-7D5E-1CEA8929F5BE>
/System/Library/PrivateFrameworks/DesktopServicesPriv.framework/Versions/A/DesktopServicesPriv
0x96f14000 - 0x9732aff7 libBLAS.dylib 219.0.0 (compatibility 1.0.0)
<C4FB303A-DB4D-F9E8-181C-129585E59603>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libBLAS.dylib
0x9736c000 - 0x9736eff7 libRadiance.dylib ??? (???)
<68BF4654-B74A-C843-759F-7FC62385F251>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libRadiance.dylib
0x9736f000 - 0x97375ff7 libCGXCoreImage.A.dylib 545.0.0
(compatibility 64.0.0) <DACD11D8-4B64-CD3B-C988-B1041E07D13A>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/Resources/libCGXCoreImage.A.dylib
0x97378000 - 0x97378ff7 com.apple.vecLib 3.6 (vecLib 3.6)
<FF4DC8B6-0AB0-DEE8-ADA8-7B57645A1F36>
/System/Library/Frameworks/vecLib.framework/Versions/A/vecLib
0x97615000 - 0x976c2fe7 libobjc.A.dylib 227.0.0 (compatibility 1.0.0)
<C8925910-B927-968B-4B71-D83A4CEF8646> /usr/lib/libobjc.A.dylib
0x976d4000 - 0x976dfff7 libGL.dylib ??? (???)
<48405993-0AE9-292B-6705-C3525528682A>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGL.dylib
0x97708000 - 0x97724fe3 com.apple.openscripting 1.3.1 (???)
<2A748037-D1C0-6D47-2C4A-0562AF799AC9>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/OpenScripting.framework/Versions/A/OpenScripting
0x97725000 - 0x97728ff7 libCGXType.A.dylib 545.0.0 (compatibility
64.0.0) <B624AACE-991B-0FFA-2482-E69970576CE1>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/Resources/libCGXType.A.dylib
0x97729000 - 0x9776aff7 libRIP.A.dylib 545.0.0 (compatibility 64.0.0)
<16DAE1A5-937A-1CA2-D98F-2AF958B62993>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/Resources/libRIP.A.dylib
0x9776b000 - 0x97813ffb com.apple.QD 3.36 (???)
<FA2785A4-BB69-DCB4-3BA3-7C89A82CAB41>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/QD.framework/Versions/A/QD
0x97814000 - 0x97817ffb com.apple.help 1.3.1 (41)
<67F1F424-3983-7A2A-EC21-867BE838E90B>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/Help.framework/Versions/A/Help
0x97b36000 - 0x97becff7 libFontParser.dylib ??? (???)
<33F62EE1-E457-C6FD-369E-E86745B94A4B>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ATS.framework/Versions/A/Resources/libFontParser.dylib
0x97c39000 - 0x97c4efff com.apple.ImageCapture 6.0.1 (6.0.1)
<E7ED2AC1-834C-A44E-531E-EC05F0496DBF>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/ImageCapture.framework/Versions/A/ImageCapture
0x97c4f000 - 0x97c52fe7 libmathCommon.A.dylib 315.0.0 (compatibility
1.0.0) <1622A54F-1A98-2CBE-B6A4-2122981A500E>
/usr/lib/system/libmathCommon.A.dylib
0x97d01000 - 0x97d0eff7 com.apple.NetFS 3.2.1 (3.2.1)
<94A52A6D-F071-09D7-E80F-F633F17233FE>
/System/Library/Frameworks/NetFS.framework/Versions/A/NetFS
0x97d8c000 - 0x97feffff com.apple.security 6.1.1 (37594)
<B6F2A8BF-C1B7-A0E2-83FB-4FF265E9BDDC>
/System/Library/Frameworks/Security.framework/Versions/A/Security
0x980c2000 - 0x98113ff7 com.apple.HIServices 1.8.2 (???)
<F6EAC2D1-902A-9374-FC4B-43B50E054416>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/HIServices.framework/Versions/A/HIServices
0x98140000 - 0x98141ff7 com.apple.audio.units.AudioUnit 1.6.5 (1.6.5)
<BE4C2495-B758-AD22-DCC0-56A6791E948E>
/System/Library/Frameworks/AudioUnit.framework/Versions/A/AudioUnit
0x98142000 - 0x9814bff7 com.apple.DiskArbitration 2.3 (2.3)
<E9C40767-DA6A-6CCB-8B00-2D5706753000>
/System/Library/Frameworks/DiskArbitration.framework/Versions/A/DiskArbitration
0x98181000 - 0x98282fe7 libxml2.2.dylib 10.3.0 (compatibility 10.0.0)
<ED8E45C6-B078-15E8-938D-99D8FD1EAE64> /usr/lib/libxml2.2.dylib
0x982cb000 - 0x98379ff3 com.apple.ink.framework 1.3.3 (107)
<233A981E-A2F9-56FB-8BDE-C2DEC3F20784>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/Ink.framework/Versions/A/Ink
0x9837a000 - 0x9837fff7 com.apple.OpenDirectory 10.6 (10.6)
<C1B46982-7D3B-3CC4-3BC2-3E4B595F0231>
/System/Library/Frameworks/OpenDirectory.framework/Versions/A/OpenDirectory
0x98380000 - 0x983c6ff7 libauto.dylib ??? (???)
<29422A70-87CF-10E2-CE59-FEE1234CFAAE> /usr/lib/libauto.dylib
0x99350000 - 0x995c3fe7 com.apple.Foundation 6.6.4 (751.42)
<65F16BF4-D106-F2F5-53F3-5BFBC2FCE608>
/System/Library/Frameworks/Foundation.framework/Versions/C/Foundation
0x99604000 - 0x99618fe7 libbsm.0.dylib ??? (???)
<14CB053A-7C47-96DA-E415-0906BA1B78C9> /usr/lib/libbsm.0.dylib
0x99629000 - 0x99738fe7 com.apple.WebKit 6533.18 (6533.18.1)
<C7FF7199-91FF-7F6F-C5D9-487A86D65E07>
/System/Library/Frameworks/WebKit.framework/Versions/A/WebKit
0x99739000 - 0x99776ff7 com.apple.SystemConfiguration 1.10.5 (1.10.2)
<362DF639-6E5F-9371-9B99-81C581A8EE41>
/System/Library/Frameworks/SystemConfiguration.framework/Versions/A/SystemConfiguration
0x9987a000 - 0x998e4fe7 libstdc++.6.dylib 7.9.0 (compatibility 7.0.0)
<411D87F4-B7E1-44EB-F201-F8B4F9227213> /usr/lib/libstdc++.6.dylib
0x9991d000 - 0x9992bfe7 libz.1.dylib 1.2.3 (compatibility 1.0.0)
<33C1B260-ED05-945D-FC33-EF56EC791E2E> /usr/lib/libz.1.dylib
0x9992c000 - 0x9993eff7 com.apple.MultitouchSupport.framework 207.10
(207.10) <32CE2895-DAF0-2137-F9BE-8150359F43A1>
/System/Library/PrivateFrameworks/MultitouchSupport.framework/Versions/A/MultitouchSupport
0x9993f000 - 0x99949ff7 com.apple.HelpData 2.0.4 (34)
<001A7163-C977-C30F-1B4B-4F5647F72E96>
/System/Library/PrivateFrameworks/HelpData.framework/Versions/A/HelpData
0x9994a000 - 0x9995effb com.apple.speech.synthesis.framework 3.10.35
(3.10.35) <57DD5458-4F24-DA7D-0927-C3321A65D743>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/SpeechSynthesis.framework/Versions/A/SpeechSynthesis
0xffff0000 - 0xffff1fff libSystem.B.dylib ??? (???)
<4FFBF71A-D603-3C64-2BC6-BFBFFFD562F0> /usr/lib/libSystem.B.dylib
Sample analysis of process 29028 written to file /dev/stdout
3/18/11 11:27:39 AM MacGDBp[29028] tx = 0 vs 27
3/18/11 11:27:39 AM MacGDBp[29028] out of date transaction 273
2) The "Sample Process" output:
NOTE: I am not sure this is the right "place" as we might've hit a UI button after the hang. It's hard to tell exactly when it hangs.
Sampling process 29028 for 3 seconds with 1 millisecond of run time
between samples
Sampling completed, processing symbols...
Analysis of sampling MacGDBp (pid 29028) every 1 millisecond
Process: MacGDBp [29028]
Path: /Users/ardell/Downloads/MacGDBp 1.4.app/Contents/MacOS/MacGDBp
Load Address: 0x1000
Identifier: org.bluestatic.macgdbp
Version: 1.4 (85)
Code Type: X86 (Native)
Parent Process: launchd [348]
Date/Time: 2011-03-18 11:30:05.903 -0400
OS Version: Mac OS X 10.6.6 (10J567)
Report Version: 6
Call graph:
2411 Thread_1676663 DispatchQueue_1: com.apple.main-thread (serial)
2411 start
2411 NSApplicationMain
2411 -[NSApplication run]
2411 -[NSApplication
nextEventMatchingMask:untilDate:inMode:dequeue:]
2411 _DPSNextEvent
2411 BlockUntilNextEventMatchingListInMode
2411 ReceiveNextEventCommon
2411 RunCurrentEventLoopInMode
2411 CFRunLoopRunInMode
2411 CFRunLoopRunSpecific
2411 __CFRunLoopRun
2411 mach_msg
2411 mach_msg_trap
2411 Thread_1676666 DispatchQueue_2:
com.apple.libdispatch-manager (serial)
2411 start_wqthread
2411 _pthread_wqthread
2411 _dispatch_worker_thread2
2411 _dispatch_queue_invoke
2411 _dispatch_mgr_invoke
2411 kevent
2411 Thread_1676670
2411 thread_start
2411 _pthread_start
2411 __NSThread__main__
2411 -[NSThread main]
2411 -[NetworkConnection runNetworkThread]
2411 CFRunLoopRun
2411 CFRunLoopRunSpecific
2411 __CFRunLoopRun
2411 mach_msg
2411 mach_msg_trap
2411 Thread_1676671: com.apple.CFSocket.private
2411 thread_start
2411 _pthread_start
2411 __CFSocketManager
2411 select$DARWIN_EXTSN
2411 Thread_1677665
2411 start_wqthread
2411 _pthread_wqthread
2411 __workq_kernreturn
Total number in stack (recursive counted multiple, when >=5):
Sort by top of stack, same collapsed (when >= 5):
mach_msg_trap 4822
__workq_kernreturn 2411
kevent 2411
select$DARWIN_EXTSN 2411
Binary Images:
0x1000 - 0x10ffb +org.bluestatic.macgdbp 1.4 (85)
<4381E03F-895D-DA10-7748-88174BDD8EB2> /Users/ardell/Downloads/MacGDBp
1.4.app/Contents/MacOS/MacGDBp
0x1b000 - 0x2efff +org.andymatuschak.Sparkle 1.5 Beta 6 (313)
<5DF2B8A3-560D-4500-6B85-4215644DE532> /Users/ardell/Downloads/MacGDBp
1.4.app/Contents/Frameworks/Sparkle.framework/Versions/A/Sparkle
0x3c000 - 0xf1fe7 libcrypto.0.9.7.dylib 0.9.7 (compatibility
0.9.7) <AACC86C0-86B4-B1A7-003F-2A0AF68973A2>
/usr/lib/libcrypto.0.9.7.dylib
0x8fe00000 - 0x8fe4162b dyld 132.1 (???)
<749D24EE-54BD-D74B-D305-C13F5E6C95D8> /usr/lib/dyld
0x9008b000 - 0x901b9fe7 com.apple.CoreData 102.1 (251)
<87FE6861-F2D6-773D-ED45-345272E56463>
/System/Library/Frameworks/CoreData.framework/Versions/A/CoreData
0x901ba000 - 0x901baff7 com.apple.Accelerate.vecLib 3.6 (vecLib 3.6)
<ABF97DA4-3BDF-6FFD-6239-B023CA1F7974>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/vecLib
0x901bb000 - 0x901c1fff com.apple.CommonPanels 1.2.4 (91)
<2438AF5D-067B-B9FD-1248-2C9987F360BA>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/CommonPanels.framework/Versions/A/CommonPanels
0x901c2000 - 0x901e2fe7 libresolv.9.dylib 41.0.0 (compatibility
1.0.0) <BF7FF2F6-5FD3-D78F-77BC-9E2CB2A5E309>
/usr/lib/libresolv.9.dylib
0x90266000 - 0x90276ff7 libsasl2.2.dylib 3.15.0 (compatibility 3.0.0)
<C8744EA3-0AB7-CD03-E639-C4F2B910BE5D> /usr/lib/libsasl2.2.dylib
0x90301000 - 0x90305ff7 libGIF.dylib ??? (???)
<FA466D54-68CF-D1AB-47A0-4134C8B1B6FD>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libGIF.dylib
0x90314000 - 0x90347ff7 com.apple.AE 496.4 (496.4)
<C73D124C-C722-41D8-3465-4CE0D0BA9307>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/AE.framework/Versions/A/AE
0x9037b000 - 0x903beff7 libGLU.dylib ??? (???)
<BB66EDB2-D5FE-61C9-21BE-747F9862819C>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGLU.dylib
0x903bf000 - 0x90489fef com.apple.CoreServices.OSServices 357 (357)
<F66F783A-9B51-953F-CAC9-509E1F550B4B>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/OSServices.framework/Versions/A/OSServices
0x9048a000 - 0x904a5ff7 libPng.dylib ??? (???)
<DF9BC42C-13E0-3080-A106-75121FD577CF>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libPng.dylib
0x904a6000 - 0x90515ff7 libvMisc.dylib 268.0.1 (compatibility 1.0.0)
<595A5539-9F54-63E6-7AAC-C04E1574B050>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvMisc.dylib
0x90516000 - 0x90518ff7 com.apple.securityhi 4.0 (36638)
<C7DA80C1-DCFD-C321-08DA-5E6946CA66E0>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/SecurityHI.framework/Versions/A/SecurityHI
0x90721000 - 0x90765fe7 com.apple.Metadata 10.6.3 (507.15)
<A23633F1-E913-66C2-A073-E2B174C09B18>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/Metadata.framework/Versions/A/Metadata
0x907d5000 - 0x90af9fef com.apple.HIToolbox 1.6.4 (???)
<4699C8BB-DE74-C530-564B-D131F74C9B54>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/HIToolbox.framework/Versions/A/HIToolbox
0x90c8d000 - 0x90e46feb com.apple.ImageIO.framework 3.0.4 (3.0.4)
<6D8C6C54-9F39-0D0F-564D-2ABA12E97BBC>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/ImageIO
0x90e47000 - 0x90eabffb com.apple.htmlrendering 72 (1.1.4)
<4D451A35-FAB6-1288-71F6-F24A4B6E2371>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/HTMLRendering.framework/Versions/A/HTMLRendering
0x90f03000 - 0x90f9eff7 com.apple.ApplicationServices.ATS 4.4 (???)
<ECB16606-4DF8-4AFB-C91D-F7947C26040F>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ATS.framework/Versions/A/ATS
0x91102000 - 0x9115fff7 com.apple.framework.IOKit 2.0 (???)
<A769737F-E0D6-FB06-29B4-915CF4F43420>
/System/Library/Frameworks/IOKit.framework/Versions/A/IOKit
0x9127a000 - 0x91660ffb com.apple.RawCamera.bundle 3.4.1 (546)
<D966727B-B687-3029-067F-87FC6CCEBB55>
/System/Library/CoreServices/RawCamera.bundle/Contents/MacOS/RawCamera
0x91661000 - 0x917e3fe7 libicucore.A.dylib 40.0.0 (compatibility
1.0.0) <35DB7644-0780-D2AB-F6A9-45F28D2D434A>
/usr/lib/libicucore.A.dylib
0x91899000 - 0x918bfffb com.apple.DictionaryServices 1.1.2 (1.1.2)
<43E1D565-6E01-3681-F2E5-72AE4C3A097A>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/DictionaryServices.framework/Versions/A/DictionaryServices
0x918f0000 - 0x91951fe7 com.apple.CoreText 3.5.0 (???)
<BB50C045-25F5-65B8-B1DB-8CDAEF45EB46>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreText.framework/Versions/A/CoreText
0x9195a000 - 0x9199eff3 com.apple.coreui 2 (114)
<2234855E-3BED-717F-0BFA-D1A289ECDBDA>
/System/Library/PrivateFrameworks/CoreUI.framework/Versions/A/CoreUI
0x9199f000 - 0x91cbfff3 com.apple.CoreServices.CarbonCore 861.23
(861.23) <96534EF7-C22E-0C01-C56F-FF7047E41224>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/CarbonCore.framework/Versions/A/CarbonCore
0x91cc0000 - 0x91d6afe7 com.apple.CFNetwork 454.11.5 (454.11.5)
<DD575760-7A29-111D-5A69-EAFD3410F74D>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/CFNetwork.framework/Versions/A/CFNetwork
0x91d6b000 - 0x91e48ff7 com.apple.vImage 4.0 (4.0)
<64597E4B-F144-DBB3-F428-0EC3D9A1219E>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vImage.framework/Versions/A/vImage
0x91e71000 - 0x91ea2ff7 libGLImage.dylib ??? (???)
<E3EC8E92-4DDD-E7B8-3D38-C5A5160A4930>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGLImage.dylib
0x91ea3000 - 0x91eb4ff7 com.apple.LangAnalysis 1.6.6 (1.6.6)
<3036AD83-4F1D-1028-54EE-54165E562650>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/LangAnalysis.framework/Versions/A/LangAnalysis
0x91ee1000 - 0x91ee4ff7 libCoreVMClient.dylib ??? (???)
<973B9E1F-70B3-2E76-B14B-E57F306AD2DF>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libCoreVMClient.dylib
0x91ee5000 - 0x91f27ff7 libvDSP.dylib 268.0.1 (compatibility 1.0.0)
<8A4721DE-25C4-C8AA-EA90-9DA7812E3EBA>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvDSP.dylib
0x92105000 - 0x92111ff7 libkxld.dylib ??? (???)
<9D8378E0-1C58-EED8-EA00-F4515B8BE7A3> /usr/lib/system/libkxld.dylib
0x92112000 - 0x92134fef com.apple.DirectoryService.Framework 3.6
(621.9) <3171B16F-E4E1-89AA-B846-D698E3D6D457>
/System/Library/Frameworks/DirectoryService.framework/Versions/A/DirectoryService
0x92135000 - 0x92156fe7 com.apple.opencl 12.3 (12.3)
<DEA600BF-4F54-66B5-DB2F-DC57FD518543>
/System/Library/Frameworks/OpenCL.framework/Versions/A/OpenCL
0x92157000 - 0x921a7ff7 com.apple.framework.familycontrols 2.0.2
(2020) <AF7F86F1-F7BF-CBA8-7A4A-D8F7A19F9601>
/System/Library/PrivateFrameworks/FamilyControls.framework/Versions/A/FamilyControls
0x921a8000 - 0x9234fff7 libSystem.B.dylib 125.2.1 (compatibility
1.0.0) <4FFBF71A-D603-3C64-2BC6-BFBFFFD562F0>
/usr/lib/libSystem.B.dylib
0x92350000 - 0x923d2ffb SecurityFoundation ??? (???)
<2E1F1AF0-A258-D215-2600-5DF03896D1F1>
/System/Library/Frameworks/SecurityFoundation.framework/Versions/A/SecurityFoundation
0x923d3000 - 0x9246bfe7 edu.mit.Kerberos 6.5.10 (6.5.10)
<DC19F49B-184E-FD0F-13F8-3A31924A3B66>
/System/Library/Frameworks/Kerberos.framework/Versions/A/Kerberos
0x925ad000 - 0x929e2ff7 libLAPACK.dylib 219.0.0 (compatibility 1.0.0)
<5E2D2283-57DE-9A49-1DB0-CD027FEFA6C2>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libLAPACK.dylib
0x929e3000 - 0x929e7ff7 libGFXShared.dylib ??? (???)
<9E14BE2F-C863-40E9-41A6-1BE9045663A0>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGFXShared.dylib
0x92a17000 - 0x92a1bff7 IOSurface ??? (???)
<235E7E3D-B6E5-0AAA-C41A-7AC1F54A7EBF>
/System/Library/Frameworks/IOSurface.framework/Versions/A/IOSurface
0x92a1c000 - 0x92a52fff libtidy.A.dylib ??? (???)
<0FD72C68-4803-4C5B-3A63-05D7394BFD71> /usr/lib/libtidy.A.dylib
0x92cb0000 - 0x92d4dfe3 com.apple.LaunchServices 362.2 (362.2)
<F3952CAB-322F-A12F-57AF-8B91B1D76DDE>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/LaunchServices.framework/Versions/A/LaunchServices
0x92e1d000 - 0x92e1eff7 com.apple.TrustEvaluationAgent 1.1 (1)
<2D970A9B-77E8-EDC0-BEC6-7580D78B2843>
/System/Library/PrivateFrameworks/TrustEvaluationAgent.framework/Versions/A/TrustEvaluationAgent
0x92e1f000 - 0x92e3eff7 com.apple.CoreVideo 1.6.2 (45.6)
<EB53CAA4-5EE2-C356-A954-5775F7DDD493>
/System/Library/Frameworks/CoreVideo.framework/Versions/A/CoreVideo
0x92eae000 - 0x92ed6ff7 libxslt.1.dylib 3.24.0 (compatibility 3.0.0)
<769EF4B2-C1AD-73D5-AAAD-1564DAEA77AF> /usr/lib/libxslt.1.dylib
0x92f59000 - 0x9305dfe7 libcrypto.0.9.8.dylib 0.9.8 (compatibility
0.9.8) <BDEFA030-5E75-7C47-2904-85AB16937F45>
/usr/lib/libcrypto.0.9.8.dylib
0x9305e000 - 0x930a1ff7 com.apple.NavigationServices 3.5.4 (182)
<8DC6FD4A-6C74-9C23-A4C3-715B44A8D28C>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/NavigationServices.framework/Versions/A/NavigationServices
0x930a2000 - 0x93299feb com.apple.JavaScriptCore 6533.18 (6533.18.1)
<F740BA2B-EFCF-98E2-FFC2-361BD7D41330>
/System/Library/Frameworks/JavaScriptCore.framework/Versions/A/JavaScriptCore
0x9329a000 - 0x932e7feb
com.apple.DirectoryService.PasswordServerFramework 6.0 (6.0)
<BF66BA5D-BBC8-78A5-DBE2-F9DE3DD1D775>
/System/Library/PrivateFrameworks/PasswordServer.framework/Versions/A/PasswordServer
0x9333f000 - 0x93363ff7 libJPEG.dylib ??? (???)
<E064CF03-8CC2-C83E-C951-D46610834D1C>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libJPEG.dylib
0x93369000 - 0x93422fe7 libsqlite3.dylib 9.6.0 (compatibility 9.0.0)
<52438E77-55D1-C231-1936-76F1369518E4> /usr/lib/libsqlite3.dylib
0x93423000 - 0x93c12557 com.apple.CoreGraphics 1.545.0 (???)
<1AB39678-00D5-FB88-3B41-93D78348E0DE>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/CoreGraphics
0x93c31000 - 0x93cc3fe7 com.apple.print.framework.PrintCore 6.3
(312.7) <7410D1B2-655D-68DA-D4B9-2C65747B6817>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/PrintCore.framework/Versions/A/PrintCore
0x93cc4000 - 0x93cdcff7 com.apple.CFOpenDirectory 10.6 (10.6)
<F9AFC571-3539-6B46-ABF9-46DA2B608819>
/System/Library/Frameworks/OpenDirectory.framework/Versions/A/Frameworks/CFOpenDirectory.framework/Versions/A/CFOpenDirectory
0x93cdd000 - 0x93cddff7 com.apple.ApplicationServices 38 (38)
<8012B504-3D83-BFBB-DA65-065E061CFE03>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/ApplicationServices
0x93cdf000 - 0x93e0efe3 com.apple.audio.toolbox.AudioToolbox 1.6.5
(1.6.5) <0A0F68E5-4806-DB51-764B-D97554B801AD>
/System/Library/Frameworks/AudioToolbox.framework/Versions/A/AudioToolbox
0x94109000 - 0x94109ff7 com.apple.Carbon 150 (152)
<734BDB59-8B13-54FA-0653-AA8623DF9846>
/System/Library/Frameworks/Carbon.framework/Versions/A/Carbon
0x941c5000 - 0x9423ffff com.apple.audio.CoreAudio 3.2.6 (3.2.6)
<A02CEAE9-943A-CBE2-2350-4631C1E7B0A7>
/System/Library/Frameworks/CoreAudio.framework/Versions/A/CoreAudio
0x9475f000 - 0x9486bff7 libGLProgrammability.dylib ??? (???)
<A077BFEA-19C6-9F48-2F36-8E4E55376F49>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGLProgrammability.dylib
0x9486c000 - 0x94876fe7 com.apple.audio.SoundManager 3.9.3 (3.9.3)
<5F494955-7290-2D91-DA94-44B590191771>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/CarbonSound.framework/Versions/A/CarbonSound
0x9487f000 - 0x948a9ff7 com.apple.shortcut 1.1 (1.1)
<B0514FA9-7CAE-AD94-93CA-7B2A2C5F7B8A>
/System/Library/PrivateFrameworks/Shortcut.framework/Versions/A/Shortcut
0x948aa000 - 0x948dcfe3 libTrueTypeScaler.dylib ??? (???)
<6E9D1A50-330E-F1F4-F93D-9ECC8A61B21A>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ATS.framework/Versions/A/Resources/libTrueTypeScaler.dylib
0x948dd000 - 0x9495dfeb com.apple.SearchKit 1.3.0 (1.3.0)
<9E18AEA5-F4B4-8BE5-EEA9-818FC4F46FD9>
/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/SearchKit.framework/Versions/A/SearchKit
0x9495e000 - 0x94968ffb com.apple.speech.recognition.framework 3.11.1
(3.11.1) <7486003F-8FDB-BD6C-CB34-DE45315BD82C>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/SpeechRecognition.framework/Versions/A/SpeechRecognition
0x94969000 - 0x94970ff3 com.apple.print.framework.Print 6.1 (237.1)
<F5AAE53D-5530-9004-A9E3-2C1690C5328E>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/Print.framework/Versions/A/Print
0x94971000 - 0x9497cff7 libCSync.A.dylib 545.0.0 (compatibility
64.0.0) <CB2510BD-A5B3-9D90-5917-C73F6ECAC913>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/Resources/libCSync.A.dylib
0x94c0d000 - 0x94c48feb libFontRegistry.dylib ??? (???)
<4FB144ED-8AF9-27CF-B315-DCE5575D5231>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ATS.framework/Versions/A/Resources/libFontRegistry.dylib
0x94c49000 - 0x94c82ff7 libcups.2.dylib 2.8.0 (compatibility 2.0.0)
<E0D512DD-365D-46A0-F50C-435BC250424F> /usr/lib/libcups.2.dylib
0x94d62000 - 0x950cdff7 com.apple.QuartzCore 1.6.3 (227.34)
<0B59EAF1-4892-C5CE-4A67-66EBD383359E>
/System/Library/Frameworks/QuartzCore.framework/Versions/A/QuartzCore
0x9511c000 - 0x9511cff7 com.apple.Cocoa 6.6 (???)
<EA27B428-5904-B00B-397A-185588698BCC>
/System/Library/Frameworks/Cocoa.framework/Versions/A/Cocoa
0x95176000 - 0x95184ff7 com.apple.opengl 1.6.12 (1.6.12)
<9F13B279-F289-18AC-5D86-DCD52BAF087D>
/System/Library/Frameworks/OpenGL.framework/Versions/A/OpenGL
0x9527c000 - 0x9527cff7 com.apple.Accelerate 1.6 (Accelerate 1.6)
<3891A689-4F38-FACD-38B2-4BF937DE30CF>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Accelerate
0x9527d000 - 0x9532dff3 com.apple.ColorSync 4.6.3 (4.6.3)
<0354B408-665F-8B3F-87FF-64E6322276F0>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ColorSync.framework/Versions/A/ColorSync
0x9532e000 - 0x9532eff7 com.apple.CoreServices 44 (44)
<51CFA89A-33DB-90ED-26A8-67D461718A4A>
/System/Library/Frameworks/CoreServices.framework/Versions/A/CoreServices
0x9532f000 - 0x95378fe7 libTIFF.dylib ??? (???)
<72AC8D6B-F187-1462-901F-999E68C24848>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libTIFF.dylib
0x9584f000 - 0x9629aff7 com.apple.WebCore 6533.18 (6533.18.1)
<55C5330D-DB7D-56B3-E31A-5FF98BD9A3A8>
/System/Library/Frameworks/WebKit.framework/Versions/A/Frameworks/WebCore.framework/Versions/A/WebCore
0x9629b000 - 0x96416fe7 com.apple.CoreFoundation 6.6.4 (550.42)
<C78D5079-663E-9734-7AFA-6CE79A0539F1>
/System/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation
0x96460000 - 0x96466fe7 com.apple.CommerceCore 1.0 (6)
<41C2A87D-93D8-56C1-9292-0400699F23C1>
/System/Library/PrivateFrameworks/CommerceKit.framework/Versions/A/Frameworks/CommerceCore.framework/Versions/A/CommerceCore
0x964ac000 - 0x96d8cff7 com.apple.AppKit 6.6.7 (1038.35)
<ABC7783C-E4D5-B848-BED6-99451D94D120>
/System/Library/Frameworks/AppKit.framework/Versions/C/AppKit
0x96d8d000 - 0x96d8dff7 liblangid.dylib ??? (???)
<B99607FC-5646-32C8-2C16-AFB5EA9097C2> /usr/lib/liblangid.dylib
0x96e38000 - 0x96f13feb com.apple.DesktopServices 1.5.9 (1.5.9)
<CED00AC1-924B-0E45-7D5E-1CEA8929F5BE>
/System/Library/PrivateFrameworks/DesktopServicesPriv.framework/Versions/A/DesktopServicesPriv
0x96f14000 - 0x9732aff7 libBLAS.dylib 219.0.0 (compatibility 1.0.0)
<C4FB303A-DB4D-F9E8-181C-129585E59603>
/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libBLAS.dylib
0x9736c000 - 0x9736eff7 libRadiance.dylib ??? (???)
<68BF4654-B74A-C843-759F-7FC62385F251>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ImageIO.framework/Versions/A/Resources/libRadiance.dylib
0x9736f000 - 0x97375ff7 libCGXCoreImage.A.dylib 545.0.0
(compatibility 64.0.0) <DACD11D8-4B64-CD3B-C988-B1041E07D13A>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/Resources/libCGXCoreImage.A.dylib
0x97378000 - 0x97378ff7 com.apple.vecLib 3.6 (vecLib 3.6)
<FF4DC8B6-0AB0-DEE8-ADA8-7B57645A1F36>
/System/Library/Frameworks/vecLib.framework/Versions/A/vecLib
0x97615000 - 0x976c2fe7 libobjc.A.dylib 227.0.0 (compatibility 1.0.0)
<C8925910-B927-968B-4B71-D83A4CEF8646> /usr/lib/libobjc.A.dylib
0x976d4000 - 0x976dfff7 libGL.dylib ??? (???)
<48405993-0AE9-292B-6705-C3525528682A>
/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGL.dylib
0x97708000 - 0x97724fe3 com.apple.openscripting 1.3.1 (???)
<2A748037-D1C0-6D47-2C4A-0562AF799AC9>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/OpenScripting.framework/Versions/A/OpenScripting
0x97725000 - 0x97728ff7 libCGXType.A.dylib 545.0.0 (compatibility
64.0.0) <B624AACE-991B-0FFA-2482-E69970576CE1>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/Resources/libCGXType.A.dylib
0x97729000 - 0x9776aff7 libRIP.A.dylib 545.0.0 (compatibility 64.0.0)
<16DAE1A5-937A-1CA2-D98F-2AF958B62993>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/CoreGraphics.framework/Versions/A/Resources/libRIP.A.dylib
0x9776b000 - 0x97813ffb com.apple.QD 3.36 (???)
<FA2785A4-BB69-DCB4-3BA3-7C89A82CAB41>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/QD.framework/Versions/A/QD
0x97814000 - 0x97817ffb com.apple.help 1.3.1 (41)
<67F1F424-3983-7A2A-EC21-867BE838E90B>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/Help.framework/Versions/A/Help
0x97b36000 - 0x97becff7 libFontParser.dylib ??? (???)
<33F62EE1-E457-C6FD-369E-E86745B94A4B>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ATS.framework/Versions/A/Resources/libFontParser.dylib
0x97c39000 - 0x97c4efff com.apple.ImageCapture 6.0.1 (6.0.1)
<E7ED2AC1-834C-A44E-531E-EC05F0496DBF>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/ImageCapture.framework/Versions/A/ImageCapture
0x97c4f000 - 0x97c52fe7 libmathCommon.A.dylib 315.0.0 (compatibility
1.0.0) <1622A54F-1A98-2CBE-B6A4-2122981A500E>
/usr/lib/system/libmathCommon.A.dylib
0x97d01000 - 0x97d0eff7 com.apple.NetFS 3.2.1 (3.2.1)
<94A52A6D-F071-09D7-E80F-F633F17233FE>
/System/Library/Frameworks/NetFS.framework/Versions/A/NetFS
0x97d8c000 - 0x97feffff com.apple.security 6.1.1 (37594)
<B6F2A8BF-C1B7-A0E2-83FB-4FF265E9BDDC>
/System/Library/Frameworks/Security.framework/Versions/A/Security
0x980c2000 - 0x98113ff7 com.apple.HIServices 1.8.2 (???)
<F6EAC2D1-902A-9374-FC4B-43B50E054416>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/HIServices.framework/Versions/A/HIServices
0x98140000 - 0x98141ff7 com.apple.audio.units.AudioUnit 1.6.5 (1.6.5)
<BE4C2495-B758-AD22-DCC0-56A6791E948E>
/System/Library/Frameworks/AudioUnit.framework/Versions/A/AudioUnit
0x98142000 - 0x9814bff7 com.apple.DiskArbitration 2.3 (2.3)
<E9C40767-DA6A-6CCB-8B00-2D5706753000>
/System/Library/Frameworks/DiskArbitration.framework/Versions/A/DiskArbitration
0x98181000 - 0x98282fe7 libxml2.2.dylib 10.3.0 (compatibility 10.0.0)
<ED8E45C6-B078-15E8-938D-99D8FD1EAE64> /usr/lib/libxml2.2.dylib
0x982cb000 - 0x98379ff3 com.apple.ink.framework 1.3.3 (107)
<233A981E-A2F9-56FB-8BDE-C2DEC3F20784>
/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/Ink.framework/Versions/A/Ink
0x9837a000 - 0x9837fff7 com.apple.OpenDirectory 10.6 (10.6)
<C1B46982-7D3B-3CC4-3BC2-3E4B595F0231>
/System/Library/Frameworks/OpenDirectory.framework/Versions/A/OpenDirectory
0x98380000 - 0x983c6ff7 libauto.dylib ??? (???)
<29422A70-87CF-10E2-CE59-FEE1234CFAAE> /usr/lib/libauto.dylib
0x99350000 - 0x995c3fe7 com.apple.Foundation 6.6.4 (751.42)
<65F16BF4-D106-F2F5-53F3-5BFBC2FCE608>
/System/Library/Frameworks/Foundation.framework/Versions/C/Foundation
0x99604000 - 0x99618fe7 libbsm.0.dylib ??? (???)
<14CB053A-7C47-96DA-E415-0906BA1B78C9> /usr/lib/libbsm.0.dylib
0x99629000 - 0x99738fe7 com.apple.WebKit 6533.18 (6533.18.1)
<C7FF7199-91FF-7F6F-C5D9-487A86D65E07>
/System/Library/Frameworks/WebKit.framework/Versions/A/WebKit
0x99739000 - 0x99776ff7 com.apple.SystemConfiguration 1.10.5 (1.10.2)
<362DF639-6E5F-9371-9B99-81C581A8EE41>
/System/Library/Frameworks/SystemConfiguration.framework/Versions/A/SystemConfiguration
0x9987a000 - 0x998e4fe7 libstdc++.6.dylib 7.9.0 (compatibility 7.0.0)
<411D87F4-B7E1-44EB-F201-F8B4F9227213> /usr/lib/libstdc++.6.dylib
0x9991d000 - 0x9992bfe7 libz.1.dylib 1.2.3 (compatibility 1.0.0)
<33C1B260-ED05-945D-FC33-EF56EC791E2E> /usr/lib/libz.1.dylib
0x9992c000 - 0x9993eff7 com.apple.MultitouchSupport.framework 207.10
(207.10) <32CE2895-DAF0-2137-F9BE-8150359F43A1>
/System/Library/PrivateFrameworks/MultitouchSupport.framework/Versions/A/MultitouchSupport
0x9993f000 - 0x99949ff7 com.apple.HelpData 2.0.4 (34)
<001A7163-C977-C30F-1B4B-4F5647F72E96>
/System/Library/PrivateFrameworks/HelpData.framework/Versions/A/HelpData
0x9994a000 - 0x9995effb com.apple.speech.synthesis.framework 3.10.35
(3.10.35) <57DD5458-4F24-DA7D-0927-C3321A65D743>
/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/SpeechSynthesis.framework/Versions/A/SpeechSynthesis
0xffff0000 - 0xffff1fff libSystem.B.dylib ??? (???)
<4FFBF71A-D603-3C64-2BC6-BFBFFFD562F0> /usr/lib/libSystem.B.dylib
Sample analysis of process 29028 written to file /dev/stdout
March 18, 2011 03:33 PM
Alan Pinstein
Your bugtracker flatten the stack trace formatting.... this should help.
On March 18, 2011 03:34 PM, Alan Pinstein changed:
- Attachment #2110 Description from "sample stack trace" to "sample process: stack trace"
April 5, 2011 08:12 AM
Thibaut Allender
Same bug here, MacOS 10.5.8
January 15, 2015 03:39 AM
outis
Still present in 1.5. It also happens when pausing on a breakpoint, not just during stepping. The "Continue" and "Evaluate" commands also stop working (I'm guessing any command that causes MacGDBp to send a message to XDebug stops working). "Stop" works, but a "Could not open socket" message appears in MacGDBp's status bar and further sessions won't start in MacGDBp (until it's quit & reopened), and hang on the XDebug side of things.
My stack traces are basically the same as Alan's (though with a few more threads).
Wireshark reveals the packet that XDebug sends in response to `context_names`. Here it is (MacGDBp's commands prefixed with "?", responses with "!")
? source -f file:///... -i 94
! 43302\0<?xml ...
? context_names -d 0 -i 95
! 273\0<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1" xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="context_names" transaction_id="95"><context name="Locals" id="0"></context><context name="Superglobals" id="1"></context></response>\0
At this point, MacGDBp logs the following:
Transaction #0 is out of date (lastRead = 94). Dropping packet: 273
That seems to show what's happening, though not why.
My stack traces are basically the same as Alan's (though with a few more threads).
Wireshark reveals the packet that XDebug sends in response to `context_names`. Here it is (MacGDBp's commands prefixed with "?", responses with "!")
? source -f file:///... -i 94
! 43302\0<?xml ...
? context_names -d 0 -i 95
! 273\0<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1" xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="context_names" transaction_id="95"><context name="Locals" id="0"></context><context name="Superglobals" id="1"></context></response>\0
At this point, MacGDBp logs the following:
Transaction #0 is out of date (lastRead = 94). Dropping packet: 273
That seems to show what's happening, though not why.
January 15, 2015 03:40 AM
outis
Still present in 1.5. It also happens when pausing on a breakpoint, not just during stepping. The "Continue" and "Evaluate" commands also stop working (I'm guessing any command that causes MacGDBp to send a message to XDebug stops working). "Stop" works, but a "Could not open socket" message appears in MacGDBp's status bar and further sessions won't start in MacGDBp (until it's quit & reopened), and hang on the XDebug side of things.
My stack traces are basically the same as Alan's (though with a few more threads).
Wireshark reveals the packet that XDebug sends in response to `context_names`. Here it is (MacGDBp's commands prefixed with "?", responses with "!")
? source -f file:///... -i 94
! 43302\0<?xml ...
? context_names -d 0 -i 95
! 273\0<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1" xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="context_names" transaction_id="95"><context name="Locals" id="0"></context><context name="Superglobals" id="1"></context></response>\0
At this point, MacGDBp logs the following:
Transaction #0 is out of date (lastRead = 94). Dropping packet: 273
That seems to show what's happening, though not why.
My stack traces are basically the same as Alan's (though with a few more threads).
Wireshark reveals the packet that XDebug sends in response to `context_names`. Here it is (MacGDBp's commands prefixed with "?", responses with "!")
? source -f file:///... -i 94
! 43302\0<?xml ...
? context_names -d 0 -i 95
! 273\0<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1" xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="context_names" transaction_id="95"><context name="Locals" id="0"></context><context name="Superglobals" id="1"></context></response>\0
At this point, MacGDBp logs the following:
Transaction #0 is out of date (lastRead = 94). Dropping packet: 273
That seems to show what's happening, though not why.
January 15, 2015 03:40 AM
outis
Still present in 1.5. It also happens when pausing on a breakpoint, not just during stepping. The "Continue" and "Evaluate" commands also stop working (I'm guessing any command that causes MacGDBp to send a message to XDebug stops working). "Stop" works, but a "Could not open socket" message appears in MacGDBp's status bar and further sessions won't start in MacGDBp (until it's quit & reopened), and hang on the XDebug side of things.
My stack traces are basically the same as Alan's (though with a few more threads).
Wireshark reveals the packet that XDebug sends in response to `context_names`. Here it is (MacGDBp's commands prefixed with "?", responses with "!")
? source -f file:///... -i 94
! 43302\0<?xml version="1.0" encoding="iso-8859-1"?>...
? context_names -d 0 -i 95
! 273\0<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1" xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="context_names" transaction_id="95"><context name="Locals" id="0"></context><context name="Superglobals" id="1"></context></response>\0
At this point, MacGDBp logs the following:
Transaction #0 is out of date (lastRead = 94). Dropping packet: 273
That seems to show what's happening, though not why.
My stack traces are basically the same as Alan's (though with a few more threads).
Wireshark reveals the packet that XDebug sends in response to `context_names`. Here it is (MacGDBp's commands prefixed with "?", responses with "!")
? source -f file:///... -i 94
! 43302\0<?xml version="1.0" encoding="iso-8859-1"?>...
? context_names -d 0 -i 95
! 273\0<?xml version="1.0" encoding="iso-8859-1"?>
<response xmlns="urn:debugger_protocol_v1" xmlns:xdebug="http://xdebug.org/dbgp/xdebug" command="context_names" transaction_id="95"><context name="Locals" id="0"></context><context name="Superglobals" id="1"></context></response>\0
At this point, MacGDBp logs the following:
Transaction #0 is out of date (lastRead = 94). Dropping packet: 273
That seems to show what's happening, though not why.
January 15, 2015 03:42 AM
outis
Ack! The bug tracker has a bug! Posting a reply returns numerous PHP warnings & errors, with no notice that the post was successful (hence my duplicate posts).
December 14, 2018 11:20 PM
outis
Note the packet content in the logged message is the packet length, rather than the XML. It seems that an earlier read from the network returns an empty string when there isn't a current packet. When this happens, `readStreamHasData:` still reads the packet size from the empty string and create a new packet. It advances `bufferOffset`, which then exceeds `bytesRead`, and `readStreamHasData:` exits without handling the (empty) packet. The next time data comes in, there's a current packet so the chunk (which is actually the length of the next packet) gets appended.
Simply skipping chunks of length 1 should resolve (though they may signal some other issue, and addressing them directly may be the better course).
Simply skipping chunks of length 1 should resolve (though they may signal some other issue, and addressing them directly may be the better course).
December 14, 2018 11:28 PM
outis
Skips empty chunks when reading from network stream.