diff options
author | George Hazan <george.hazan@gmail.com> | 2012-07-15 16:44:52 +0000 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2012-07-15 16:44:52 +0000 |
commit | 4649bcfc2b1cbbe2f004d7bec963a7528866c072 (patch) | |
tree | c6619f8f08266c740dc4e9783396f4f614319e1f /protocols/Gadu-Gadu/dynstuff.c | |
parent | 43691e8134fab2a55243607b2047c2fb3f3ee04b (diff) |
z całym szacunkiem dla naszych polskich użytkowników
git-svn-id: http://svn.miranda-ng.org/main/trunk@977 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/Gadu-Gadu/dynstuff.c')
-rw-r--r-- | protocols/Gadu-Gadu/dynstuff.c | 613 |
1 files changed, 0 insertions, 613 deletions
diff --git a/protocols/Gadu-Gadu/dynstuff.c b/protocols/Gadu-Gadu/dynstuff.c deleted file mode 100644 index d90c4e7908..0000000000 --- a/protocols/Gadu-Gadu/dynstuff.c +++ /dev/null @@ -1,613 +0,0 @@ -/* $Id: dynstuff.c 11259 2010-02-17 04:47:22Z borkra $ */
-
-/*
- * (C) Copyright 2001-2003 Wojtek Kaniewski <wojtekka@irc.pl>
- * Dawid Jarosz <dawjar@poczta.onet.pl>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License Version 2 as
- * published by the Free Software Foundation.
- *
- * 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, write to the Free Software
- * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- */
-
-#include "gg.h"
-
-#include <errno.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-
-/*
- * list_add_sorted()
- *
- * dodaje do listy dany element. przy okazji mo¿e te¿ skopiowaæ zawarto¶æ.
- * je¶li poda siê jako ostatni parametr funkcjê porównuj±c± zawarto¶æ
- * elementów, mo¿e posortowaæ od razu.
- *
- * - list - wska¼nik do listy,
- * - data - wska¼nik do elementu,
- * - alloc_size - rozmiar elementu, je¶li chcemy go skopiowaæ.
- *
- * zwraca wska¼nik zaalokowanego elementu lub NULL w przpadku b³êdu.
- */
-void *list_add_sorted(list_t *list, void *data, int alloc_size, int (*comparision)(void *, void *))
-{
- list_t new, tmp;
-
- if (!list) {
- errno = EFAULT;
- return NULL;
- }
-
- new = malloc(sizeof(struct list));
-
- new->data = data;
- new->next = NULL;
-
- if (alloc_size) {
- new->data = malloc(alloc_size);
- memcpy(new->data, data, alloc_size);
- }
-
- if (!(tmp = *list)) {
- *list = new;
- } else {
- if (!comparision) {
- while (tmp->next)
- tmp = tmp->next;
- tmp->next = new;
- } else {
- list_t prev = NULL;
-
- while (comparision(new->data, tmp->data) > 0) {
- prev = tmp;
- tmp = tmp->next;
- if (!tmp)
- break;
- }
-
- if (!prev) {
- tmp = *list;
- *list = new;
- new->next = tmp;
- } else {
- prev->next = new;
- new->next = tmp;
- }
- }
- }
-
- return new->data;
-}
-
-/*
- * list_add()
- *
- * wrapper do list_add_sorted(), który zachowuje poprzedni± sk³adniê.
- */
-void *list_add(list_t *list, void *data, int alloc_size)
-{
- return list_add_sorted(list, data, alloc_size, NULL);
-}
-
-/*
- * list_remove()
- *
- * usuwa z listy wpis z podanym elementem.
- *
- * - list - wska¼nik do listy,
- * - data - element,
- * - free_data - zwolniæ pamiêæ po elemencie.
- */
-int list_remove(list_t *list, void *data, int free_data)
-{
- list_t tmp, last = NULL;
-
- if (!list || !*list) {
- errno = EFAULT;
- return -1;
- }
-
- tmp = *list;
- if (tmp->data == data) {
- *list = tmp->next;
- } else {
- for (; tmp && tmp->data != data; tmp = tmp->next)
- last = tmp;
- if (!tmp) {
- errno = ENOENT;
- return -1;
- }
- last->next = tmp->next;
- }
-
- if (free_data)
- free(tmp->data);
- free(tmp);
-
- return 0;
-}
-
-/*
- * list_count()
- *
- * zwraca ilo¶æ elementów w danej li¶cie.
- *
- * - list - lista.
- */
-int list_count(list_t list)
-{
- int count = 0;
-
- for (; list; list = list->next)
- count++;
-
- return count;
-}
-
-/*
- * list_destroy()
- *
- * niszczy wszystkie elementy listy.
- *
- * - list - lista,
- * - free_data - czy zwalniaæ bufor danych?
- */
-int list_destroy(list_t list, int free_data)
-{
- list_t tmp;
-
- while (list) {
- if (free_data)
- free(list->data);
-
- tmp = list->next;
-
- free(list);
-
- list = tmp;
- }
-
- return 0;
-}
-
-/*
- * string_realloc()
- *
- * upewnia siê, ¿e w stringu bêdzie wystarczaj±co du¿o miejsca.
- *
- * - s - ci±g znaków,
- * - count - wymagana ilo¶æ znaków (bez koñcowego '\0').
- */
-static void string_realloc(string_t s, int count)
-{
- char *tmp;
-
- if (s->str && count + 1 <= s->size)
- return;
-
- tmp = realloc(s->str, count + 81);
- if (!s->str)
- *tmp = 0;
- tmp[count + 80] = 0;
- s->size = count + 81;
- s->str = tmp;
-}
-
-/*
- * string_append_c()
- *
- * dodaje do danego ci±gu jeden znak, alokuj±c przy tym odpowiedni± ilo¶æ
- * pamiêci.
- *
- * - s - ci±g znaków.
- * - c - znaczek do dopisania.
- */
-int string_append_c(string_t s, char c)
-{
- if (!s) {
- errno = EFAULT;
- return -1;
- }
-
- string_realloc(s, s->len + 1);
-
- s->str[s->len + 1] = 0;
- s->str[s->len++] = c;
-
- return 0;
-}
-
-/*
- * string_append_n()
- *
- * dodaje tekst do bufora alokuj±c odpowiedni± ilo¶æ pamiêci.
- *
- * - s - ci±g znaków,
- * - str - tekst do dopisania,
- * - count - ile znaków tego tekstu dopisaæ? (-1 znaczy, ¿e ca³y).
- */
-int string_append_n(string_t s, const char *str, int count)
-{
- if (!s || !str) {
- errno = EFAULT;
- return -1;
- }
-
- if (count == -1)
- count = (int)strlen(str);
-
- string_realloc(s, s->len + count);
-
- s->str[s->len + count] = 0;
- strncpy(s->str + s->len, str, count);
-
- s->len += count;
-
- return 0;
-}
-
-int string_append(string_t s, const char *str)
-{
- return string_append_n(s, str, -1);
-}
-
-/*
- * string_insert_n()
- *
- * wstawia tekst w podane miejsce bufora.
- *
- * - s - ci±g znaków,
- * - index - miejsce, gdzie mamy wpisaæ (liczone od 0),
- * - str - tekst do dopisania,
- * - count - ilo¶æ znaków do dopisania (-1 znaczy, ¿e wszystkie).
- */
-void string_insert_n(string_t s, int index, const char *str, int count)
-{
- if (!s || !str)
- return;
-
- if (count == -1)
- count = (int)strlen(str);
-
- if (index > s->len)
- index = s->len;
-
- string_realloc(s, s->len + count);
-
- memmove(s->str + index + count, s->str + index, s->len + 1 - index);
- memmove(s->str + index, str, count);
-
- s->len += count;
-}
-
-void string_insert(string_t s, int index, const char *str)
-{
- string_insert_n(s, index, str, -1);
-}
-
-/*
- * string_init()
- *
- * inicjuje strukturê string. alokuje pamiêæ i przypisuje pierwsz± warto¶æ.
- *
- * - value - je¶li NULL, ci±g jest pusty, inaczej kopiuje tam.
- *
- * zwraca zaalokowan± strukturê `string'.
- */
-string_t string_init(const char *value)
-{
- string_t tmp = malloc(sizeof(struct string));
-
- if (!value)
- value = "";
-
- tmp->str = _strdup(value);
- tmp->len = (int)strlen(value);
- tmp->size = (int)strlen(value) + 1;
-
- return tmp;
-}
-
-/*
- * string_clear()
- *
- * czy¶ci zawarto¶æ struktury `string'.
- *
- * - s - ci±g znaków.
- */
-void string_clear(string_t s)
-{
- if (!s)
- return;
-
- if (s->size > 160) {
- s->str = realloc(s->str, 80);
- s->size = 80;
- }
-
- s->str[0] = 0;
- s->len = 0;
-}
-
-/*
- * string_free()
- *
- * zwalnia pamiêæ po strukturze string i mo¿e te¿ zwolniæ pamiêæ po samym
- * ci±gu znaków.
- *
- * - s - struktura, któr± wycinamy,
- * - free_string - zwolniæ pamiêæ po ci±gu znaków?
- *
- * je¶li free_string=0 zwraca wska¼nik do ci±gu, inaczej NULL.
- */
-char *string_free(string_t s, int free_string)
-{
- char *tmp = NULL;
-
- if (!s)
- return NULL;
-
- if (free_string)
- free(s->str);
- else
- tmp = s->str;
-
- free(s);
-
- return tmp;
-}
-
-/*
- * _itoa()
- *
- * prosta funkcja, która zwraca tekstow± reprezentacjê liczby. w obrêbie
- * danego wywo³ania jakiej¶ funkcji lub wyra¿enia mo¿e byæ wywo³ania 10
- * razy, poniewa¿ tyle mamy statycznych buforów. lepsze to ni¿ ci±g³e
- * tworzenie tymczasowych buforów na stosie i sprintf()owanie.
- *
- * - i - liczba do zamiany.
- *
- * zwraca adres do bufora, którego _NIE_NALE¯Y_ zwalniaæ.
- */
-const char *ditoa(long int i)
-{
- static char bufs[10][16];
- static int index = 0;
- char *tmp = bufs[index++];
-
- if (index > 9)
- index = 0;
-
- mir_snprintf(tmp, 16, "%ld", i);
-
- return tmp;
-}
-
-/*
- * array_make()
- *
- * tworzy tablicê tekstów z jednego, rozdzielonego podanymi znakami.
- *
- * - string - tekst wej¶ciowy,
- * - sep - lista elementów oddzielaj±cych,
- * - max - maksymalna ilo¶æ elementów tablicy. je¶li równe 0, nie ma
- * ograniczeñ rozmiaru tablicy.
- * - trim - czy wiêksz± ilo¶æ elementów oddzielaj±cych traktowaæ jako
- * jeden (na przyk³ad spacje, tabulacja itp.)
- * - quotes - czy pola mog± byæ zapisywane w cudzys³owiach lub
- * apostrofach z escapowanymi znakami.
- *
- * zaalokowan± tablicê z zaalokowanymi ci±gami znaków, któr± nale¿y
- * zwolniæ funkcj± array_free()
- */
-char **array_make(const char *string, const char *sep, int max, int trim, int quotes)
-{
- const char *p, *q;
- char **result = NULL;
- int items = 0, last = 0;
-
- if (!string || !sep)
- goto failure;
-
- for (p = string; ; ) {
- int len = 0;
- char *token = NULL;
-
- if (max && items >= max - 1)
- last = 1;
-
- if (trim) {
- while (*p && strchr(sep, *p))
- p++;
- if (!*p)
- break;
- }
-
- if (!last && quotes && (*p == '\'' || *p == '\"')) {
- char sep = *p;
-
- for (q = p + 1, len = 0; *q; q++, len++) {
- if (*q == '\\') {
- q++;
- if (!*q)
- break;
- } else if (*q == sep)
- break;
- }
-
- if ((token = calloc(1, len + 1))) {
- char *r = token;
-
- for (q = p + 1; *q; q++, r++) {
- if (*q == '\\') {
- q++;
-
- if (!*q)
- break;
-
- switch (*q) {
- case 'n':
- *r = '\n';
- break;
- case 'r':
- *r = '\r';
- break;
- case 't':
- *r = '\t';
- break;
- default:
- *r = *q;
- }
- } else if (*q == sep) {
- break;
- } else
- *r = *q;
- }
-
- *r = 0;
- }
-
- p = (*q) ? q + 1 : q;
-
- } else {
- for (q = p, len = 0; *q && (last || !strchr(sep, *q)); q++, len++);
- token = calloc(1, len + 1);
- strncpy(token, p, len);
- token[len] = 0;
- p = q;
- }
-
- result = realloc(result, (items + 2) * sizeof(char*));
- result[items] = token;
- result[++items] = NULL;
-
- if (!*p)
- break;
-
- p++;
- }
-
-failure:
- if (!items)
- result = calloc(1, sizeof(char*));
-
- return result;
-}
-
-/*
- * array_count()
- *
- * zwraca ilo¶æ elementów tablicy.
- */
-int array_count(char **array)
-{
- int result = 0;
-
- if (!array)
- return 0;
-
- while (*array) {
- result++;
- array++;
- }
-
- return result;
-}
-
-/*
- * array_add()
- *
- * dodaje element do tablicy.
- */
-void array_add(char ***array, char *string)
-{
- int count = array_count(*array);
-
- *array = realloc(*array, (count + 2) * sizeof(char*));
- (*array)[count + 1] = NULL;
- (*array)[count] = string;
-}
-
-/*
- * array_join()
- *
- * ³±czy elementy tablicy w jeden string oddzielaj±c elementy odpowiednim
- * separatorem.
- *
- * - array - wska¼nik do tablicy,
- * - sep - seperator.
- *
- * zwrócony ci±g znaków nale¿y zwolniæ.
- */
-char *array_join(char **array, const char *sep)
-{
- string_t s = string_init(NULL);
- int i;
-
- if (!array)
- return _strdup("");
-
- for (i = 0; array[i]; i++) {
- if (i)
- string_append(s, sep);
-
- string_append(s, array[i]);
- }
-
- return string_free(s, 0);
-}
-
-/*
- * array_contains()
- *
- * stwierdza, czy tablica zawiera podany element.
- *
- * - array - tablica,
- * - string - szukany ci±g znaków,
- * - casesensitive - czy mamy zwracaæ uwagê na wielko¶æ znaków?
- *
- * 0/1
- */
-int array_contains(char **array, const char *string, int casesensitive)
-{
- int i;
-
- if (!array || !string)
- return 0;
-
- for (i = 0; array[i]; i++) {
- if (casesensitive && !strcmp(array[i], string))
- return 1;
- if (!casesensitive && !strcasecmp(array[i], string))
- return 1;
- }
-
- return 0;
-}
-
-/*
- * array_free()
- *
- * zwalnia pamieæ zajmowan± przez tablicê.
- */
-void array_free(char **array)
-{
- char **tmp;
-
- if (!array)
- return;
-
- for (tmp = array; *tmp; tmp++)
- free(*tmp);
-
- free(array);
-}
|