Changeset ebb5ed9


Ignore:
Timestamp:
Mar 10, 2017, 4:42:26 PM (7 years ago)
Author:
Rob Schluntz <rschlunt@…>
Branches:
ADT, aaron-thesis, arm-eh, ast-experimental, cleanup-dtors, deferred_resn, demangler, enum, forall-pointer-decay, jacob/cs343-translation, jenkins-sandbox, master, new-ast, new-ast-unique-expr, new-env, no_list, persistent-indexer, pthread-emulation, qualifiedEnum, resolv-new, with_gc
Children:
0b465a5
Parents:
dc0557d
Message:

update tuplePolymorphism test to include an example of non-matching tuple assertions

Location:
src/tests
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • src/tests/.expect/tuplePolymorphism.txt

    rdc0557d rebb5ed9  
    33123 999.123 456
    44246 1998.25 912
     51.21 x 10.21 1111 v 54385938 1111 v 54385938
  • src/tests/tuplePolymorphism.c

    rdc0557d rebb5ed9  
    1414//
    1515
     16// packed is needed so that structs are not passed with the same alignment as function arguments
     17__attribute__((packed)) struct A {
     18  double x;
     19  char y;
     20  double z;
     21};
     22
     23__attribute__((packed)) struct B {
     24  long long x;
     25  char y;
     26  long long z;
     27};
     28
     29// ensure that f is a viable candidate for g, even though its parameter structure does not exactly match
     30[A] f([A, B] x, B y) { printf("%g %c %g %lld %c %lld %lld %c %lld\n", x.0.[x,y,z], x.1.[x,y,z], y.[x,y,z]); return x.0; }
     31forall(otype T, otype U | { T f(T, U, U); })
     32void g(T x, U y) { f(x, y, y); }
     33
     34// add two triples
    1635forall(otype T | { T ?+?(T, T); })
    1736[T, T, T] ?+?([T, T, T] x, [T, T, T] y) {
     
    4059  [x1, x2, x3] = zzz+zzz;
    4160  printf("%d %g %d\n", x1, x2, x3);
     61
     62  // ensure non-matching assertions are specialized correctly
     63  g((A){ 1.21, 'x', 10.21}, (B){ 1111LL, 'v', 54385938LL });
    4264}
    4365
Note: See TracChangeset for help on using the changeset viewer.