]> git.sur5r.net Git - bacula/bacula/blobdiff - bacula/src/dird/ua.h
Add new files
[bacula/bacula] / bacula / src / dird / ua.h
index 98c53dfceace4c8b8d18754376b838adb754c3ef..d63e949f90ade1c64a1ef9ecd917755ff853b71c 100644 (file)
@@ -6,7 +6,7 @@
  *     Version $Id$
  */
 /*
-   Copyright (C) 2000, 2001, 2002 Kern Sibbald and John Walker
+   Copyright (C) 2000-2003 Kern Sibbald and John Walker
 
    This program is free software; you can redistribute it and/or
    modify it under the terms of the GNU General Public License as
 
  */
 
-#define MAX_ARGS 30
+#ifndef __UA_H_
+#define __UA_H_ 1
 
-typedef struct s_ua_context {
+
+struct UAContext {
    BSOCK *UA_sock;
    BSOCK *sd;
    JCR *jcr;
@@ -35,8 +37,8 @@ typedef struct s_ua_context {
    CAT *catalog;
    POOLMEM *cmd;                     /* return command/name buffer */
    POOLMEM *args;                    /* command line arguments */
-   char *argk[MAX_ARGS];             /* argument keywords */
-   char *argv[MAX_ARGS];             /* argument values */
+   char *argk[MAX_CMD_ARGS];         /* argument keywords */
+   char *argv[MAX_CMD_ARGS];         /* argument values */
    int argc;                         /* number of arguments */
    char **prompt;                    /* list of prompts */
    int max_prompts;                  /* max size of list */
@@ -46,53 +48,18 @@ typedef struct s_ua_context {
    int automount;                    /* if set, mount after label */
    int quit;                         /* if set, quit */
    int verbose;                      /* set for normal UA verbosity */
-} UAContext;
-
-/* ua_cmds.c */
-int do_a_command(UAContext *ua, char *cmd);
-int do_a_dot_command(UAContext *ua, char *cmd);
-int qmessagescmd(UAContext *ua, char *cmd);
-int open_db(UAContext *ua);
-void close_db(UAContext *ua);
-
-/* ua_input.c */
-char *next_arg(char **s);
-int get_cmd(UAContext *ua, char *prompt);
-void parse_command_args(UAContext *ua);
-
-/* ua_output.c */
-void prtit(void *ctx, char *msg);
-
-/* ua_server.c */
-void bsendmsg(void *sock, char *fmt, ...);
-
-/* ua_select.c */
-STORE  *select_storage_resource(UAContext *ua);
-JOB    *select_job_resource(UAContext *ua);
-JOB    *select_restore_job_resource(UAContext *ua);
-CLIENT *select_client_resource(UAContext *ua);
-FILESET *select_fileset_resource(UAContext *ua);
-int    select_pool_and_media_dbr(UAContext *ua, POOL_DBR *pr, MEDIA_DBR *mr);
-int    select_pool_dbr(UAContext *ua, POOL_DBR *pr);
-int    select_client_dbr(UAContext *ua, CLIENT_DBR *cr);
+   uint32_t pint32_val;              /* positive integer */
+   int32_t  int32_val;               /* positive/negative */
+};         
 
-void   start_prompt(UAContext *ua, char *msg);
-void   add_prompt(UAContext *ua, char *prompt);
-int    do_prompt(UAContext *ua, char *msg, char *prompt, int max_prompt);
-CAT    *get_catalog_resource(UAContext *ua);          
-STORE  *get_storage_resource(UAContext *ua, char *cmd);
-int    get_media_type(UAContext *ua, char *MediaType, int max_media);
-int    get_pool_dbr(UAContext *ua, POOL_DBR *pr);
-int    get_client_dbr(UAContext *ua, CLIENT_DBR *cr);
-POOL   *get_pool_resource(UAContext *ua);
-CLIENT *get_client_resource(UAContext *ua);
-int    get_job_dbr(UAContext *ua, JOB_DBR *jr);
+/* Context for insert_tree_handler() */
+struct TREE_CTX {
+   TREE_ROOT *root;                  /* root */
+   TREE_NODE *node;                  /* current node */
+   TREE_NODE *avail_node;            /* unused node last insert */
+   int cnt;                          /* count for user feedback */
+   UAContext *ua;
+};
 
-int find_arg_keyword(UAContext *ua, char **list);
-int do_keyword_prompt(UAContext *ua, char *msg, char **list);
-int confirm_retention(UAContext *ua, utime_t *ret, char *msg);
 
-/* ua_prune.c */
-int prune_files(UAContext *ua, CLIENT *client);
-int prune_jobs(UAContext *ua, CLIENT *client, int JobType);
-int prune_volume(UAContext *ua, POOL_DBR *pr, MEDIA_DBR *mr);
+#endif