Location: PHPKode > projects > Entier Studio > entierstudio/studio/classes/procs/interchange/proc.ElementClassWriter.php
<?php
/**
 * Entier Studio
 *
 * LICENSE
 *
 *	Copyright 2006 Entier Studio team.
 *
 *	Licensed under the Apache License, Version 2.0 (the "License");
 *	you may not use this file except in compliance with the License.
 *	You may obtain a copy of the License at
 *
 *		http://www.apache.org/licenses/LICENSE-2.0
 *
 *	Unless required by applicable law or agreed to in writing, software
 *	distributed under the License is distributed on an "AS IS" BASIS,
 *	WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *	See the License for the specific language governing permissions and
 *	limitations under the License.
 *
 * @package    entier.studio
 * @copyright  Copyright (c) 2006 Entier Studio team. All rights reserved.
 * @version	   $Id: proc.ElementClassWriter.php 115 2008-03-07 22:29:12Z yannromefort $
 */
//-----------------------------------------------------------------------------
//	namespace
if (!defined("DefElementClassWriter")) {
    //-------------------------------------------------------------------------
    //	Define
    define("DefElementClassWriter", "1");
    //-------------------------------------------------------------------------
    //	Include
    @require_once (INTERCHANGE_PROC. "proc.ElementWriter.php");
    @require_once (INTERCHANGE_PROC. "proc.ElementOperationWriter.php");
    @require_once (INTERCHANGE_PROC. "proc.ElementReferenceWriter.php");
    //-------------------------------------------------------------------------
    //	Class
    class ElementClassWriter extends ElementWriter {
        //---------------------------------------------------------------------
        //	Constructor        
        /**
         *
         */
        function ElementClassWriter() {
            //            
        }
        //---------------------------------------------------------------------
        //	Methods        
        /**
         * This function renders the xml <references> block of the element(primarykey) class
         *
         * @access	protected
         * @param	object		name="datasource"
         * @param	object		name="template"
         * @param	integer		name="handle"
         * @param	integer		name="primarykey"
         * @return	boolean
         */
        function addClassReferenceSet(&$datasource, &$template, $handle, $primarykey) {
            //
            $block = array(
                    "class-references",						// block 0
                    "class-reference-properties",			// block 1
                    array(									// block 2
                        "class-reference-association",
                        "class-reference-association-properties"
                    ) ,
                    "class-reference-class"					// block 3
            );
            //	1- Reference set
            $writer = new ElementReferenceWriter();
            return( $writer->addReferenceSet($datasource, $template, $handle, $block, $primarykey));
        }
        /**
		 * This function renders the xml <operations> block of the element(primarykey) class
         *
         * @access	protected
         * @param	object		name="datasource"
         * @param	object		name="template"
         * @param	integer		name="handle"
         * @param	integer		name="primarykey"
         * @return	boolean
         */
        function addClassOperationSet(&$datasource, &$template, $handle, $primarykey) {
			//
            $block = array (
                  "class-operations",			// block 0
                  "class-operation-properties", // block 1
                  "class-operation-parameters"	// block 2
			);
            //	1- Operation set
            $writer = new ElementOperationWriter();
            return( $writer->addOperationSet($datasource, $template, $handle, $block, $primarykey));
        }
        /**
         * This function renders the xml <attributes> block of the element(primarykey) class
         *
         * @access	protected
         * @param	object		name="datasource"
         * @param	object		name="template"
         * @param	integer		name="handle"
         * @param	integer		name="primarykey"
         * @return	boolean
         */
        function addClassAttributeSet(&$datasource, &$template, $handle, $primarykey) {
			//
            $block = array (
                  "class-attributes",			// block 0
                  "class-attribute-properties"	// block 1
			);
            //	1- Attribute set
            return ($this->addContainedElementSet($datasource, $template, $handle, $block, ATTRIBUTE_TYPE, $primarykey));
        }
        /**
         *
         * @access	public
         *
         * @param	object		name="datasource"
         * @param	object		name="template"
         * @param	array		name="element"
         * @param	integer		name="handle"
         * @return	boolean
         */
        function addElement(&$datasource, &$template, &$element, $handle) {
            //
            $element["OBJPATHROOT"] = $this->getNamespaceRoot($datasource, $element["OBJELEMROOT"]);
            $element["OBJELEMPATH"] = $this->getNamespacePath($datasource, $element["OBJELEMLINK"]);
            //
            $template->assign($element, NULL, $handle);
            // Properties
            if (false == $this->addPropertySet(
							$datasource, $template, $handle, "class-properties", $element["OBJELEMPKID"]))
                return (false);
            // Attributes
            if (false == $this->addClassAttributeSet(
							$datasource, $template, $handle, $element["OBJELEMPKID"]))
                return (false);
            // Operations
            if (false == $this->addClassOperationSet(
							$datasource, $template, $handle, $element["OBJELEMPKID"]))
                return (false);
            // References
            if (false == $this->addClassReferenceSet(
							$datasource, $template, $handle, $element["OBJELEMPKID"]))
                return (false);
            //
            return (true);
        }
    };
    //	Class
    //-------------------------------------------------------------------------    
}
//	namespace
//-----------------------------------------------------------------------------
?>
Return current item: Entier Studio