/* ====================================================================
* Copyright 1999 Web Juice, LLC. All rights reserved.
*
* staglist.c
*
* Functions for manipulating the simple tag list structure in the
* template library.
*
* ==================================================================== */
#include <string.h>
#include <stdlib.h>
#include <context.h>
#include <staglist.h>
/* ====================================================================
* NAME: staglist_init
*
* DESCRIPTION: Initializes and returns a pointer to a new simple tag
* structure.
*
* RETURN VALUES: Returns NULL if the memory allocation fails; otherwise
* returns a pointer to a simple tag structure.
*
* BUGS: Hopefully none.
* ==================================================================== */
staglist_p
staglist_init(void)
{
staglist_p simple_tag_list;
simple_tag_list = (staglist_p)calloc(1, sizeof(staglist));
if (simple_tag_list == NULL)
{
return NULL;
}
simple_tag_list->name = NULL;
simple_tag_list->function = NULL;
simple_tag_list->next = NULL;
return(simple_tag_list);
}
/* ====================================================================
* NAME: staglist_destroy
*
* DESCRIPTION: Frees up all memory associated with a simple tag list
*
* RETURN VALUES: None.
*
* BUGS: Because a free()d pointer still *looks* valid, it is
* difficult to protect against the problems that arise
* if the user calls this function too early.
* ==================================================================== */
void
staglist_destroy(staglist_p simple_tag_list)
{
staglist_p next;
if (simple_tag_list == NULL)
{
return;
}
next = simple_tag_list->next;
simple_tag_list->next = NULL;
if (simple_tag_list->name != NULL)
{
free(simple_tag_list->name);
}
free(simple_tag_list);
staglist_destroy(next);
}
/* ====================================================================
* NAME: staglist_register
*
* DESCRIPTION: Register a new tag and associated function to call.
*
* RETURN VALUES: Returns 0 upon failure; 1 on success.
*
* BUGS: Hopefully none.
* ==================================================================== */
int
staglist_register(staglist_p simple_tag_list, char *name,
void (*function)(context_p, char **, int, char**))
{
staglist_p current = simple_tag_list;
staglist_p existing = NULL;
staglist_p last = NULL;
/* Make sure the function isn't NULL */
if (function == NULL)
{
return 0;
}
/* Make sure the pointer passed in wasn't NULL */
if (simple_tag_list == NULL)
{
return 0;
}
/* Walk through the whole list, marking any pre-existing tag of
this name, and marking the last element in the list */
while (current != NULL)
{
if ((current->name != NULL) && (strcmp(current->name, name) == 0))
{
existing = current;
}
last = current;
current = current->next;
}
/* If the tag doesn't already exist, we may have to create a new list
element */
if (existing == NULL)
{
if (last->function == NULL)
{
existing = last;
} else {
last->next = staglist_init();
existing = last->next;
if (existing == NULL)
{
return 0;
}
}
existing->name = (char *)malloc(strlen(name) + 1);
strncpy(existing->name, name, strlen(name));
existing->name[strlen(name)] = '\0';
}
existing->function = function;
return 1;
}
/* ====================================================================
* NAME: staglist_exists
*
* DESCRIPTION: Find out whether a particular tag is a legitimate
* simple tag.
*
* RETURN VALUES: Returns 0 if there's a problem or if the name is not
* a valid simple tag, or 1 if the name is a valid tag.
*
* BUGS: Hopefully none.
* ==================================================================== */
int
staglist_exists(staglist_p simple_tag_list, char *name)
{
staglist_p current = simple_tag_list;
if (simple_tag_list == NULL)
{
return 0;
}
while (current != NULL)
{
if ((current->name != NULL) && (current->function != NULL)
&& (strcmp(current->name, name) == 0))
{
return 1;
}
current = current->next;
}
return 0;
}
/* ====================================================================
* NAME: staglist_exec
*
* DESCRIPTION: Executes the function associated with a given tag.
*
* RETURN VALUES: Returns NULL if there's a problem or the string result
* of the function on success.
*
* BUGS: Hopefully none.
* ==================================================================== */
int
staglist_exec(staglist_p simple_tag_list, char *name, context_p ctx,
char **output, int argc, char **argv)
{
staglist_p current = simple_tag_list;
if (simple_tag_list == NULL)
{
return 0;
}
while (current != NULL)
{
if ((current->name != NULL) && (current->function != NULL)
&& (strcmp(current->name, name) == 0))
{
current->function(ctx, output, argc, argv);
return 1;
}
current = current->next;
}
return 0;
}