2001-07-04 06:02:36 +02:00
|
|
|
/* $OpenBSD: misc.h,v 1.9 2001/06/26 06:32:56 itojun Exp $ */
|
2001-01-29 08:39:26 +01:00
|
|
|
|
2001-01-22 06:34:40 +01:00
|
|
|
/*
|
|
|
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
|
|
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
|
|
|
* All rights reserved
|
|
|
|
*
|
|
|
|
* As far as I am concerned, the code I have written for this software
|
|
|
|
* can be used freely for any purpose. Any derived versions of this
|
|
|
|
* software must be clearly marked as such, and if the derived work is
|
|
|
|
* incompatible with the protocol description in the RFC file, it must be
|
|
|
|
* called by a name other than "ssh" or "Secure Shell".
|
|
|
|
*/
|
|
|
|
/* remove newline at end of string */
|
2001-07-04 06:02:36 +02:00
|
|
|
char *chop(char *);
|
2001-01-22 06:34:40 +01:00
|
|
|
|
|
|
|
/* return next token in configuration line */
|
2001-07-04 06:02:36 +02:00
|
|
|
char *strdelim(char **);
|
2001-01-22 06:34:40 +01:00
|
|
|
|
2001-05-12 02:08:37 +02:00
|
|
|
/* set/unset filedescriptor to non-blocking */
|
2001-07-04 06:02:36 +02:00
|
|
|
void set_nonblock(int);
|
|
|
|
void unset_nonblock(int);
|
2001-02-04 14:20:36 +01:00
|
|
|
|
2001-07-04 06:02:36 +02:00
|
|
|
struct passwd * pwcopy(struct passwd *);
|
2001-03-05 06:56:40 +01:00
|
|
|
|
2001-04-13 01:39:26 +02:00
|
|
|
/*
|
|
|
|
* Convert ASCII string to TCP/IP port number.
|
|
|
|
* Port must be >0 and <=65535.
|
|
|
|
* Return 0 if invalid.
|
|
|
|
*/
|
2001-07-04 06:02:36 +02:00
|
|
|
int a2port(const char *);
|
2001-05-08 22:27:25 +02:00
|
|
|
|
2001-05-04 01:39:53 +02:00
|
|
|
/* code from scp.c/rcp.c */
|
2001-07-04 06:02:36 +02:00
|
|
|
char *cleanhostname(char *);
|
|
|
|
char *colon(char *);
|
2001-04-13 01:39:26 +02:00
|
|
|
|
2001-06-05 21:59:08 +02:00
|
|
|
/*
|
|
|
|
* Convert a time string into seconds; format is
|
|
|
|
* a sequence of:
|
|
|
|
* time[qualifier]
|
|
|
|
*
|
|
|
|
* Valid time qualifiers are:
|
|
|
|
* <none> seconds
|
|
|
|
* s|S seconds
|
|
|
|
* m|M minutes
|
|
|
|
* h|H hours
|
|
|
|
* d|D days
|
|
|
|
* w|W weeks
|
|
|
|
*
|
|
|
|
* Examples:
|
|
|
|
* 90m 90 minutes
|
|
|
|
* 1h30m 90 minutes
|
|
|
|
* 2d 2 days
|
|
|
|
* 1w 1 week
|
|
|
|
*
|
|
|
|
* Return -1 if time string is invalid.
|
|
|
|
*/
|
|
|
|
|
2001-07-04 06:02:36 +02:00
|
|
|
long convtime(const char *);
|
2001-06-05 21:59:08 +02:00
|
|
|
|
2001-05-08 22:27:25 +02:00
|
|
|
/* function to assist building execv() arguments */
|
|
|
|
typedef struct arglist arglist;
|
|
|
|
struct arglist {
|
|
|
|
char **list;
|
|
|
|
int num;
|
|
|
|
int nalloc;
|
|
|
|
};
|
|
|
|
|
2001-07-04 06:02:36 +02:00
|
|
|
void addargs(arglist *, char *, ...) __attribute__((format(printf, 2, 3)));
|
2001-05-08 22:27:25 +02:00
|
|
|
|
2001-02-04 14:20:36 +01:00
|
|
|
/* wrapper for signal interface */
|
|
|
|
typedef void (*mysig_t)(int);
|
|
|
|
mysig_t mysignal(int sig, mysig_t act);
|