view lphobos/typeinfo1/ti_uint.d @ 648:8d850fa25713

Fix VarDecls for tuples. Closes #99. I've implemented it this way since it doesn't require any changes in the frontend. However, I think having TypeTuple expressed as LLVM struct types would make much more sense and open the door to tuple lvalues.
author Christian Kamm <kamm incasoftware de>
date Sun, 05 Oct 2008 11:47:47 +0200
parents 2c3cd3596187
children
line wrap: on
line source


// uint

module typeinfo1.ti_uint;

class TypeInfo_k : TypeInfo
{
    char[] toString() { return "uint"; }

    hash_t getHash(void *p)
    {
	return *cast(uint *)p;
    }

    int equals(void *p1, void *p2)
    {
	return *cast(uint *)p1 == *cast(uint *)p2;
    }

    int compare(void *p1, void *p2)
    {
	if (*cast(uint*) p1 < *cast(uint*) p2)
	    return -1;
	else if (*cast(uint*) p1 > *cast(uint*) p2)
	    return 1;
	return 0;
    }

    size_t tsize()
    {
	return uint.sizeof;
    }

    void swap(void *p1, void *p2)
    {
	int t;

	t = *cast(uint *)p1;
	*cast(uint *)p1 = *cast(uint *)p2;
	*cast(uint *)p2 = t;
    }
}