Imported Upstream version 3.3.3
[debian/amanda] / server-src / tapefile.h
1 /*
2  * Amanda, The Advanced Maryland Automatic Network Disk Archiver
3  * Copyright (c) 1991-1998 University of Maryland at College Park
4  * Copyright (c) 2007-2012 Zmanda, Inc.  All Rights Reserved.
5  * All Rights Reserved.
6  *
7  * Permission to use, copy, modify, distribute, and sell this software and its
8  * documentation for any purpose is hereby granted without fee, provided that
9  * the above copyright notice appear in all copies and that both that
10  * copyright notice and this permission notice appear in supporting
11  * documentation, and that the name of U.M. not be used in advertising or
12  * publicity pertaining to distribution of the software without specific,
13  * written prior permission.  U.M. makes no representations about the
14  * suitability of this software for any purpose.  It is provided "as is"
15  * without express or implied warranty.
16  *
17  * U.M. DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL
18  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL U.M.
19  * BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
20  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
21  * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
22  * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
23  *
24  * Author: James da Silva, Systems Design and Analysis Group
25  *                         Computer Science Department
26  *                         University of Maryland at College Park
27  */
28 /*
29  * $Id: tapefile.h,v 1.9 2006/05/25 01:47:20 johnfranks Exp $
30  *
31  * interface for active tape list manipulation routines
32  */
33 #ifndef TAPEFILE_H
34 #define TAPEFILE_H
35
36 #include "amanda.h"
37
38 typedef struct tape_s {
39     struct tape_s *next, *prev;
40     int position;
41     char * datestamp;
42     int reuse;
43     char *label;
44     char *barcode;
45     char *meta;
46     guint64 blocksize;
47     char *comment;
48 } tape_t;
49
50 int read_tapelist(char *tapefile);
51 int write_tapelist(char *tapefile);
52 void clear_tapelist(void);
53 tape_t *lookup_tapelabel(const char *label);
54 tape_t *lookup_tapepos(int pos);
55 tape_t *lookup_tapedate(char *datestamp);
56 int lookup_nb_tape(void);
57 char *get_last_reusable_tape_label(int skip);
58 tape_t *lookup_last_reusable_tape(int skip);
59 void remove_tapelabel(char *label);
60 tape_t *add_tapelabel(char *datestamp, char *label, char *comment);
61 int reusable_tape(tape_t *tp);
62
63 int guess_runs_from_tapelist(void);
64 char *list_new_tapes(int nb);
65 void print_new_tapes(FILE *output, int nb);
66
67 #endif /* !TAPEFILE_H */