Added more files, mainly beginning of filesystem sources implementation.

This commit is contained in:
Vreixo Formoso 2007-11-24 16:58:36 +01:00
parent 9ee4e39899
commit 6c090c9a7b
10 changed files with 283 additions and 30 deletions

View File

@ -10,9 +10,12 @@ lib_LTLIBRARIES = src/libisofs.la
src_libisofs_la_LDFLAGS = \ src_libisofs_la_LDFLAGS = \
-version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE) -version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE)
src_libisofs_la_SOURCES = \ src_libisofs_la_SOURCES = \
src/tree.h \ src/node.h \
src/tree.c \ src/node.c \
src/image.h src/image.h \
src/fsource.h \
src/fs_local.c \
src/stream.h
libinclude_HEADERS = \ libinclude_HEADERS = \
src/libisofs.h src/libisofs.h

2
TODO
View File

@ -6,6 +6,8 @@ TODO
==== ====
#00001 (tree.h) -> consider adding new timestamps to IsoTreeNode #00001 (tree.h) -> consider adding new timestamps to IsoTreeNode
#00002 (tree.h) -> handle deletion of each kind of node
#00003 make error.h header public
FIXME FIXME
===== =====

21
src/error.h Normal file
View File

@ -0,0 +1,21 @@
/*
* Copyright (c) 2007 Vreixo Formoso
*
* This file is part of the libisofs project; 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. See COPYING file for details.
*/
#ifndef LIBISO_ERROR_H_
#define LIBISO_ERROR_H_
/*
* Return values for libisofs functions, mainly error codes
* TODO #00003 make this header public
*/
#define ISO_SUCCESS 1
#define ISO_NULL_POINTER -1
#endif /*LIBISO_ERROR_H_*/

View File

@ -6,13 +6,10 @@
* published by the Free Software Foundation. See COPYING file for details. * published by the Free Software Foundation. See COPYING file for details.
*/ */
#include "tree.h"
#include "libisofs.h"
/*
/** * Filesystem/FileSource implementation to access the local filesystem.
* Increments the reference counting of the given node.
*/ */
void iso_node_ref(IsoTreeNode *node) {
node->refcount++; #include "fsource.h"
}

97
src/fsource.h Normal file
View File

@ -0,0 +1,97 @@
/*
* Copyright (c) 2007 Vreixo Formoso
*
* This file is part of the libisofs project; 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. See COPYING file for details.
*/
#ifndef LIBISO_FSOURCE_H_
#define LIBISO_FSOURCE_H_
/*
* Definitions for the file sources.
*/
/*
* Some functions here will be moved to libisofs.h when we expose
* Sources.
*/
#include <sys/stat.h>
typedef struct Iso_File_Source IsoFileSource;
typedef struct Iso_Filesystem IsoFilesystem;
struct Iso_Filesystem
{
/**
*
* @return
* 1 on success, < 0 on error
*/
int (*get_root)(IsoFilesystem *fs, IsoFileSource *root);
};
struct Iso_File_Source
{
/**
*
* @return
* 1 success, < 0 error
*/
int (*lstat)(IsoFileSource *src, struct stat *info);
//stat?
/**
* Opens the source.
* @return 1 on success, < 0 on error
*/
int (*open)(IsoFileSource *src);
void (*close)(IsoFileSource *src);
/**
* Attempts to read up to count bytes from the given source into
* the buffer starting at buf.
*
* The file src must be open() before calling this, and close() when no
* more needed. Not valid for dirs. On symlinks it reads the destination
* file.
*
* @return
* number of bytes read, 0 if EOF, < 0 on error
*/
int (*read)(IsoFileSource *src, void *buf, size_t count);
/**
* Read a directory.
*
* Each call to this function will return a new children, until we reach
* the end of file (i.e, no more children), in that case it returns 0.
*
* The dir must be open() before calling this, and close() when no more
* needed. Only valid for dirs.
*
* @param child
* pointer to be filled with the given child. Undefined on error or OEF
* @return
* 1 on success, 0 if EOF (no more children), < 0 on error
*/
int (*readdir)(IsoFileSource *src, IsoFileSource **child);
/**
*
*/
int (*readlink)(IsoFileSource *src, char *buf, size_t bufsiz);
};
#endif /*LIBISO_FSOURCE_H_*/

View File

@ -8,12 +8,33 @@
#ifndef LIBISO_LIBISOFS_H_ #ifndef LIBISO_LIBISOFS_H_
#define LIBISO_LIBISOFS_H_ #define LIBISO_LIBISOFS_H_
typedef struct Iso_Tree_Node IsoTreeNode; typedef struct Iso_Node IsoNode;
typedef struct Iso_Dir IsoDir;
/** /**
* Increments the reference counting of the given node. * Increments the reference counting of the given node.
*/ */
void iso_node_ref(IsoTreeNode *node); void iso_node_ref(IsoNode *node);
/**
* Decrements the reference couting of the given node.
* If it reach 0, the node is free, and, if the node is a directory,
* its children will be unref() too.
*/
void iso_node_unref(IsoNode *node);
/**
* Set the name of a node.
*
* @param name The name in UTF-8 encoding
*/
void iso_node_set_name(IsoNode *node, const char *name);
/**
* Get the name of a node (in UTF-8).
* The returned string belongs to the node and should not be modified nor
* freed. Use strdup if you really need your own copy.
*/
const char *iso_node_get_name(IsoNode *node);
#endif /*LIBISO_LIBISOFS_H_*/ #endif /*LIBISO_LIBISOFS_H_*/

56
src/node.c Normal file
View File

@ -0,0 +1,56 @@
/*
* Copyright (c) 2007 Vreixo Formoso
*
* This file is part of the libisofs project; 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. See COPYING file for details.
*/
#include "node.h"
#include "libisofs.h"
#include <stdlib.h>
#include <string.h>
/**
* Increments the reference counting of the given node.
*/
void iso_node_ref(IsoNode *node)
{
++node->refcount;
}
/**
* Decrements the reference couting of the given node.
* If it reach 0, the node is free, and, if the node is a directory,
* its children will be unref() too.
*/
void iso_node_unref(IsoNode *node)
{
if (--node->refcount == 0) {
/* TODO #00002 handle deletion of each kind of node */
free(node->name);
free(node);
}
}
/**
* Set the name of a node.
*
* @param name The name in UTF-8 encoding
*/
void iso_node_set_name(IsoNode *node, const char *name)
{
free(node->name);
node->name = strdup(name);
}
/**
* Get the name of a node (in UTF-8).
* The returned string belongs to the node and should not be modified nor
* freed. Use strdup if you really need your own copy.
*/
const char *iso_node_get_name(IsoNode *node)
{
return node->name;
}

View File

@ -5,8 +5,8 @@
* modify it under the terms of the GNU General Public License version 2 as * modify it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation. See COPYING file for details. * published by the Free Software Foundation. See COPYING file for details.
*/ */
#ifndef LIBISO_TREE_H_ #ifndef LIBISO_NODE_H_
#define LIBISO_TREE_H_ #define LIBISO_NODE_H_
/* /*
* Definitions for the public iso tree * Definitions for the public iso tree
@ -19,9 +19,9 @@
#include <unistd.h> #include <unistd.h>
/** /**
* The type of an IsoTreeNode. * The type of an IsoNode.
*/ */
enum IsoTreeNodeType { enum IsoNodeType {
LIBISO_DIR, LIBISO_DIR,
LIBISO_FILE, LIBISO_FILE,
LIBISO_SYMLINK, LIBISO_SYMLINK,
@ -32,18 +32,19 @@ enum IsoTreeNodeType {
/** /**
* *
*/ */
struct Iso_Tree_Node { struct Iso_Node
{
/* /*
* Initilized to 1, originally owned by user, until added to another node. * Initilized to 1, originally owned by user, until added to another node.
* Then it is owned by the parent node, so the user must take his own ref * Then it is owned by the parent node, so the user must take his own ref
* if needed. With the exception of the creation functions, none of the * if needed. With the exception of the creation functions, none of the
* other libisofs functions that return an IsoTreeNode increment its * other libisofs functions that return an IsoNode increment its
* refcount. This is responsablity of the client, if (s)he needs it. * refcount. This is responsablity of the client, if (s)he needs it.
*/ */
int refcount; int refcount;
/**< Type of the IsoTreeNode, do not confuse with mode */ /**< Type of the IsoNode, do not confuse with mode */
enum IsoTreeNodeType type; enum IsoNodeType type;
char *name; /**< Real name, supossed to be in UTF-8 */ char *name; /**< Real name, supossed to be in UTF-8 */
@ -63,18 +64,29 @@ struct Iso_Tree_Node {
* It is a circular list where the last child points to the first * It is a circular list where the last child points to the first
* and viceversa. * and viceversa.
*/ */
IsoTreeNode *prev; IsoNode *prev;
IsoTreeNode *next; IsoNode *next;
}; };
struct IsoDir { struct Iso_Dir
IsoTreeNode node; {
IsoNode node;
size_t nchildren; /**< The number of children of this directory. */ size_t nchildren; /**< The number of children of this directory. */
struct IsoTreeNode *children; /**< list of children. ptr to first child */ struct IsoNode *children; /**< list of children. ptr to first child */
}; };
//void iso_node_unref(IsoTreeNode *node); struct Iso_File
{
IsoNode node;
/**
* It sorts the order in which the file data is written to the CD image.
* Higher weighting filesare written at the beginning of image
*/
int sort_weight;
};
#endif /*TREE_H_*/ #endif /*LIBISO_NODE_H_*/

44
src/stream.h Normal file
View File

@ -0,0 +1,44 @@
/*
* Copyright (c) 2007 Vreixo Formoso
*
* This file is part of the libisofs project; 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. See COPYING file for details.
*/
#ifndef LIBISO_STREAM_H_
#define LIBISO_STREAM_H_
/*
* Definitions of streams.
*/
/*
* Some functions here will be moved to libisofs.h when we expose
* Streams.
*/
typedef struct Iso_Stream IsoStream;
struct Iso_Stream
{
/**
* Opens the stream.
* @return 1 on success, < 0 on error
*/
int (*open)(IsoStream *stream);
/**
* Close the Stream.
*/
void (*close)(IsoStream *stream);
// Stream should read in 2k blocks!
//...
int refcount;
}
#endif /*STREAM_H_*/

View File

@ -11,6 +11,6 @@
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
IsoTreeNode *node; IsoNode *node;
} }