/*
 * Copyright (c) 2003, The Tendra Project <http://www.ten15.org/>
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice unmodified, this list of conditions, and the following
 *    disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 *
 *  		 Crown Copyright (c) 1997
 *  
 *  This TenDRA(r) Computer Program is subject to Copyright
 *  owned by the United Kingdom Secretary of State for Defence
 *  acting through the Defence Evaluation and Research Agency
 *  (DERA).  It is made available to Recipients with a
 *  royalty-free licence for its use, reproduction, transfer
 *  to other parties and amendment for any purpose not excluding
 *  product development provided that any such use et cetera
 *  shall be deemed to be acceptance of the following conditions:-
 *  
 *      (1) Its Recipients shall ensure that this Notice is
 *      reproduced upon any copies or amended versions of it;
 *  
 *      (2) Any amended version of it shall be clearly marked to
 *      show both the nature of and the organisation responsible
 *      for the relevant amendment or amendments;
 *  
 *      (3) Its onward transfer from a recipient to another
 *      party shall be deemed to be that party's acceptance of
 *      these conditions;
 *  
 *      (4) DERA gives no warranty or assurance as to its
 *      quality or suitability for any purpose and DERA accepts
 *      no liability whatsoever in relation to any use to which
 *      it may be put.
 *
 * $TenDRA: tendra/src/tools/pl/examples/arep.pl,v 1.4 2003/08/24 22:53:06 nonce Exp $
 */


/* CAPSULE B:
	This might be a capsule which defines how array descriptors are laid
	out - could vary from platform to platform - bound by TDF linking
	to capsules produced from Fortran.
*/

Struct Desc (BASE:Ptr Double, LB:Int, UB:Int,
		STRIDE:offset(alignment(Double), alignment(Double)));
/* Desc is a token giving the shape of a 1-d array pointer;
	BASE is token which extracts the base pointer from a Desc EXP
	.BASE is the offset of the base pointer from the start of a Desc
	etc for LB,UB and STRIDE
*/ 

Tokdef SIZE = [e:EXP]EXP 
	( STRIDE[e] .* ((UB[e] - LB[e])+ 1(Int)) );
/* SIZE is a token which evaluates the "size" of an array from its descriptor
*/

Tokdef Make_Desc = [base:EXP, l:EXP, u:EXP, s:EXP]EXP
		   Cons[shape_offset(Desc)]
			( .BASE:base, .LB:l, .UB:u, .STRIDE:s);
/* constructs a descriptor from its components */

Tokdef Local_array = [l:EXP, u:EXP, s:SHAPE]EXP
	EXP: Make_Desc[local_alloc( Sizeof(s) .* ((u - l)+ 1(Int))),
		  l, u, Sizeof(s)];
/* define a 1-d array of shape s */

Keep (Desc, BASE, LB, UB, STRIDE, SIZE, Make_Desc, Local_array)


syntax highlighted by Code2HTML, v. 0.9.1