2014-05-26 19:30:42 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 FH Bielefeld
|
|
|
|
*
|
|
|
|
* This file is part of a FH Bielefeld project.
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library 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
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
|
|
* MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file ntru_string.h
|
|
|
|
* Header for the external API of ntru_string.c.
|
|
|
|
* @brief header for ntru_string.c
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef NTRU_STRING_H
|
|
|
|
#define NTRU_STRING_H
|
|
|
|
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct string string;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents a string.
|
|
|
|
*/
|
|
|
|
struct string {
|
|
|
|
/**
|
|
|
|
* Pointer to the char array,
|
|
|
|
* holding the actual string.
|
2014-05-26 23:08:52 +00:00
|
|
|
* THIS IS NOT NULL TERMINATED
|
|
|
|
* (at least not necessarily,
|
|
|
|
* don't ever assume it).
|
2014-05-26 19:30:42 +00:00
|
|
|
*/
|
|
|
|
char *ptr;
|
|
|
|
/**
|
|
|
|
* Length of the string.
|
|
|
|
*/
|
|
|
|
size_t len;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2014-06-05 14:32:57 +00:00
|
|
|
/**
|
|
|
|
* Prints the given string to stdout.
|
|
|
|
*
|
|
|
|
* @param print_string the print to string
|
|
|
|
*/
|
2014-05-26 23:08:42 +00:00
|
|
|
void
|
2014-06-01 18:41:29 +00:00
|
|
|
prints(const string *print_string);
|
2014-05-26 23:08:42 +00:00
|
|
|
|
2014-05-26 19:38:39 +00:00
|
|
|
/**
|
|
|
|
* Delete the inner structure
|
|
|
|
* of the string and frees the string
|
|
|
|
* itself from the heap. Must not be
|
|
|
|
* called on stack variables.
|
|
|
|
*
|
|
|
|
* @param del_string the string to delete
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
string_delete(string *del_string);
|
|
|
|
|
|
|
|
|
2014-05-26 19:30:42 +00:00
|
|
|
#endif /* NTRU_STRING_H */
|