ILIAS  eassessment Revision 61809
 All Data Structures Namespaces Files Functions Variables Groups Pages
ilObjectXMLParser Class Reference

Object XML Parser. More...

+ Inheritance diagram for ilObjectXMLParser:
+ Collaboration diagram for ilObjectXMLParser:

Public Member Functions

 ilObjectXMLParser ($a_xml_data= '', $throwException=false)
 Constructor.
 getObjectData ()
 parse ($a_xml_parser, $a_fp=null)
 parse xml file
 setHandlers ($a_xml_parser)
 set event handlers
 handlerBeginTag ($a_xml_parser, $a_name, $a_attribs)
 handler for begin of element
 handlerEndTag ($a_xml_parser, $a_name)
 handler for end of element
 handlerCharacterData ($a_xml_parser, $a_data)
 handler for character data
 __addProperty ($a_name, $a_value)
 __addReference ($a_ref_id, $a_parent_id, $a_time_target)
- Public Member Functions inherited from ilSaxParser
 ilSaxParser ($a_xml_file= '', $throwException=false)
 Constructor setup ILIAS global object public.
 setXMLContent ($a_xml_content)
 getXMLContent ()
 getInputType ()
 startParsing ()
 stores xml data in array
 createParser ()
 create parser
 setOptions ($a_xml_parser)
 set parser options
 openXMLFile ()
 open xml file
 freeParser ($a_xml_parser)
 free xml parser handle
 setThrowException ($throwException)
 set error handling
- Public Member Functions inherited from PEAR
 PEAR ($error_class=null)
 Constructor.
 _PEAR ()
 Destructor (the emulated type of...).
getStaticProperty ($class, $var)
 If you have a class that's mostly/entirely static, and you need static properties, you can use this method to simulate them.
 registerShutdownFunc ($func, $args=array())
 Use this function to register a shutdown method for static classes.
 isError ($data, $code=null)
 Tell whether a value is a PEAR error.
 setErrorHandling ($mode=null, $options=null)
 Sets how errors generated by this object should be handled.
 expectError ($code= '*')
 This method is used to tell which errors you expect to get.
 popExpect ()
 This method pops one element off the expected error codes stack.
 _checkDelExpect ($error_code)
 This method checks unsets an error code if available.
 delExpect ($error_code)
 This method deletes all occurences of the specified element from the expected error codes stack.
raiseError ($message=null, $code=null, $mode=null, $options=null, $userinfo=null, $error_class=null, $skipmsg=false)
 This method is a wrapper that returns an instance of the configured error class with this object's default error handling applied.
throwError ($message=null, $code=null, $userinfo=null)
 Simpler form of raiseError with fewer options.
 staticPushErrorHandling ($mode, $options=null)
 staticPopErrorHandling ()
 pushErrorHandling ($mode, $options=null)
 Push a new error handler on top of the error handler options stack.
 popErrorHandling ()
 Pop the last error handler used.
 loadExtension ($ext)
 OS independant PHP extension load.

Data Fields

 $object_data = array()
- Data Fields inherited from ilSaxParser
 $input_type = null
 $xml_content = ''
 $ilias
 $lng
 $xml_file
 $throwException = false
- Data Fields inherited from PEAR
 $_debug = false
 $_default_error_mode = null
 $_default_error_options = null
 $_default_error_handler = ''
 $_error_class = 'PEAR_Error'
 $_expected_errors = array()

Private Attributes

 $ref_id
 $parent_id

Additional Inherited Members

- Protected Member Functions inherited from ilSaxParser
 handleError ($message, $code)
 use given error handler to handle error message or internal ilias error message handle

Detailed Description

Object XML Parser.

Author
Stefan Meyer meyer.nosp@m.@lei.nosp@m.fos.c.nosp@m.om
Version
Id:
class.ilObjectXMLParser.php 25692 2010-09-15 09:44:16Z mwarkus

Definition at line 37 of file class.ilObjectXMLParser.php.

Member Function Documentation

ilObjectXMLParser::__addProperty (   $a_name,
  $a_value 
)

Definition at line 258 of file class.ilObjectXMLParser.php.

Referenced by handlerBeginTag(), and handlerEndTag().

{
$this->object_data[$this->curr_obj][$a_name] = $a_value;
}

+ Here is the caller graph for this function:

ilObjectXMLParser::__addReference (   $a_ref_id,
  $a_parent_id,
  $a_time_target 
)
Exceptions
ilObjectXMLExcpetion

Definition at line 266 of file class.ilObjectXMLParser.php.

Referenced by handlerEndTag().

{
$reference['ref_id'] = $a_ref_id;
$reference['parent_id'] = $a_parent_id;
$reference['time_target'] = $a_time_target;
if(isset($reference['time_target']['changeable']) and $reference['time_target']['changeable'])
{
if(!isset($reference['time_target']['earliest_start']) or !isset($reference['time_target']['latest_end']))
{
throw new ilObjectXMLException('Missing attributes: "earliest_start" and "latest_end" required for attribute "changeable"');
}
if(!isset($reference['time_target']['suggestion_start']) or !isset($reference['time_target']['suggestion_end']))
{
throw new ilObjectXMLException('Missing attributes: "starting_time" and "ending_time" required for attribute "changeable"');
}
if(($reference['time_target']['earliest_start'] < $reference['time_target']['suggestion_start']) or
($reference['time_target']['earliest_start'] > $reference['time_target']['suggestion_end']))
{
throw new ilObjectXMLException('Invalid attributes: "earliest_start" must be within "starting_time" and "ending_time"');
}
if(($reference['time_target']['latest_end'] < $reference['time_target']['suggestion_start']) or
($reference['time_target']['latest_end'] > $reference['time_target']['suggestion_end']))
{
throw new ilObjectXMLException('Invalid attributes: "latest_end" must be within "starting_time" and "ending_time"');
}
}
$this->object_data[$this->curr_obj]['references'][] = $reference;
}

+ Here is the caller graph for this function:

ilObjectXMLParser::getObjectData ( )

Definition at line 59 of file class.ilObjectXMLParser.php.

{
return $this->object_data ? $this->object_data : array();
}
ilObjectXMLParser::handlerBeginTag (   $a_xml_parser,
  $a_name,
  $a_attribs 
)

handler for begin of element

Parameters
resource$a_xml_parserxml parser
string$a_nameelement name
array$a_attribselement attributes array

Definition at line 100 of file class.ilObjectXMLParser.php.

References __addProperty(), and ilUtil\__extractId().

{
switch($a_name)
{
case 'Objects':
$this->curr_obj = -1;
break;
case 'Object':
++$this->curr_obj;
$this->__addProperty('type',$a_attribs['type']);
$this->__addProperty('obj_id',is_numeric($a_attribs['obj_id'])?(int) $a_attribs["obj_id"] : ilUtil::__extractId($a_attribs["obj_id"], IL_INST_ID));
break;
case 'Title':
break;
case 'Description':
break;
case 'Owner':
break;
case 'CreateDate':
break;
case 'LastUpdate':
break;
case 'ImportId':
break;
case 'References':
$this->time_target = array();
$this->ref_id = $a_attribs["ref_id"];
$this->parent_id = $a_attribs['parent_id'];
break;
case 'TimeTarget':
$this->time_target['timing_type'] = $a_attribs['type'];
break;
case 'Timing':
$this->time_target['timing_visibility'] = $a_attribs['visibility'];
if(isset($a_attribs['starting_time']))
{
$this->time_target['starting_time'] = $a_attribs['starting_time'];
}
if(isset($a_attribs['ending_time']))
{
$this->time_target['ending_time'] = $a_attribs['ending_time'];
}
if($a_attribs['ending_time'] < $a_attribs['starting_time'])
throw new ilObjectXMLException('Starting time must be earlier than ending time.');
break;
case 'Suggestion':
$this->time_target['changeable'] = $a_attribs['changeable'];
if(isset($a_attribs['starting_time']))
{
$this->time_target['suggestion_start'] = $a_attribs['starting_time'];
}
if(isset($a_attribs['ending_time']))
{
$this->time_target['suggestion_end'] = $a_attribs['ending_time'];
}
if(isset($a_attribs['earliest_start']))
{
$this->time_target['earliest_start'] = $a_attribs['earliest_start'];
}
if(isset($a_attribs['latest_end']))
{
$this->time_target['latest_end'] = $a_attribs['latest_end'];
}
if($a_attribs['latest_end'] < $a_attribs['earliest_start'])
throw new ilObjectXMLException('Earliest start time must be earlier than latest ending time.');
if($a_attribs['ending_time'] < $a_attribs['starting_time'])
throw new ilObjectXMLException('Starting time must be earlier than ending time.');
break;
}
}

+ Here is the call graph for this function:

ilObjectXMLParser::handlerCharacterData (   $a_xml_parser,
  $a_data 
)

handler for character data

Parameters
resource$a_xml_parserxml parser
string$a_datacharacter data

Definition at line 244 of file class.ilObjectXMLParser.php.

{
if($a_data != "\n")
{
// Replace multiple tabs with one space
$a_data = preg_replace("/\t+/"," ",$a_data);
$this->cdata .= $a_data;
}
}
ilObjectXMLParser::handlerEndTag (   $a_xml_parser,
  $a_name 
)

handler for end of element

Parameters
resource$a_xml_parserxml parser
string$a_nameelement name

Definition at line 194 of file class.ilObjectXMLParser.php.

References __addProperty(), and __addReference().

{
switch($a_name)
{
case 'Objects':
break;
case 'Object':
break;
case 'Title':
$this->__addProperty('title',trim($this->cdata));
break;
case 'Description':
$this->__addProperty('description',trim($this->cdata));
break;
case 'Owner':
$this->__addProperty('owner',trim($this->cdata));
break;
case 'CreateDate':
$this->__addProperty('create_date',trim($this->cdata));
break;
case 'LastUpdate':
$this->__addProperty('last_update',trim($this->cdata));
break;
case 'ImportId':
$this->__addProperty('import_id',trim($this->cdata));
break;
case 'References':
$this->__addReference($this->ref_id,$this->parent_id,$this->time_target);
break;
}
$this->cdata = '';
return;
}

+ Here is the call graph for this function:

ilObjectXMLParser::ilObjectXMLParser (   $a_xml_data = '',
  $throwException = false 
)

Constructor.

Parameters
object$a_content_objectmust be of type ilObjContentObject ilObjTest or ilObjQuestionPool
string$a_xml_filexml data
string$a_subdirsubdirectory in import directory public

Definition at line 53 of file class.ilObjectXMLParser.php.

References ilSaxParser\$throwException, ilSaxParser\ilSaxParser(), and ilSaxParser\setXMLContent().

{
$this->setXMLContent($a_xml_data);
}

+ Here is the call graph for this function:

ilObjectXMLParser::parse (   $a_xml_parser,
  $a_fp = null 
)

parse xml file

private

Exceptions
ilSaxParserException
ilObjectXMLException

Reimplemented from ilSaxParser.

Definition at line 71 of file class.ilObjectXMLParser.php.

{
parent::parse($a_xml_parser,$a_fp);
}
ilObjectXMLParser::setHandlers (   $a_xml_parser)

set event handlers

Parameters
resourcereference to the xml parser private

Reimplemented from ilSaxParser.

Definition at line 83 of file class.ilObjectXMLParser.php.

{
xml_set_object($a_xml_parser,$this);
xml_set_element_handler($a_xml_parser,'handlerBeginTag','handlerEndTag');
xml_set_character_data_handler($a_xml_parser,'handlerCharacterData');
}

Field Documentation

ilObjectXMLParser::$object_data = array()

Definition at line 39 of file class.ilObjectXMLParser.php.

ilObjectXMLParser::$parent_id
private

Definition at line 42 of file class.ilObjectXMLParser.php.

ilObjectXMLParser::$ref_id
private

Definition at line 41 of file class.ilObjectXMLParser.php.


The documentation for this class was generated from the following file: