/* bsys.c */
char *bstrncpy (char *dest, const char *src, int maxlen);
char *bstrncat (char *dest, const char *src, int maxlen);
-void *b_malloc (char *file, int line, size_t size);
+void *b_malloc (const char *file, int line, size_t size);
#ifndef DEBUG
void *bmalloc (size_t size);
#endif
void *brealloc (void *buf, size_t size);
void *bcalloc (size_t size1, size_t size2);
-int bsnprintf (char *str, size_t size, const char *format, ...);
-int bvsnprintf (char *str, size_t size, const char *format, va_list ap);
-int pool_sprintf (char *pool_buf, char *fmt, ...);
-void create_pid_file (char *dir, char *progname, int port);
-int delete_pid_file (char *dir, char *progname, int port);
+int bsnprintf (char *str, int32_t size, const char *format, ...);
+int bvsnprintf (char *str, int32_t size, const char *format, va_list ap);
+int pool_sprintf (char *pool_buf, const char *fmt, ...);
+void create_pid_file (char *dir, const char *progname, int port);
+int delete_pid_file (char *dir, const char *progname, int port);
void drop (char *uid, char *gid);
-int bmicrosleep (time_t sec, long msec);
+int bmicrosleep (time_t sec, long usec);
char *bfgets (char *s, int size, FILE *fd);
+void make_unique_filename (POOLMEM **name, int Id, char *what);
#ifndef HAVE_STRTOLL
long long int strtoll (const char *ptr, char **endptr, int base);
#endif
+void read_state_file(char *dir, const char *progname, int port);
/* bnet.c */
int32_t bnet_recv (BSOCK *bsock);
int bnet_send (BSOCK *bsock);
-int bnet_fsend (BSOCK *bs, char *fmt, ...);
+int bnet_fsend (BSOCK *bs, const char *fmt, ...);
int bnet_set_buffer_size (BSOCK *bs, uint32_t size, int rw);
int bnet_sig (BSOCK *bs, int sig);
int bnet_ssl_server (BSOCK *bsock, char *password, int ssl_need, int ssl_has);
int bnet_ssl_client (BSOCK *bsock, char *password, int ssl_need);
BSOCK * bnet_connect (JCR *jcr, int retry_interval,
- int max_retry_time, char *name, char *host, char *service,
+ int max_retry_time, const char *name, char *host, char *service,
int port, int verbose);
void bnet_close (BSOCK *bsock);
-BSOCK * init_bsock (JCR *jcr, int sockfd, char *who, char *ip, int port);
+BSOCK * init_bsock (JCR *jcr, int sockfd, const char *who, char *ip,
+ int port, struct sockaddr_in *client_addr);
BSOCK * dup_bsock (BSOCK *bsock);
void term_bsock (BSOCK *bsock);
char * bnet_strerror (BSOCK *bsock);
char * bnet_sig_to_ascii (BSOCK *bsock);
int bnet_wait_data (BSOCK *bsock, int sec);
int bnet_wait_data_intr (BSOCK *bsock, int sec);
-int bnet_despool (BSOCK *bsock);
+int bnet_despool_to_bsock (BSOCK *bsock);
int is_bnet_stop (BSOCK *bsock);
int is_bnet_error (BSOCK *bsock);
void bnet_suppress_error_messages(BSOCK *bsock, int flag);
int bget_msg(BSOCK *sock);
/* bpipe.c */
-BPIPE * open_bpipe(char *prog, int wait, char *mode);
+BPIPE * open_bpipe(char *prog, int wait, const char *mode);
int close_wpipe(BPIPE *bpipe);
int close_bpipe(BPIPE *bpipe);
char *edit_utime (utime_t val, char *buf);
int is_a_number (const char *num);
int is_an_integer (const char *n);
+bool is_name_valid (char *name, POOLMEM **msg);
+
+/* jcr.c (most definitions are in src/jcr.h) */
+void init_last_jobs_list();
+void term_last_jobs_list();
+void lock_last_jobs_list();
+void unlock_last_jobs_list();
+void read_last_jobs_list(int fd, uint64_t addr);
+uint64_t write_last_jobs_list(int fd, uint64_t addr);
+void write_state_file(char *dir, const char *progname, int port);
+void job_end_push(JCR *jcr, void job_end_cb(JCR *jcr));
+
/* lex.c */
LEX * lex_close_file (LEX *lf);
LEX * lex_open_file (LEX *lf, char *fname, LEX_ERROR_HANDLER *scan_error);
int lex_get_char (LEX *lf);
void lex_unget_char (LEX *lf);
-char * lex_tok_to_str (int token);
+const char * lex_tok_to_str (int token);
int lex_get_token (LEX *lf, int expect);
/* message.c */
-void my_name_is (int argc, char *argv[], char *name);
+void my_name_is (int argc, char *argv[], const char *name);
void init_msg (JCR *jcr, MSGS *msg);
void term_msg (void);
void close_msg (JCR *jcr);
void add_msg_dest (MSGS *msg, int dest, int type, char *where, char *dest_code);
void rem_msg_dest (MSGS *msg, int dest, int type, char *where);
-void Jmsg (JCR *jcr, int type, int level, char *fmt, ...);
+void Jmsg (JCR *jcr, int type, int level, const char *fmt, ...);
void dispatch_message (JCR *jcr, int type, int level, char *buf);
void init_console_msg (char *wd);
void free_msgs_res (MSGS *msgs);
int open_spool_file (JCR *jcr, BSOCK *bs);
int close_spool_file (JCR *jcr, BSOCK *bs);
+void dequeue_messages (JCR *jcr);
+void set_trace (int trace_flag);
/* bnet_server.c */
void bnet_thread_server(char *bind_addr, int port, int max_clients, workq_t *client_wq,
void *handle_client_request(void *bsock));
+void bnet_stop_thread_server(pthread_t tid);
void bnet_server (int port, void handle_client_request(BSOCK *bsock));
int net_connect (int port);
BSOCK * bnet_bind (int port);
BSOCK * bnet_accept (BSOCK *bsock, char *who);
+/* idcache.c */
+char *getuser(uid_t uid);
+void free_getuser_cache();
+char *getgroup (gid_t gid);
+void free_getgroup_cache();
+
+
/* signal.c */
void init_signals (void terminate(int sig));
void init_stack_dump (void);
/* scan.c */
void strip_trailing_junk (char *str);
void strip_trailing_slashes (char *dir);
-int skip_spaces (char **msg);
-int skip_nonspaces (char **msg);
+bool skip_spaces (char **msg);
+bool skip_nonspaces (char **msg);
int fstrsch (char *a, char *b);
-int parse_args(POOLMEM *cmd, POOLMEM *args, int *argc,
+int parse_args(POOLMEM *cmd, POOLMEM **args, int *argc,
char **argk, char **argv, int max_args);
char *next_arg(char **s);
char * encode_mode (mode_t mode, char *buf);
int do_shell_expansion (char *name, int name_len);
void jobstatus_to_ascii (int JobStatus, char *msg, int maxlen);
-void pm_strcat (POOLMEM **pm, char *str);
-void pm_strcpy (POOLMEM **pm, char *str);
+int pm_strcat (POOLMEM **pm, const char *str);
+int pm_strcpy (POOLMEM **pm, const char *str);
int run_program (char *prog, int wait, POOLMEM *results);
char * job_type_to_str (int type);
char * job_status_to_str (int stat);
char * job_level_to_str (int level);
void make_session_key (char *key, char *seed, int mode);
-POOLMEM *edit_job_codes(JCR *jcr, char *omsg, char *imsg, char *to);
+POOLMEM *edit_job_codes(JCR *jcr, char *omsg, char *imsg, const char *to);
void set_working_directory(char *wd);
/* watchdog.c */
int start_watchdog(void);
int stop_watchdog(void);
+watchdog_t *new_watchdog(void);
+bool register_watchdog(watchdog_t *wd);
+bool unregister_watchdog(watchdog_t *wd);
+bool unregister_watchdog_unlocked(watchdog_t *wd);
+
+/* timers.c */
btimer_t *start_child_timer(pid_t pid, uint32_t wait);
-void stop_child_timer(btimer_id wid);
-btimer_id start_thread_timer(pthread_t tid, uint32_t wait);
-void stop_thread_timer(btimer_id wid);
+void stop_child_timer(btimer_t *wid);
+btimer_t *start_thread_timer(pthread_t tid, uint32_t wait);
+void stop_thread_timer(btimer_t *wid);
+btimer_t *start_bsock_timer(BSOCK *bs, uint32_t wait);
+void stop_bsock_timer(btimer_t *wid);