/* * This file Copyright (C) 2007-2014 Mnemosyne LLC * * It may be used under the GNU Public License v2 or v3 licenses, * or any future license endorsed by Mnemosyne LLC. * * $Id$ */ #ifndef TR_MAKEMETA_H #define TR_MAKEMETA_H 1 #ifdef __cplusplus extern "C" { #endif typedef struct tr_metainfo_builder_file { char * filename; uint64_t size; } tr_metainfo_builder_file; typedef enum { TR_MAKEMETA_OK, TR_MAKEMETA_URL, TR_MAKEMETA_CANCELLED, TR_MAKEMETA_IO_READ, /* see builder.errfile, builder.my_errno */ TR_MAKEMETA_IO_WRITE /* see builder.errfile, builder.my_errno */ } tr_metainfo_builder_err; typedef struct tr_metainfo_builder { /** *** These are set by tr_makeMetaInfoBuilderCreate () *** and cleaned up by tr_metaInfoBuilderFree () **/ char * top; tr_metainfo_builder_file * files; uint64_t totalSize; uint32_t fileCount; uint32_t pieceSize; uint32_t pieceCount; int isSingleFile; /** *** These are set inside tr_makeMetaInfo () *** by copying the arguments passed to it, *** and cleaned up by tr_metaInfoBuilderFree () **/ tr_tracker_info * trackers; int trackerCount; char * comment; char * outputFile; bool isPrivate; /** *** These are set inside tr_makeMetaInfo () so the client *** can poll periodically to see what the status is. *** The client can also set abortFlag to nonzero to *** tell tr_makeMetaInfo () to abort and clean up after itself. **/ uint32_t pieceIndex; bool abortFlag; bool isDone; tr_metainfo_builder_err result; /* file in use when result was set to _IO_READ or _IO_WRITE, * or the URL in use when the result was set to _URL */ char errfile[2048]; /* errno encountered when result was set to _IO_READ or _IO_WRITE */ int my_errno; /** *** This is an implementation detail. *** The client should never use these fields. **/ struct tr_metainfo_builder * nextBuilder; } tr_metainfo_builder; tr_metainfo_builder * tr_metaInfoBuilderCreate (const char * topFile); /** * Call this before tr_makeMetaInfo() to override the builder.pieceSize * and builder.pieceCount values that were set by tr_metainfoBuilderCreate() */ void tr_metaInfoBuilderSetPieceSize (tr_metainfo_builder * builder, uint32_t bytes); void tr_metaInfoBuilderFree (tr_metainfo_builder*); /** * @brief create a new .torrent file * * This is actually done in a worker thread, not the main thread! * Otherwise the client's interface would lock up while this runs. * * It is the caller's responsibility to poll builder->isDone * from time to time! When the worker thread sets that flag, * the caller must pass the builder to tr_metaInfoBuilderFree (). * * @param outputFile if NULL, builder->top + ".torrent" will be used. * @param trackers An array of trackers, sorted by tier from first to last. * NOTE: only the `tier' and `announce' fields are used. * * @param trackerCount size of the `trackers' array */ void tr_makeMetaInfo (tr_metainfo_builder * builder, const char * outputFile, const tr_tracker_info * trackers, int trackerCount, const char * comment, bool isPrivate); #ifdef __cplusplus } #endif #endif