//
// aegis - project change supervisor
// Copyright (C) 2001, 2002, 2004-2006, 2008 Peter Miller
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see
// .
//
#include
#include
format_version_list_ty *
format_version_list_new(void)
{
format_version_list_ty *fvlp;
fvlp = new format_version_list_ty;
fvlp->item = 0;
fvlp->length = 0;
fvlp->maximum = 0;
return fvlp;
}
void
format_version_list_delete(format_version_list_ty *fvlp, int delmore)
{
size_t j;
if (delmore)
{
for (j = 0; j < fvlp->length; ++j)
delete(fvlp->item[j]);
}
delete [] fvlp->item;
fvlp->item = 0;
fvlp->length = 0;
fvlp->maximum = 0;
delete fvlp;
}
#ifdef DEBUG
void
format_version_list_validate(format_version_list_ty *fvlp)
{
size_t j;
for (j = 0; j < fvlp->length; ++j)
fvlp->item[j]->validate();
}
#endif
void
format_version_list_append(format_version_list_ty *fvlp, format_version_ty *fvp)
{
if (fvlp->length >= fvlp->maximum)
{
fvlp->maximum = fvlp->maximum * 2 + 8;
format_version_ty **new_item = new format_version_ty * [fvlp->maximum];
for (size_t j = 0; j < fvlp->length; ++j)
new_item[j] = fvlp->item[j];
delete [] fvlp->item;
fvlp->item = new_item;
}
fvlp->item[fvlp->length++] = fvp;
}
static int
cmp(const void *va, const void *vb)
{
format_version_ty *a;
format_version_ty *b;
a = *(format_version_ty **)va;
b = *(format_version_ty **)vb;
if (a->when < b->when)
return -1;
if (a->when > b->when)
return 1;
return 0;
}
void
format_version_list_sort_by_date(format_version_list_ty *fvlp)
{
qsort(fvlp->item, fvlp->length, sizeof(fvlp->item[0]), cmp);
}