Skip to main content

Notice: this Wiki will be going read only early in 2024 and edits will no longer be possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.

Jump to: navigation, search

Difference between revisions of "VJET/Typing Arrays with VJETDocs"

(Fix syntax in previous examples. Cleanup text and formatting. Add example of Array of o-type.)
 
Line 1: Line 1:
 
<span style="color:#333333">In JavaScript there is the Array type.</span> Below <span style="color:#333333">are examples of using JavaScript Array.</span><br> <source lang="javascript">
 
<span style="color:#333333">In JavaScript there is the Array type.</span> Below <span style="color:#333333">are examples of using JavaScript Array.</span><br> <source lang="javascript">
 
var browsers = ['Firefox', 'Chrome', 'Safari'] ; //< Array  
 
var browsers = ['Firefox', 'Chrome', 'Safari'] ; //< Array  
var browsers = new Array('Firefox', 'Chrome', 'Safari') ; //< Array  
+
var browsers = new Array('Firefox', 'Chrome', 'Safari') ; //< Array  
var browsers = new Array() ; //< Array
+
var browsers = new Array() ; //< Array
browsers[0] = 'FireFox' ;
+
browsers[0] = 'FireFox' ;
browsers[1] = 'Chrome' ;
+
browsers[1] = 'Chrome' ;
browsers[2] = 'Safari' ;  
+
browsers[2] = 'Safari' ;  
 
</source>  
 
</source>  
  
Line 24: Line 24:
 
<br> <span style="color:#333333">An array with a single <nowiki>[</nowiki><nowiki>]</nowiki> pairs is called a single dimension array.&nbsp;</span><br> <source lang="javascript">
 
<br> <span style="color:#333333">An array with a single <nowiki>[</nowiki><nowiki>]</nowiki> pairs is called a single dimension array.&nbsp;</span><br> <source lang="javascript">
 
var out = vjo.sysout.println;  
 
var out = vjo.sysout.println;  
var scores = [91, 77, 84] ; //< Number[]
+
var scores = [91, 77, 84] ; //< Number[]
var names = ['Mark', 'Sean', 'Juan'] ; //< String[]  
+
var names = ['Mark', 'Sean', 'Juan'] ; //< String[]  
for(var i = 0; i < 3; i++) {
+
for(var i = 0; i < 3; i++) {
 
     var name = names[i] ; //< String
 
     var name = names[i] ; //< String
 
     var score = scores[i] ; //< Number
 
     var score = scores[i] ; //< Number
     out(name + ": " + score)
+
     out(name + ": " + score);
 +
}
 
</source>  
 
</source>  
  
 
console&gt;<br> <span style="color:#333333">Mark: 91</span><br> <span style="color:#333333">Sean: 77</span><br> <span style="color:#333333">Juan: 84&nbsp;</span><br>  
 
console&gt;<br> <span style="color:#333333">Mark: 91</span><br> <span style="color:#333333">Sean: 77</span><br> <span style="color:#333333">Juan: 84&nbsp;</span><br>  
  
<span style="color:#333333">It is possible to define arrays  of arrays; these are called multi-dimension arrays. Multi-dimension  arrays are defined by how many consecutive <nowiki>[</nowiki><nowiki>]</nowiki> pairs. The number of <nowiki>[</nowiki><nowiki>]</nowiki> pairs is often referred to as the n-dimensional array. Thus <nowiki>[</nowiki><nowiki>]</nowiki><nowiki>[</nowiki><nowiki>]</nowiki> means a 2 dimensional array and <nowiki>[</nowiki><nowiki>]</nowiki><nowiki>[</nowiki><nowiki>]</nowiki><nowiki>[</nowiki><nowiki>]</nowiki> means a 3-dimensional array and so on.&nbsp;</span><span style="color:#333333">For example <nowiki>[</nowiki><nowiki>]</nowiki><nowiki>[</nowiki><nowiki>]</nowiki> is a two-dimensional array. <nowiki>[</nowiki><nowiki>]</nowiki><nowiki>[</nowiki><nowiki>]</nowiki><nowiki>[</nowiki><nowiki>]</nowiki> is a three dimensional array and so on.</span><br>  
+
<span style="color:#333333">It is possible to define arrays  of arrays; these are called multi-dimension arrays. Multi-dimension  arrays are defined by how many consecutive <nowiki>[</nowiki><nowiki>]</nowiki> pairs.<br>
 +
The number of <nowiki>[</nowiki><nowiki>]</nowiki> pairs is often referred to as the n-dimensional array.  
 +
<br>
 +
Thus <nowiki>[</nowiki><nowiki>]</nowiki><nowiki>[</nowiki><nowiki>]</nowiki> means a 2 dimensional array and <nowiki>[</nowiki><nowiki>]</nowiki><nowiki>[</nowiki><nowiki>]</nowiki><nowiki>[</nowiki><nowiki>]</nowiki> means a 3-dimensional array and so on</span><span style="color:#333333">.</span><br>  
  
 
<span style="color:#333333">Here is an example of a two dimensional array of Number.</span><br> <source lang="javascript">
 
<span style="color:#333333">Here is an example of a two dimensional array of Number.</span><br> <source lang="javascript">
Line 43: Line 47:
 
  ];
 
  ];
 
var total = 0 ; //< Number  
 
var total = 0 ; //< Number  
for(var row = 0; row < 3; row++) {
+
for(var row = 0; row < 3; row++) {
for (var col = 0; col < 3; col++) {
+
  for (var col = 0; col < 3; col++) {
total += keys[row][col] ;
+
    total += keys[row][col] ;
vjo.sysout.println('total: ' + total) ;
+
    vjo.sysout.println('total: ' + total) ;
 +
  }
 +
}
 
</source>  
 
</source>  
  
 
<span style="color:#333333">console&gt;&nbsp;total: 45&nbsp;</span><br>  
 
<span style="color:#333333">console&gt;&nbsp;total: 45&nbsp;</span><br>  
  
<span style="color:#333333">We can have arrays of native types and vjet types. We can even have arrays of functions (we haven't described them yet).&nbsp;</span> <span style="color:#333333">We can even have an array of type-reference (although it may not be too useful).</span>
+
We can define an Object Literal which defines characteristics of a CPU. &nbsp;We scope this definition in a VJO o-type called MachineInfo.
  
[[Category:VJET]]
+
<source lang="javascript">
[[Category:VJETDoc]]
+
// This is a VJO o-type.  O-types allow us to define types for Javascript constructs
[[Category:JavaScript]]
+
// such as object literals.
 +
// In this example, arrs.MachineInfo is just a scoping name.
 +
vjo.otype('arrs.MachineInfo') //< public
 +
.defs({
 +
cpu: {
 +
vendor: null, //< public String
 +
cores: null, //< public int
 +
clock: null //< public Number
 +
}
 +
})
 +
.endType();
 +
</source>
 +
 
 +
We can then define an Array of CPU's.
 +
 
 +
<source lang="javascript">
 +
//< needs(arrs.MachineInfo)
 +
 
 +
var amd = { //< MachineInfo.cpu
 +
    clock: 2.8,
 +
    cores: 4,
 +
    vendor: 'AMD'
 +
};
 +
 
 +
// The order of elements in the Object Literal does not change the type contract.
 +
var intel = { //< MachineInfo.cpu
 +
    cores: 8,
 +
    clock: 3.1,
 +
    vendor: 'INTEL'
 +
};
 +
 
 +
// VJET "knows" this is a uniform array of Machine.cpu's so it auto-declares
 +
// for us.  We can see what the declaration would look like since we use it in the
 +
// following function overClock(...)
 +
var cpews = [amd, intel] ;
 +
 
 +
//> void overClock(MachineInfo.cpu[ ] cpus)
 +
function overClock(cpus) {
 +
for(var i = 0; i < cpus.length; i++) {
 +
cpus[i].clock += 1.1 ;
 +
}
 +
}
 +
 
 +
vjo.sysout.println(amd.clock) ; // outputs 2.8
 +
 
 +
// Wind them up!
 +
overClock(cpews) ;
 +
 
 +
vjo.sysout.println(amd.clock) ; // outputs 3.9
 +
</source>
 +
<span style="color:#333333">console&gt;<br>
 +
&nbsp;2.8<br>
 +
&nbsp;3.9
 +
</span><br>
 +
 
 +
We can have arrays of Javascript native types and VJET types. We can even have arrays of Functions, Typed-Functions and Type-References.
 +
 
 +
[[Category:VJET]] [[Category:VJETDoc]] [[Category:JavaScript]]

Latest revision as of 03:30, 15 February 2013

In JavaScript there is the Array type. Below are examples of using JavaScript Array.
var browsers = ['Firefox', 'Chrome', 'Safari'] ; //< Array 
var browsers = new Array('Firefox', 'Chrome', 'Safari') ; //< Array 
var browsers = new Array() ; //< Array
browsers[0] = 'FireFox' ;
browsers[1] = 'Chrome' ;
browsers[2] = 'Safari' ;

What elements you put in the array are up to you. In essence, any JavaScript object can be put in the array. In our previous examples it appears that we only want browser names in our Array. Actually we only want Strings from a typing standpoint. 

VJETDocs allows you to be very specific about what type you want your array to be. 


Array-Dimension = "[" "]" Ex: [] 

Array-Dimensions = one or more Array-Dimension's back to back

Ex: [][] or [][][] 

Array-Type: Limited-Type-Name Array-Dimensions 

Examples of a Vjet Array Type: String[] or Number[] or Date[][]or worker.Task[][][] 


An array with a single [] pairs is called a single dimension array. 
var out = vjo.sysout.println; 
var scores = [91, 77, 84] ; //< Number[]
var names = ['Mark', 'Sean', 'Juan'] ; //< String[] 
for(var i = 0; i < 3; i++) {
    var name = names[i] ; //< String
    var score = scores[i] ; //< Number
    out(name + ": " + score);
}

console>
Mark: 91
Sean: 77
Juan: 84 

It is possible to define arrays of arrays; these are called multi-dimension arrays. Multi-dimension arrays are defined by how many consecutive [] pairs.
The number of [] pairs is often referred to as the n-dimensional array.
Thus [][] means a 2 dimensional array and [][][] means a 3-dimensional array and so on
.

Here is an example of a two dimensional array of Number.
var keys = [ //< Number[][]
 [1, 2, 3],
 [4, 5, 6],
 [7, 8, 9]
 ];
var total = 0 ; //< Number 
for(var row = 0; row < 3; row++) {
  for (var col = 0; col < 3; col++) {
    total += keys[row][col] ;
    vjo.sysout.println('total: ' + total) ;
  }
}

console> total: 45 

We can define an Object Literal which defines characteristics of a CPU.  We scope this definition in a VJO o-type called MachineInfo.

// This is a VJO o-type.  O-types allow us to define types for Javascript constructs
// such as object literals.
// In this example, arrs.MachineInfo is just a scoping name.
vjo.otype('arrs.MachineInfo') //< public
.defs({
	cpu: {
		vendor: null,	//< public String
		cores: null, 	//< public int
		clock: null 	//< public Number
	}
})
.endType();

We can then define an Array of CPU's.

//< needs(arrs.MachineInfo)
 
var amd = { 	//< MachineInfo.cpu
    clock: 2.8,
    cores: 4,
    vendor: 'AMD'
};
 
// The order of elements in the Object Literal does not change the type contract.
var intel = { 	//< MachineInfo.cpu
    cores: 8,
    clock: 3.1,
    vendor: 'INTEL'
};
 
// VJET "knows" this is a uniform array of Machine.cpu's so it auto-declares
// for us.  We can see what the declaration would look like since we use it in the
// following function overClock(...)
var cpews = [amd, intel] ;
 
//> void overClock(MachineInfo.cpu[ ] cpus)
function overClock(cpus) {
	for(var i = 0; i < cpus.length; i++) {
		cpus[i].clock += 1.1 ;
	}
}
 
vjo.sysout.println(amd.clock) ; // outputs 2.8
 
// Wind them up!
overClock(cpews) ;
 
vjo.sysout.println(amd.clock) ; // outputs 3.9

console>
 2.8
 3.9

We can have arrays of Javascript native types and VJET types. We can even have arrays of Functions, Typed-Functions and Type-References.

Back to the top