File: gen.php

package info (click to toggle)
collada-dom 2.4.4%2Bds1-2
  • links: PTS, VCS
  • area: main
  • in suites: buster, stretch
  • size: 17,096 kB
  • sloc: cpp: 156,849; php: 4,567; makefile: 38; sh: 32; python: 14
file content (158 lines) | stat: -rw-r--r-- 4,802 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
<?php
/*
* Copyright 2006 Sony Computer Entertainment Inc.
*
* Licensed under the MIT Open Source License, for details please see license.txt or the website
* http://www.opensource.org/licenses/mit-license.php
*
*/ 

// COMMAND LINE: bin/php.exe gen.php collada.xsd [minimal]
// Note: must be run from home directory of code generator (i.e. where gen.php lives)

ini_set("memory_limit", "256M");

if ( file_exists( $argv[1] ) ) { $collada_file = $argv[1]; }
else
{
  die( "Can't find COLLADA file '" . $argv[1] . "'\n" );
}


require_once( 'src/SchemaParser.php' );
require_once( 'om/object-model.php' );
require_once( 'tpl/template-engine.php' );

// Returns either a capitalized or non-capitalized version of the name, thus helping us
// avoid name clashes. For example, say we have an element called 'rgb' and an element 
// called 'RGB'. They're both going to map to the name constant 'COLLADA_ELEMENT_RGB'. 
// Instead, use COLLADA_ELEMENT_rgb for the 'rgb' element.
function getUniqueName($name, $array) {
	$uniqueName = strtoupper($name);
	if (array_search($uniqueName, $array) !== FALSE) {
		$uniqueName = $name;
	}
	return $uniqueName;
}


if ( preg_match( "/min/i", $argv[2] ) || preg_match( "/min/i", $argv[3] ) ) { 
	$_globals['full_code'] = false; 
}
if ( preg_match( "/cprt/i", $argv[2] ) || preg_match( "/cprt/i", $argv[3] ) ) { 
	$_globals['copyright'] = true; 
}

$_globals['accessorsAndMutators'] = true;

$p = new SchemaParser();
$p->parse( $collada_file );


initGen( $collada_file );


$pop = $p->root_elements[0];

//Grab the collada version number
$_globals['constStrings']['COLLADA_VERSION'] = "\"". $pop->getAttribute('version') . "\";\n";
//Grab the collada namespace
$_globals['constStrings']['COLLADA_NAMESPACE'] = "\"". $pop->getAttribute('xmlns') . "\";\n\n";

// Grab simple types and collect meta-data for code-gen
$t_list = $pop->getElementsByType( 'xsSimpleType' );


$typemeta = array();

for( $i=0; $i<count( $t_list ); $i++ )
{
  $local_meta = & $t_list[$i]->generate();
  $typemeta[ $local_meta['type'] ] = & $local_meta;
  //print "Type: ". $local_meta['type'] ." created\n";
}

function propogateArrayTypes( &$lmeta ) {
	global $typemeta;
	if ( $lmeta['isArray'] ) {
		return;
	}
	if( isset( $typemeta[$lmeta['base']] ) ) {
		propogateArrayTypes( $typemeta[$lmeta['base']] );
		$lmeta['isArray'] = $typemeta[$lmeta['base']]['isArray'];
	}
	//print $lmeta['type'] ." isArray = ". $lmeta['isArray'] ."\n";
}
foreach( $typemeta as $k => &$local_meta ) {
	propogateArrayTypes( $local_meta );
}

//Grab global complex types and make them available for all who need them

$_globals['complex_types'] = $pop->getElementsByType( 'xsComplexType' );

//generate type meta data
//print applyTemplate( 'TYPES_HEADER_FILE', $typemeta );
//print applyTemplate( 'TYPES_CPP_FILE', $typemeta );

$element_context = array();
$meta = array();

print "COMPLEX TYPES\n";
for( $i=0; $i<count( $_globals['complex_types'] ); $i++ )
{
  $local_meta = & $_globals['complex_types'][$i]->generate( $element_context, $_globals['global_elements'] );
  $meta[ $local_meta['element_name'] ] = & $local_meta;
}

//collect element meta-data for code-gen

//Grab global groups and make them available for all who need them
$_globals['groups'] = $pop->getElementsByType( 'xsGroup' );
//collect meta-data for code-gen
print "GROUPS\n";
for( $i=0; $i<count( $_globals['groups'] ); $i++ )
{
  $local_meta = & $_globals['groups'][$i]->generate( $element_context, $_globals['global_elements'] );
  $meta[ $local_meta['element_name'] ] = & $local_meta;
}

// Grab global elements and collect meta-data for code-gen
$e_list = $pop->getElementsByType( 'xsElement' );

print "ELEMENTS\n";

for( $i=0; $i<count( $e_list ); $i++ )
{
  $local_meta = & $e_list[$i]->generate( $element_context, $_globals['global_elements'] );
  $meta[ $local_meta['element_name'] ] = & $local_meta;
}

//propogate the substitutableWith lists and attributes inherited by type
foreach( $meta as $k => &$local_meta ) {
	if ( $local_meta['substitution_group'] != '' ) {
		$meta[$local_meta['substitution_group']]['substitutableWith'][] = $k;
		//$meta[$local_meta['substitution_group']]['ref_elements'][] = $k;
		//print $local_meta['substitution_group'] ." sub with ". $k ."\n";
	}
}

$indentNum = 0;
// Generate header files
$includeList = array();
foreach( $meta as $k => &$local_meta )
{
  // Generate the dom
  print applyTemplate( 'HEADER_FILE', $local_meta );
  print applyTemplate( 'CPP_FILE', $local_meta );
}

print applyTemplate( 'TYPES_HEADER_FILE', $typemeta );
print applyTemplate( 'TYPES_CPP_FILE', $typemeta );

print applyTemplate( 'ELEMENTS_FILE', $meta );
print applyTemplate( 'CONSTANTS_FILE', $_globals['constStrings'] );
print applyTemplate( 'CONSTANTS_CPP_FILE', $_globals['constStrings'] );
cleanupGen();

?>