* @author Vasilis Georgoudis * @author Corentin Perrot */ class Pressbooks_Metadata_SoftwareSourceCode extends Pressbooks_Metadata_Type { /** * The variable that holds all parent required properties * * @since 0.x * @access public */ static $required_parent_props = array( ); /** * The variable that holds the values for the settings for this schema type * * @since 0.x * @access public */ static $type_setting = array('softwareSourceCode_type' => array('SoftwareSourceCode Type','http://schema.org/SoftwareSourceCode')); /** * The variable that holds the parents for the type * * @since 0.x * @access public */ static $type_parents = array( 'schemaTypes\Pressbooks_Metadata_Thing', 'schemaTypes\Pressbooks_Metadata_CreativeWork' ); /** * The variable that holds the properties of this schema type * * @since 0.x * @access public */ static $type_properties = array( 'codeRepository' => array(false,'Code Repository','Link to the repository where the un-compiled, human readable code and related code is located (SVN, github, CodePlex).'), 'codeSampleType' => array(false,'Code Sample Type','What type of code sample: full (compile ready) solution, code snippet, inline code, scripts, template. Supersedes sampleType.'), 'programmingLanguage' => array(false,'Programming Language','The computer programming language.'), 'runtimePlatform' => array(false,'Runtime Platform','Runtime platform or script interpreter dependencies (Example - Java v1, Python2.3, .Net Framework 3.0). Supersedes runtime.'), //'targetProduct' => array(false,'Target Product','Target Operating System / Product to which the code applies. If applies to several versions, just the product name can be used.') ); public function __construct($type_level_input) { parent::__construct($type_level_input); $this->type_fields = $this->get_all_properties(); $this->class_name = __CLASS__ .'_'. $this->type_level; $this->pmdt_populate_names(self::$type_setting); $this->pmdt_add_metabox($this->type_level); } /** * Function used for combining the current types properties with its parents fields * * @since 0.x * @access public */ public function get_all_properties() { $properties = self::$type_properties; foreach(self::$type_parents as $parentType){ $properties = array_merge($properties,$parentType::type_properties); } return $properties; } /** * Function used for comparing the instances of the schema types * * @since 0.x * @access public */ public function __toString() { return $this->class_name; } }