mirror of
https://github.com/zeek/zeek.git
synced 2025-10-02 06:38:20 +00:00

This also installs symlinks from "zeek" and "bro-config" to a wrapper script that prints a deprecation warning. The btests pass, but this is still WIP. broctl renaming is still missing. #239
246 lines
4.2 KiB
C++
246 lines
4.2 KiB
C++
#include "zeek-config.h"
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
#include "List.h"
|
|
#include "util.h"
|
|
|
|
#define DEFAULT_LIST_SIZE 10
|
|
#define GROWTH_FACTOR 2
|
|
|
|
BaseList::BaseList(int size)
|
|
{
|
|
num_entries = 0;
|
|
|
|
if ( size <= 0 )
|
|
{
|
|
max_entries = 0;
|
|
entry = 0;
|
|
return;
|
|
}
|
|
|
|
max_entries = size;
|
|
|
|
entry = (ent *) safe_malloc(max_entries * sizeof(ent));
|
|
}
|
|
|
|
|
|
BaseList::BaseList(const BaseList& b)
|
|
{
|
|
max_entries = b.max_entries;
|
|
num_entries = b.num_entries;
|
|
|
|
if ( max_entries )
|
|
entry = (ent *) safe_malloc(max_entries * sizeof(ent));
|
|
else
|
|
entry = 0;
|
|
|
|
for ( int i = 0; i < num_entries; ++i )
|
|
entry[i] = b.entry[i];
|
|
}
|
|
|
|
BaseList::BaseList(BaseList&& b)
|
|
{
|
|
entry = b.entry;
|
|
num_entries = b.num_entries;
|
|
max_entries = b.max_entries;
|
|
|
|
b.entry = 0;
|
|
b.num_entries = b.max_entries = 0;
|
|
}
|
|
|
|
BaseList::BaseList(const ent* arr, int n)
|
|
{
|
|
num_entries = max_entries = n;
|
|
entry = (ent*) safe_malloc(max_entries * sizeof(ent));
|
|
memcpy(entry, arr, n * sizeof(ent));
|
|
}
|
|
|
|
void BaseList::sort(list_cmp_func cmp_func)
|
|
{
|
|
qsort(entry, num_entries, sizeof(ent), cmp_func);
|
|
}
|
|
|
|
BaseList& BaseList::operator=(const BaseList& b)
|
|
{
|
|
if ( this == &b )
|
|
return *this;
|
|
|
|
free(entry);
|
|
|
|
max_entries = b.max_entries;
|
|
num_entries = b.num_entries;
|
|
|
|
if ( max_entries )
|
|
entry = (ent *) safe_malloc(max_entries * sizeof(ent));
|
|
else
|
|
entry = 0;
|
|
|
|
for ( int i = 0; i < num_entries; ++i )
|
|
entry[i] = b.entry[i];
|
|
|
|
return *this;
|
|
}
|
|
|
|
BaseList& BaseList::operator=(BaseList&& b)
|
|
{
|
|
if ( this == &b )
|
|
return *this;
|
|
|
|
free(entry);
|
|
entry = b.entry;
|
|
num_entries = b.num_entries;
|
|
max_entries = b.max_entries;
|
|
|
|
b.entry = 0;
|
|
b.num_entries = b.max_entries = 0;
|
|
return *this;
|
|
}
|
|
|
|
void BaseList::insert(ent a)
|
|
{
|
|
if ( num_entries == max_entries )
|
|
resize(max_entries ? max_entries * GROWTH_FACTOR : DEFAULT_LIST_SIZE);
|
|
|
|
for ( int i = num_entries; i > 0; --i )
|
|
entry[i] = entry[i-1]; // move all pointers up one
|
|
|
|
++num_entries;
|
|
entry[0] = a;
|
|
}
|
|
|
|
#include <stdio.h>
|
|
|
|
void BaseList::sortedinsert(ent a, list_cmp_func cmp_func)
|
|
{
|
|
// We optimize for the case that the new element is
|
|
// larger than most of the current entries.
|
|
|
|
// First append element.
|
|
if ( num_entries == max_entries )
|
|
resize(max_entries ? max_entries * GROWTH_FACTOR : DEFAULT_LIST_SIZE);
|
|
|
|
entry[num_entries++] = a;
|
|
|
|
// Then move it to the correct place.
|
|
ent tmp;
|
|
for ( int i = num_entries - 1; i > 0; --i )
|
|
{
|
|
if ( cmp_func(entry[i],entry[i-1]) <= 0 )
|
|
break;
|
|
|
|
tmp = entry[i];
|
|
entry[i] = entry[i-1];
|
|
entry[i-1] = tmp;
|
|
}
|
|
}
|
|
|
|
ent BaseList::remove(ent a)
|
|
{
|
|
int i;
|
|
for ( i = 0; i < num_entries && a != entry[i]; ++i )
|
|
;
|
|
|
|
return remove_nth(i);
|
|
}
|
|
|
|
ent BaseList::remove_nth(int n)
|
|
{
|
|
if ( n < 0 || n >= num_entries )
|
|
return 0;
|
|
|
|
ent old_ent = entry[n];
|
|
--num_entries;
|
|
|
|
for ( ; n < num_entries; ++n )
|
|
entry[n] = entry[n+1];
|
|
|
|
entry[n] = 0; // for debugging
|
|
return old_ent;
|
|
}
|
|
|
|
void BaseList::append(ent a)
|
|
{
|
|
if ( num_entries == max_entries )
|
|
resize(max_entries ? max_entries * GROWTH_FACTOR : DEFAULT_LIST_SIZE);
|
|
|
|
entry[num_entries++] = a;
|
|
}
|
|
|
|
// Get and remove from the end of the list.
|
|
ent BaseList::get()
|
|
{
|
|
if ( num_entries == 0 )
|
|
return 0;
|
|
|
|
return entry[--num_entries];
|
|
}
|
|
|
|
|
|
void BaseList::clear()
|
|
{
|
|
free(entry);
|
|
entry = 0;
|
|
num_entries = max_entries = 0;
|
|
}
|
|
|
|
ent BaseList::replace(int ent_index, ent new_ent)
|
|
{
|
|
if ( ent_index < 0 )
|
|
return 0;
|
|
|
|
ent old_ent;
|
|
|
|
if ( ent_index > num_entries - 1 )
|
|
{ // replacement beyond the end of the list
|
|
resize(ent_index + 1);
|
|
|
|
for ( int i = num_entries; i < max_entries; ++i )
|
|
entry[i] = 0;
|
|
num_entries = max_entries;
|
|
|
|
old_ent = 0;
|
|
}
|
|
else
|
|
old_ent = entry[ent_index];
|
|
|
|
entry[ent_index] = new_ent;
|
|
|
|
return old_ent;
|
|
}
|
|
|
|
int BaseList::resize(int new_size)
|
|
{
|
|
if ( new_size < num_entries )
|
|
new_size = num_entries; // do not lose any entries
|
|
|
|
if ( new_size != max_entries )
|
|
{
|
|
entry = (ent*) safe_realloc((void*) entry, sizeof(ent) * new_size);
|
|
if ( entry )
|
|
max_entries = new_size;
|
|
else
|
|
max_entries = 0;
|
|
}
|
|
|
|
return max_entries;
|
|
}
|
|
|
|
ent BaseList::is_member(ent e) const
|
|
{
|
|
int i;
|
|
for ( i = 0; i < length() && e != entry[i]; ++i )
|
|
;
|
|
|
|
return (i == length()) ? 0 : e;
|
|
}
|
|
|
|
int BaseList::member_pos(ent e) const
|
|
{
|
|
int i;
|
|
for ( i = 0; i < length() && e != entry[i]; ++i )
|
|
;
|
|
|
|
return (i == length()) ? -1 : i;
|
|
}
|