2012-09-20 07:51:34 +04:00
|
|
|
/**
|
|
|
|
* xrdp: A Remote Desktop Protocol server.
|
|
|
|
*
|
2014-03-02 11:26:40 +04:00
|
|
|
* Copyright (C) Jay Sorg 2004-2014
|
2012-09-20 07:51:34 +04:00
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*
|
|
|
|
* simple list
|
|
|
|
*/
|
2005-06-28 07:04:36 +04:00
|
|
|
|
|
|
|
#if !defined(LIST_H)
|
|
|
|
#define LIST_H
|
|
|
|
|
2006-10-12 08:46:40 +04:00
|
|
|
#include "arch.h"
|
|
|
|
|
2005-06-28 07:04:36 +04:00
|
|
|
/* list */
|
|
|
|
struct list
|
|
|
|
{
|
2021-03-06 18:45:27 +03:00
|
|
|
tintptr *items;
|
2014-07-26 08:33:05 +04:00
|
|
|
int count;
|
|
|
|
int alloc_size;
|
|
|
|
int grow_by;
|
|
|
|
int auto_free;
|
2005-06-28 07:04:36 +04:00
|
|
|
};
|
|
|
|
|
2021-03-06 18:45:27 +03:00
|
|
|
struct list *
|
2005-06-30 05:01:19 +04:00
|
|
|
list_create(void);
|
2023-02-08 14:16:03 +03:00
|
|
|
/**
|
|
|
|
* Creates a list with at least the specified number of items
|
|
|
|
* reserved
|
|
|
|
* @param size Number of items to reserve
|
|
|
|
* @return list, or NULL if no memory
|
|
|
|
*/
|
|
|
|
struct list *
|
|
|
|
list_create_sized(unsigned int size);
|
2017-03-12 19:35:00 +03:00
|
|
|
void
|
2021-03-06 18:45:27 +03:00
|
|
|
list_delete(struct list *self);
|
2023-02-08 14:16:03 +03:00
|
|
|
/**
|
|
|
|
* Adds an item to a list
|
|
|
|
* @param self The list
|
|
|
|
* @param item The item to add
|
|
|
|
* @result 0 if a memory allocation failure occurred. In this
|
|
|
|
* case the item is not added
|
|
|
|
*
|
|
|
|
* Memory allocation failures will not occur if the list is
|
|
|
|
* sized appropriately when created.
|
|
|
|
*/
|
|
|
|
int
|
2021-03-06 18:45:27 +03:00
|
|
|
list_add_item(struct list *self, tintptr item);
|
2017-03-12 19:35:00 +03:00
|
|
|
tintptr
|
2016-10-17 09:14:06 +03:00
|
|
|
list_get_item(const struct list *self, int index);
|
2017-03-12 19:35:00 +03:00
|
|
|
void
|
2021-03-06 18:45:27 +03:00
|
|
|
list_clear(struct list *self);
|
2017-03-12 19:35:00 +03:00
|
|
|
int
|
2021-03-06 18:45:27 +03:00
|
|
|
list_index_of(struct list *self, tintptr item);
|
2017-03-12 19:35:00 +03:00
|
|
|
void
|
2021-03-06 18:45:27 +03:00
|
|
|
list_remove_item(struct list *self, int index);
|
2023-02-08 14:16:03 +03:00
|
|
|
/**
|
|
|
|
* Inserts an item into a list
|
|
|
|
* @param self The list
|
|
|
|
* @param index The location to insert the item before
|
|
|
|
* @param item The item to add
|
|
|
|
* @result 0 if a memory allocation failure occurred. In this
|
|
|
|
* case the item is not added
|
|
|
|
*
|
|
|
|
* Memory allocation failures will not occur if the list is
|
|
|
|
* sized appropriately when created.
|
|
|
|
*/
|
|
|
|
int
|
2021-03-06 18:45:27 +03:00
|
|
|
list_insert_item(struct list *self, int index, tintptr item);
|
2023-02-08 14:16:03 +03:00
|
|
|
/**
|
|
|
|
* Adds strings to a list from another list
|
|
|
|
* @param self The source list
|
|
|
|
* @param dest Destination list
|
|
|
|
* @param start_index Index to start on the source list (zero based)
|
|
|
|
*
|
|
|
|
* @result 0 if a memory allocation failure occurred. In this
|
|
|
|
* case the destination list is unaltered.
|
|
|
|
*
|
|
|
|
* Strings from the source list are copied with strdup()
|
|
|
|
* The dest list should have auto_free set, or memory leaks will occur
|
|
|
|
*/
|
|
|
|
int
|
2021-03-06 18:45:27 +03:00
|
|
|
list_append_list_strdup(struct list *self, struct list *dest, int start_index);
|
2017-03-12 19:35:00 +03:00
|
|
|
void
|
2021-03-06 18:45:27 +03:00
|
|
|
list_dump_items(struct list *self);
|
2005-06-28 07:04:36 +04:00
|
|
|
|
2023-02-15 08:50:28 +03:00
|
|
|
/**
|
|
|
|
* Splits a string on a separation character and then returns a list of
|
|
|
|
* the string split by the character, without the character contained within
|
|
|
|
* the pieces.
|
|
|
|
*
|
|
|
|
* The list must be disposed of by the caller.
|
|
|
|
*
|
|
|
|
* @param str String to split.
|
|
|
|
* @param character Character used as the delimiter between strings.
|
|
|
|
* @param start_index Index to start on the source list (zero based)
|
|
|
|
*
|
|
|
|
* @result 0 if a memory allocation failure occurred.
|
|
|
|
*
|
|
|
|
* String fragments in the list are created with strdup()
|
|
|
|
*/
|
|
|
|
struct list *
|
|
|
|
split_string_into_list(const char *str, char character);
|
|
|
|
|
2023-03-06 16:54:22 +03:00
|
|
|
/**
|
|
|
|
* As list_add_item() but for a C string
|
|
|
|
*
|
|
|
|
* This is a convenience function for a common operation
|
|
|
|
* @param self List to append to
|
|
|
|
* @param str String to append
|
|
|
|
*
|
|
|
|
* The passed-in string is strdup'd onto the list, so if auto_free
|
|
|
|
* isn't set, memory leaks will occur.
|
|
|
|
*
|
|
|
|
* A NULL pointer will be added as a NULL entry.
|
|
|
|
*
|
|
|
|
* @result 0 if any memory allocation failure occurred. In this case
|
|
|
|
* the list is unchanged.
|
|
|
|
*/
|
|
|
|
|
|
|
|
int
|
|
|
|
list_add_strdup(struct list *self, const char *str);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add multiple strings to a list
|
|
|
|
*
|
|
|
|
* This is a convenience function for a common operation
|
|
|
|
* @param self List to append to
|
|
|
|
* @param ... Strings to append. Terminate the list with a NULL.
|
|
|
|
*
|
|
|
|
* @result 0 if any memory allocation failure occurred. In this case
|
|
|
|
* the list is unchanged.
|
|
|
|
*/
|
|
|
|
|
|
|
|
int
|
|
|
|
list_add_strdup_multi(struct list *self, ...);
|
|
|
|
|
2005-06-28 07:04:36 +04:00
|
|
|
#endif
|