source: tests/swap.cfa@ 10a1225

ADT arm-eh ast-experimental cleanup-dtors enum forall-pointer-decay jacob/cs343-translation jenkins-sandbox new-ast new-ast-unique-expr pthread-emulation qualifiedEnum
Last change on this file since 10a1225 was ef346f7c, checked in by Peter A. Buhr <pabuhr@…>, 7 years ago

fix ostype

  • Property mode set to 100644
File size: 2.8 KB
RevLine 
[86bd7c1f]1//
2// Cforall Version 1.0.0 Copyright (C) 2015 University of Waterloo
3//
4// The contents of this file are covered under the licence agreement in the
5// file "LICENCE" distributed with Cforall.
6//
[dc8511c]7// swap.cfa --
[86bd7c1f]8//
[cb811ac]9// Author : Peter A. Buhr
[86bd7c1f]10// Created On : Wed May 27 17:56:53 2015
11// Last Modified By : Peter A. Buhr
[ef346f7c]12// Last Modified On : Sun Dec 23 23:00:49 2018
13// Update Count : 77
[86bd7c1f]14//
15
[73abe95]16#include <fstream.hfa>
17#include <stdlib.hfa> // swap
[42dcae7]18
[784deab]19int main( void ) {
[5721a6d]20 char c1 = 'a', c2 = 'b';
[200fcb3]21 sout | "char\t\t\t" | c1 | ' ' | c2 | "\t\t\tswap " | nonl;
[cb811ac]22 swap( c1, c2 );
[200fcb3]23 sout | '\t' | c1 | ' ' | c2;
[5721a6d]24
25 signed int i1 = -1, i2 = -2;
[200fcb3]26 sout | "signed int\t\t" | i1 | i2 | "\t\t\tswap " | nonl;
[cb811ac]27 swap( i1, i2 );
[200fcb3]28 sout | '\t' | i1 | i2;
[5721a6d]29
30 unsigned int ui1 = 1, ui2 = 2;
[200fcb3]31 sout | "unsigned int\t\t" | ui1 | ui2 | "\t\t\tswap " | nonl;
[cb811ac]32 swap( ui1, ui2 );
[200fcb3]33 sout | '\t' | ui1 | ui2;
[5721a6d]34
35 signed long int li1 = -1, li2 = -2;
[200fcb3]36 sout | "signed long int\t\t" | li1 | li2 | "\t\t\tswap " | nonl;
[cb811ac]37 swap( li1, li2 );
[200fcb3]38 sout | '\t' | li1 | li2;
[5721a6d]39
40 unsigned long int uli1 = 1, uli2 = 2;
[200fcb3]41 sout | "unsigned long int\t" | uli1 | uli2 | "\t\t\tswap " | nonl;
[cb811ac]42 swap( uli1, uli2 );
[200fcb3]43 sout | '\t' | uli1 | uli2;
[5721a6d]44
45 signed long long int lli1 = -1, lli2 = -2;
[200fcb3]46 sout | "signed long long int\t" | lli1 | lli2 | "\t\t\tswap " | nonl;
[cb811ac]47 swap( lli1, lli2 );
[200fcb3]48 sout | '\t' | lli1 | lli2;
[5721a6d]49
50 unsigned long long int ulli1 = 1, ulli2 = 2;
[200fcb3]51 sout | "unsigned long long int\t" | ulli1 | ulli2 | "\t\t\tswap " | nonl;
[cb811ac]52 swap( ulli1, ulli2 );
[200fcb3]53 sout | '\t' | ulli1 | ulli2;
[5721a6d]54
55 float f1 = 1.5, f2 = 2.5;
[200fcb3]56 sout | "float\t\t\t" | f1 | f2 | "\t\t\tswap " | nonl;
[cb811ac]57 swap( f1, f2 );
[200fcb3]58 sout | '\t' | f1 | f2;
[5721a6d]59
60 double d1 = 1.5, d2 = 2.5;
[200fcb3]61 sout | "double\t\t\t" | d1 | d2 | "\t\t\tswap " | nonl;
[cb811ac]62 swap( d1, d2 );
[200fcb3]63 sout | '\t' | d1 | d2;
[5721a6d]64
65 long double ld1 = 1.5, ld2 = 2.5;
[200fcb3]66 sout | "long double\t\t" | ld1 | ld2 | "\t\t\tswap " | nonl;
[cb811ac]67 swap( ld1, ld2 );
[200fcb3]68 sout | '\t' | ld1 | ld2;
[5721a6d]69
70 float _Complex fc1 = 1.5f+1.5if, fc2 = 2.5f+2.5if;
[200fcb3]71 sout | "float _Complex\t\t" | fc1 | fc2 | "\tswap " | nonl;
[cb811ac]72 swap( fc1, fc2 );
[200fcb3]73 sout | '\t' | fc1 | fc2;
[5721a6d]74
75 double _Complex dc1 = 1.5d+1.5id, dc2 = 2.5d+2.5id;
[200fcb3]76 sout | "double _Complex\t\t" | dc1 | dc2 | "\tswap " | nonl;
[cb811ac]77 swap( dc1, dc2 );
[200fcb3]78 sout | '\t' | dc1 | dc2;
[5721a6d]79
80 long double _Complex ldc1 = 1.5d+1.5il, ldc2 = 2.5d+2.5il;
[200fcb3]81 sout | "long double _Complex\t" | ldc1 | ldc2 | "\tswap " | nonl;
[cb811ac]82 swap( ldc1, ldc2 );
[200fcb3]83 sout | '\t' | ldc1 | ldc2;
[5721a6d]84
85 struct S { int i, j; } s1 = { 1, 2 }, s2 = { 2, 1 };
[09687aa]86 ofstream & ?|?( ofstream & os, S s ) { return os | s.i | s.j; }
[ef346f7c]87 void ?|?( ofstream & os, S s ) { (ofstream &)(os | s.i | s.j); nl( os ); }
[200fcb3]88 sout | "struct S\t\t" | s1 | "," | s2 | "\t\tswap " | nonl;
[cb811ac]89 swap( s1, s2 );
[200fcb3]90 sout | '\t' | s1 | "," | s2;
[5721a6d]91} // main
[42dcae7]92
93// Local Variables: //
[86bd7c1f]94// tab-width: 4 //
[dc8511c]95// compile-command: "cfa swap.cfa" //
[42dcae7]96// End: //
Note: See TracBrowser for help on using the repository browser.