view dmd/lstring.c @ 948:780530d1cad3

Revert templates to old behavior. While emitting a template instantiation only once is good for compile times and binary sizes, it doesn't work with linkonce linkage as inlined function bodies could be discarded. Since we don't want to inhibit inlining, templates are reverted to the previous behavior, where an instantiation is emitted for each module using it. In the future, a custom inlining pass may allow us to switch back to common/weak linkage and reenable smart template instance emission.
author Christian Kamm <kamm incasoftware de>
date Sun, 08 Feb 2009 21:44:46 +0100
parents c53b6e3fe49a
children b30fe7e1dbb9
line wrap: on
line source

// lstring.c

// Copyright (c) 1999-2002 by Digital Mars
// All Rights Reserved
// written by Walter Bright
// www.digitalmars.com
// License for redistribution is by either the Artistic License
// in artistic.txt, or the GNU General Public License in gnu.txt.
// See the included readme.txt for details.

#include <stdlib.h>

#include "dchar.h"
#include "mem.h"
#include "lstring.h"

Lstring Lstring::zero = LSTRING_EMPTY();

Lstring *Lstring::ctor(const dchar *p, unsigned length)
{
    Lstring *s;

    s = alloc(length);
    memcpy(s->string, p, length * sizeof(dchar));
    return s;
}

Lstring *Lstring::alloc(unsigned length)
{
    Lstring *s;

    s = (Lstring *)mem.malloc(size(length));
    s->length = length;
    s->string[length] = 0;
    return s;
}

Lstring *Lstring::append(const Lstring *s)
{
    Lstring *t;

    if (!s->length)
	return this;
    t = alloc(length + s->length);
    memcpy(t->string, string, length * sizeof(dchar));
    memcpy(t->string + length, s->string, s->length * sizeof(dchar));
    return t;
}

Lstring *Lstring::substring(int start, int end)
{
    Lstring *t;

    if (start == end)
	return &zero;
    t = alloc(end - start);
    memcpy(t->string, string + start, (end - start) * sizeof(dchar));
    return t;
}