sync code with last improvements from OpenBSD
This commit is contained in:
parent
a959d2beea
commit
3252c81e6b
39
bin/ls/ls.c
39
bin/ls/ls.c
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: ls.c,v 1.54 2020/10/07 21:03:09 millert Exp $ */
|
/* $OpenBSD: ls.c,v 1.56 2023/10/07 13:29:08 schwarze Exp $ */
|
||||||
/* $NetBSD: ls.c,v 1.18 1996/07/09 09:16:29 mycroft Exp $ */
|
/* $NetBSD: ls.c,v 1.18 1996/07/09 09:16:29 mycroft Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -436,12 +436,12 @@ display(FTSENT *p, FTSENT *list)
|
|||||||
unsigned long long btotal;
|
unsigned long long btotal;
|
||||||
blkcnt_t maxblock;
|
blkcnt_t maxblock;
|
||||||
ino_t maxinode;
|
ino_t maxinode;
|
||||||
|
unsigned int maxmajor, maxminor;
|
||||||
int bcfile, flen, glen, ulen, maxflags, maxgroup, maxuser, maxlen;
|
int bcfile, flen, glen, ulen, maxflags, maxgroup, maxuser, maxlen;
|
||||||
int entries, needstats;
|
int entries, needstats;
|
||||||
int width;
|
int width;
|
||||||
const char *user, *group;
|
const char *user, *group;
|
||||||
char nuser[12], ngroup[12];
|
char nuser[12], ngroup[12];
|
||||||
char buf[21]; /* 64 bits == 20 digits */
|
|
||||||
char *flags = NULL;
|
char *flags = NULL;
|
||||||
|
|
||||||
needstats = f_inode || f_longform || f_size;
|
needstats = f_inode || f_longform || f_size;
|
||||||
@ -449,6 +449,7 @@ display(FTSENT *p, FTSENT *list)
|
|||||||
btotal = maxblock = maxinode = maxlen = maxnlink = 0;
|
btotal = maxblock = maxinode = maxlen = maxnlink = 0;
|
||||||
bcfile = 0;
|
bcfile = 0;
|
||||||
maxuser = maxgroup = maxflags = 0;
|
maxuser = maxgroup = maxflags = 0;
|
||||||
|
maxmajor = maxminor = 0;
|
||||||
maxsize = 0;
|
maxsize = 0;
|
||||||
for (cur = list, entries = 0; cur != NULL; cur = cur->fts_link) {
|
for (cur = list, entries = 0; cur != NULL; cur = cur->fts_link) {
|
||||||
if (cur->fts_info == FTS_ERR || cur->fts_info == FTS_NS) {
|
if (cur->fts_info == FTS_ERR || cur->fts_info == FTS_NS) {
|
||||||
@ -523,9 +524,13 @@ display(FTSENT *p, FTSENT *list)
|
|||||||
(void)strlcpy(np->group, group, glen + 1);
|
(void)strlcpy(np->group, group, glen + 1);
|
||||||
|
|
||||||
if (S_ISCHR(sp->st_mode) ||
|
if (S_ISCHR(sp->st_mode) ||
|
||||||
S_ISBLK(sp->st_mode))
|
S_ISBLK(sp->st_mode)) {
|
||||||
bcfile = 1;
|
bcfile = 1;
|
||||||
|
if (maxmajor < major(sp->st_rdev))
|
||||||
|
maxmajor = major(sp->st_rdev);
|
||||||
|
if (maxminor < minor(sp->st_rdev))
|
||||||
|
maxminor = minor(sp->st_rdev);
|
||||||
|
}
|
||||||
if (f_flags) {
|
if (f_flags) {
|
||||||
np->flags = &np->data[ulen + 1 + glen + 1];
|
np->flags = &np->data[ulen + 1 + glen + 1];
|
||||||
(void)strlcpy(np->flags, flags, flen + 1);
|
(void)strlcpy(np->flags, flags, flen + 1);
|
||||||
@ -551,25 +556,29 @@ display(FTSENT *p, FTSENT *list)
|
|||||||
d.entries = entries;
|
d.entries = entries;
|
||||||
d.maxlen = maxlen;
|
d.maxlen = maxlen;
|
||||||
if (needstats) {
|
if (needstats) {
|
||||||
d.bcfile = bcfile;
|
|
||||||
d.btotal = btotal;
|
d.btotal = btotal;
|
||||||
(void)snprintf(buf, sizeof(buf), "%llu",
|
d.s_block = snprintf(NULL, 0, "%llu",
|
||||||
(unsigned long long)maxblock);
|
(unsigned long long)maxblock);
|
||||||
d.s_block = strlen(buf);
|
|
||||||
d.s_flags = maxflags;
|
d.s_flags = maxflags;
|
||||||
d.s_group = maxgroup;
|
d.s_group = maxgroup;
|
||||||
(void)snprintf(buf, sizeof(buf), "%llu",
|
d.s_inode = snprintf(NULL, 0, "%llu",
|
||||||
(unsigned long long)maxinode);
|
(unsigned long long)maxinode);
|
||||||
d.s_inode = strlen(buf);
|
d.s_nlink = snprintf(NULL, 0, "%lu",
|
||||||
(void)snprintf(buf, sizeof(buf), "%lu",
|
|
||||||
(unsigned long)maxnlink);
|
(unsigned long)maxnlink);
|
||||||
d.s_nlink = strlen(buf);
|
if (!f_humanval)
|
||||||
if (!f_humanval) {
|
d.s_size = snprintf(NULL, 0, "%lld",
|
||||||
(void)snprintf(buf, sizeof(buf), "%lld",
|
|
||||||
(long long)maxsize);
|
(long long)maxsize);
|
||||||
d.s_size = strlen(buf);
|
else
|
||||||
} else
|
|
||||||
d.s_size = FMT_SCALED_STRSIZE-2; /* no - or '\0' */
|
d.s_size = FMT_SCALED_STRSIZE-2; /* no - or '\0' */
|
||||||
|
d.s_major = d.s_minor = 3;
|
||||||
|
if (bcfile) {
|
||||||
|
d.s_major = snprintf(NULL, 0, "%u", maxmajor);
|
||||||
|
d.s_minor = snprintf(NULL, 0, "%u", maxminor);
|
||||||
|
if (d.s_size <= d.s_major + 2 + d.s_minor)
|
||||||
|
d.s_size = d.s_major + 2 + d.s_minor;
|
||||||
|
else
|
||||||
|
d.s_major = d.s_size - 2 - d.s_minor;
|
||||||
|
}
|
||||||
d.s_user = maxuser;
|
d.s_user = maxuser;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: ls.h,v 1.9 2013/05/30 16:34:32 guenther Exp $ */
|
/* $OpenBSD: ls.h,v 1.10 2023/10/07 11:51:08 schwarze Exp $ */
|
||||||
/* $NetBSD: ls.h,v 1.7 1995/03/21 09:06:33 cgd Exp $ */
|
/* $NetBSD: ls.h,v 1.7 1995/03/21 09:06:33 cgd Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -55,7 +55,6 @@ extern int f_typedir; /* add type character for directories */
|
|||||||
typedef struct {
|
typedef struct {
|
||||||
FTSENT *list;
|
FTSENT *list;
|
||||||
unsigned long long btotal;
|
unsigned long long btotal;
|
||||||
int bcfile;
|
|
||||||
int entries;
|
int entries;
|
||||||
int maxlen;
|
int maxlen;
|
||||||
int s_block;
|
int s_block;
|
||||||
@ -64,6 +63,8 @@ typedef struct {
|
|||||||
int s_inode;
|
int s_inode;
|
||||||
int s_nlink;
|
int s_nlink;
|
||||||
int s_size;
|
int s_size;
|
||||||
|
int s_major;
|
||||||
|
int s_minor;
|
||||||
int s_user;
|
int s_user;
|
||||||
} DISPLAY;
|
} DISPLAY;
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: print.c,v 1.39 2020/10/07 21:03:09 millert Exp $ */
|
/* $OpenBSD: print.c,v 1.40 2023/10/07 11:51:08 schwarze Exp $ */
|
||||||
/* $NetBSD: print.c,v 1.15 1996/12/11 03:25:39 thorpej Exp $ */
|
/* $NetBSD: print.c,v 1.15 1996/12/11 03:25:39 thorpej Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -110,12 +110,9 @@ printlong(DISPLAY *dp)
|
|||||||
if (f_flags)
|
if (f_flags)
|
||||||
(void)printf("%-*s ", dp->s_flags, np->flags);
|
(void)printf("%-*s ", dp->s_flags, np->flags);
|
||||||
if (S_ISCHR(sp->st_mode) || S_ISBLK(sp->st_mode))
|
if (S_ISCHR(sp->st_mode) || S_ISBLK(sp->st_mode))
|
||||||
(void)printf("%3u, %3u ",
|
(void)printf("%*u, %*u ",
|
||||||
major(sp->st_rdev), minor(sp->st_rdev));
|
dp->s_major, major(sp->st_rdev),
|
||||||
else if (dp->bcfile)
|
dp->s_minor, minor(sp->st_rdev));
|
||||||
(void)printf("%*s%*lld ",
|
|
||||||
8 - dp->s_size, "", dp->s_size,
|
|
||||||
(long long)sp->st_size);
|
|
||||||
else
|
else
|
||||||
printsize(dp->s_size, sp->st_size);
|
printsize(dp->s_size, sp->st_size);
|
||||||
if (f_accesstime)
|
if (f_accesstime)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: fvwrite.c,v 1.20 2017/03/17 16:06:33 millert Exp $ */
|
/* $OpenBSD: fvwrite.c,v 1.21 2023/10/06 16:41:02 millert Exp $ */
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1990, 1993
|
* Copyright (c) 1990, 1993
|
||||||
* The Regents of the University of California. All rights reserved.
|
* The Regents of the University of California. All rights reserved.
|
||||||
@ -34,7 +34,6 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <errno.h>
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include "local.h"
|
#include "local.h"
|
||||||
#include "fvwrite.h"
|
#include "fvwrite.h"
|
||||||
@ -58,10 +57,8 @@ __sfvwrite(FILE *fp, struct __suio *uio)
|
|||||||
if ((len = uio->uio_resid) == 0)
|
if ((len = uio->uio_resid) == 0)
|
||||||
return (0);
|
return (0);
|
||||||
/* make sure we can write */
|
/* make sure we can write */
|
||||||
if (cantwrite(fp)) {
|
if (cantwrite(fp))
|
||||||
errno = EBADF;
|
|
||||||
return (EOF);
|
return (EOF);
|
||||||
}
|
|
||||||
|
|
||||||
#define MIN(a, b) ((a) < (b) ? (a) : (b))
|
#define MIN(a, b) ((a) < (b) ? (a) : (b))
|
||||||
#define COPY(n) (void)memcpy(fp->_p, p, n)
|
#define COPY(n) (void)memcpy(fp->_p, p, n)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: putc.c,v 1.13 2015/08/31 02:53:57 guenther Exp $ */
|
/* $OpenBSD: putc.c,v 1.14 2023/10/06 16:41:02 millert Exp $ */
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1990, 1993
|
* Copyright (c) 1990, 1993
|
||||||
* The Regents of the University of California. All rights reserved.
|
* The Regents of the University of California. All rights reserved.
|
||||||
@ -32,7 +32,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <errno.h>
|
|
||||||
#include "local.h"
|
#include "local.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -43,10 +42,8 @@
|
|||||||
int
|
int
|
||||||
putc_unlocked(int c, FILE *fp)
|
putc_unlocked(int c, FILE *fp)
|
||||||
{
|
{
|
||||||
if (cantwrite(fp)) {
|
if (cantwrite(fp))
|
||||||
errno = EBADF;
|
|
||||||
return (EOF);
|
return (EOF);
|
||||||
}
|
|
||||||
_SET_ORIENTATION(fp, -1);
|
_SET_ORIENTATION(fp, -1);
|
||||||
return (__sputc(c, fp));
|
return (__sputc(c, fp));
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: vfprintf.c,v 1.81 2021/09/08 15:57:27 jca Exp $ */
|
/* $OpenBSD: vfprintf.c,v 1.82 2023/10/06 16:41:02 millert Exp $ */
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1990 The Regents of the University of California.
|
* Copyright (c) 1990 The Regents of the University of California.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
@ -457,10 +457,8 @@ __vfprintf(FILE *fp, const char *fmt0, __va_list ap)
|
|||||||
|
|
||||||
_SET_ORIENTATION(fp, -1);
|
_SET_ORIENTATION(fp, -1);
|
||||||
/* sorry, fprintf(read_only_file, "") returns EOF, not 0 */
|
/* sorry, fprintf(read_only_file, "") returns EOF, not 0 */
|
||||||
if (cantwrite(fp)) {
|
if (cantwrite(fp))
|
||||||
errno = EBADF;
|
|
||||||
return (EOF);
|
return (EOF);
|
||||||
}
|
|
||||||
|
|
||||||
/* optimise fprintf(stderr) (and other unbuffered Unix files) */
|
/* optimise fprintf(stderr) (and other unbuffered Unix files) */
|
||||||
if ((fp->_flags & (__SNBF|__SWR|__SRW)) == (__SNBF|__SWR) &&
|
if ((fp->_flags & (__SNBF|__SWR|__SRW)) == (__SNBF|__SWR) &&
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: vfwprintf.c,v 1.22 2021/09/08 15:57:27 jca Exp $ */
|
/* $OpenBSD: vfwprintf.c,v 1.23 2023/10/06 16:41:02 millert Exp $ */
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1990 The Regents of the University of California.
|
* Copyright (c) 1990 The Regents of the University of California.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
@ -451,10 +451,8 @@ __vfwprintf(FILE * __restrict fp, const wchar_t * __restrict fmt0, __va_list ap)
|
|||||||
|
|
||||||
_SET_ORIENTATION(fp, 1);
|
_SET_ORIENTATION(fp, 1);
|
||||||
/* sorry, fwprintf(read_only_file, "") returns EOF, not 0 */
|
/* sorry, fwprintf(read_only_file, "") returns EOF, not 0 */
|
||||||
if (cantwrite(fp)) {
|
if (cantwrite(fp))
|
||||||
errno = EBADF;
|
|
||||||
return (EOF);
|
return (EOF);
|
||||||
}
|
|
||||||
|
|
||||||
/* optimise fwprintf(stderr) (and other unbuffered Unix files) */
|
/* optimise fwprintf(stderr) (and other unbuffered Unix files) */
|
||||||
if ((fp->_flags & (__SNBF|__SWR|__SRW)) == (__SNBF|__SWR) &&
|
if ((fp->_flags & (__SNBF|__SWR|__SRW)) == (__SNBF|__SWR) &&
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: wbuf.c,v 1.13 2015/08/31 02:53:57 guenther Exp $ */
|
/* $OpenBSD: wbuf.c,v 1.14 2023/10/06 16:41:02 millert Exp $ */
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1990, 1993
|
* Copyright (c) 1990, 1993
|
||||||
* The Regents of the University of California. All rights reserved.
|
* The Regents of the University of California. All rights reserved.
|
||||||
@ -32,7 +32,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <errno.h>
|
|
||||||
#include "local.h"
|
#include "local.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -54,10 +53,8 @@ __swbuf(int c, FILE *fp)
|
|||||||
* calls might wrap _w from negative to positive.
|
* calls might wrap _w from negative to positive.
|
||||||
*/
|
*/
|
||||||
fp->_w = fp->_lbfsize;
|
fp->_w = fp->_lbfsize;
|
||||||
if (cantwrite(fp)) {
|
if (cantwrite(fp))
|
||||||
errno = EBADF;
|
|
||||||
return (EOF);
|
return (EOF);
|
||||||
}
|
|
||||||
c = (unsigned char)c;
|
c = (unsigned char)c;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: wsetup.c,v 1.7 2005/08/08 08:05:36 espie Exp $ */
|
/* $OpenBSD: wsetup.c,v 1.8 2023/10/06 16:41:02 millert Exp $ */
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1990, 1993
|
* Copyright (c) 1990, 1993
|
||||||
* The Regents of the University of California. All rights reserved.
|
* The Regents of the University of California. All rights reserved.
|
||||||
@ -31,6 +31,7 @@
|
|||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include "local.h"
|
#include "local.h"
|
||||||
@ -38,7 +39,7 @@
|
|||||||
/*
|
/*
|
||||||
* Various output routines call wsetup to be sure it is safe to write,
|
* Various output routines call wsetup to be sure it is safe to write,
|
||||||
* because either _flags does not include __SWR, or _buf is NULL.
|
* because either _flags does not include __SWR, or _buf is NULL.
|
||||||
* _wsetup returns 0 if OK to write, nonzero otherwise.
|
* __swsetup returns 0 if OK to write, nonzero otherwise, setting errno.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
__swsetup(FILE *fp)
|
__swsetup(FILE *fp)
|
||||||
@ -51,8 +52,11 @@ __swsetup(FILE *fp)
|
|||||||
* If we are not writing, we had better be reading and writing.
|
* If we are not writing, we had better be reading and writing.
|
||||||
*/
|
*/
|
||||||
if ((fp->_flags & __SWR) == 0) {
|
if ((fp->_flags & __SWR) == 0) {
|
||||||
if ((fp->_flags & __SRW) == 0)
|
if ((fp->_flags & __SRW) == 0) {
|
||||||
|
errno = EBADF;
|
||||||
|
fp->_flags |= __SERR;
|
||||||
return (EOF);
|
return (EOF);
|
||||||
|
}
|
||||||
if (fp->_flags & __SRD) {
|
if (fp->_flags & __SRD) {
|
||||||
/* clobber any ungetc data */
|
/* clobber any ungetc data */
|
||||||
if (HASUB(fp))
|
if (HASUB(fp))
|
||||||
@ -68,8 +72,11 @@ __swsetup(FILE *fp)
|
|||||||
* Make a buffer if necessary, then set _w.
|
* Make a buffer if necessary, then set _w.
|
||||||
*/
|
*/
|
||||||
if (fp->_bf._base == NULL) {
|
if (fp->_bf._base == NULL) {
|
||||||
if ((fp->_flags & (__SSTR | __SALC)) == __SSTR)
|
if ((fp->_flags & (__SSTR | __SALC)) == __SSTR) {
|
||||||
|
errno = EINVAL;
|
||||||
|
fp->_flags |= __SERR;
|
||||||
return (EOF);
|
return (EOF);
|
||||||
|
}
|
||||||
__smakebuf(fp);
|
__smakebuf(fp);
|
||||||
}
|
}
|
||||||
if (fp->_flags & __SLBF) {
|
if (fp->_flags & __SLBF) {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $OpenBSD: agent-pkcs11.sh,v 1.9 2021/07/25 12:13:03 dtucker Exp $
|
# $OpenBSD: agent-pkcs11.sh,v 1.11 2023/10/06 03:32:15 djm Exp $
|
||||||
# Placed in the Public Domain.
|
# Placed in the Public Domain.
|
||||||
|
|
||||||
tid="pkcs11 agent test"
|
tid="pkcs11 agent test"
|
||||||
@ -38,6 +38,7 @@ export SSH_ASKPASS
|
|||||||
unset DISPLAY
|
unset DISPLAY
|
||||||
|
|
||||||
# start command w/o tty, so ssh-add accepts pin from stdin
|
# start command w/o tty, so ssh-add accepts pin from stdin
|
||||||
|
# XXX could force askpass instead
|
||||||
notty() {
|
notty() {
|
||||||
perl -e 'use POSIX; POSIX::setsid();
|
perl -e 'use POSIX; POSIX::setsid();
|
||||||
if (fork) { wait; exit($? >> 8); } else { exec(@ARGV) }' "$@"
|
if (fork) { wait; exit($? >> 8); } else { exec(@ARGV) }' "$@"
|
||||||
@ -45,18 +46,23 @@ notty() {
|
|||||||
|
|
||||||
trace "generating keys"
|
trace "generating keys"
|
||||||
RSA=${DIR}/RSA
|
RSA=${DIR}/RSA
|
||||||
|
RSAP8=${DIR}/RSAP8
|
||||||
|
ECPARAM=${DIR}/ECPARAM
|
||||||
EC=${DIR}/EC
|
EC=${DIR}/EC
|
||||||
$OPENSSL_BIN genpkey -algorithm rsa > $RSA
|
ECP8=${DIR}/ECP8
|
||||||
$OPENSSL_BIN pkcs8 -nocrypt -in $RSA |\
|
$OPENSSL_BIN genpkey -algorithm rsa > $RSA || fatal "genpkey RSA fail"
|
||||||
softhsm2-util --slot "$slot" --label 01 --id 01 --pin "$TEST_SSH_PIN" --import /dev/stdin
|
$OPENSSL_BIN pkcs8 -nocrypt -in $RSA > $RSAP8 || fatal "pkcs8 RSA fail"
|
||||||
|
softhsm2-util --slot "$slot" --label 01 --id 01 \
|
||||||
|
--pin "$TEST_SSH_PIN" --import $RSAP8 || fatal "softhsm import RSA fail"
|
||||||
|
|
||||||
$OPENSSL_BIN genpkey \
|
$OPENSSL_BIN genpkey \
|
||||||
-genparam \
|
-genparam \
|
||||||
-algorithm ec \
|
-algorithm ec \
|
||||||
-pkeyopt ec_paramgen_curve:prime256v1 |\
|
-pkeyopt ec_paramgen_curve:prime256v1 > $ECPARAM || fatal "param EC fail"
|
||||||
$OPENSSL_BIN genpkey \
|
$OPENSSL_BIN genpkey -paramfile $ECPARAM > $EC || fatal "genpkey EC fail"
|
||||||
-paramfile /dev/stdin > $EC
|
$OPENSSL_BIN pkcs8 -nocrypt -in $EC > $ECP8 || fatal "pkcs8 EC fail"
|
||||||
$OPENSSL_BIN pkcs8 -nocrypt -in $EC |\
|
softhsm2-util --slot "$slot" --label 02 --id 02 \
|
||||||
softhsm2-util --slot "$slot" --label 02 --id 02 --pin "$TEST_SSH_PIN" --import /dev/stdin
|
--pin "$TEST_SSH_PIN" --import $ECP8 || fatal "softhsm import EC fail"
|
||||||
|
|
||||||
trace "start agent"
|
trace "start agent"
|
||||||
eval `${SSHAGENT} ${EXTRA_AGENT_ARGS} -s` > /dev/null
|
eval `${SSHAGENT} ${EXTRA_AGENT_ARGS} -s` > /dev/null
|
||||||
@ -83,7 +89,8 @@ else
|
|||||||
chmod 600 $k
|
chmod 600 $k
|
||||||
ssh-keygen -y -f $k > $k.pub
|
ssh-keygen -y -f $k > $k.pub
|
||||||
pub=$(cat $k.pub)
|
pub=$(cat $k.pub)
|
||||||
${SSHADD} -L | grep -q "$pub" || fail "key $k missing in ssh-add -L"
|
${SSHADD} -L | grep -q "$pub" || \
|
||||||
|
fail "key $k missing in ssh-add -L"
|
||||||
${SSHADD} -T $k.pub || fail "ssh-add -T with $k failed"
|
${SSHADD} -T $k.pub || fail "ssh-add -T with $k failed"
|
||||||
|
|
||||||
# add to authorized keys
|
# add to authorized keys
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# $OpenBSD: Makefile,v 1.86 2022/05/10 09:42:32 bluhm Exp $
|
# $OpenBSD: Makefile,v 1.87 2023/10/06 06:00:18 espie Exp $
|
||||||
|
|
||||||
REGRESS_TARGETS=pkgnames pkgpaths signatures depends-check longnames pkgcfl \
|
REGRESS_TARGETS=pkgnames pkgpaths signatures depends-check longnames pkgcfl \
|
||||||
collision-check1 collision-check2 collision-check3 \
|
collision-check1 collision-check2 collision-check3 \
|
||||||
@ -24,6 +24,8 @@ REGRESS_EXPECTED_FAILURES = collision-check1 collision-check2 \
|
|||||||
|
|
||||||
PERLSCRIPT = perl -I ${.CURDIR} ${.CURDIR}
|
PERLSCRIPT = perl -I ${.CURDIR} ${.CURDIR}
|
||||||
|
|
||||||
|
WAVE_PLIST=-DREGRESSION_TESTING=plist_checks
|
||||||
|
|
||||||
ADD_PKG = ${PERLSCRIPT}/my add -Dchecksum
|
ADD_PKG = ${PERLSCRIPT}/my add -Dchecksum
|
||||||
DELETE_PKG = ${PERLSCRIPT}/my delete -Dchecksum
|
DELETE_PKG = ${PERLSCRIPT}/my delete -Dchecksum
|
||||||
INFO_PKG = ${PERLSCRIPT}/my info
|
INFO_PKG = ${PERLSCRIPT}/my info
|
||||||
@ -353,22 +355,22 @@ rep0/intb-0.tgz:
|
|||||||
@${CREATE_PKG} -P't/inta:inta-*:inta-0' ${EMPTY} $@
|
@${CREATE_PKG} -P't/inta:inta-*:inta-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep1/o-1.tgz:
|
rep1/o-1.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -P't/p:p-*:p-0' -W'coincoin.0.0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -P't/p:p-*:p-0' -W'coincoin.0.0' ${EMPTY} $@
|
||||||
|
|
||||||
rep1/o1-1.tgz:
|
rep1/o1-1.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -P't/p1:p1-*:p1-0' -W'coincoin.0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -P't/p1:p1-*:p1-0' -W'coincoin.0' ${EMPTY} $@
|
||||||
|
|
||||||
rep1/o2-1.tgz:
|
rep1/o2-1.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -P't/p2:p2-*:p2-0' -W'coincoin.0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -P't/p2:p2-*:p2-0' -W'coincoin.0' ${EMPTY} $@
|
||||||
|
|
||||||
rep0/o3-0.tgz:
|
rep0/o3-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W'unlikelylibraryname.0.0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W'unlikelylibraryname.0.0' ${EMPTY} $@
|
||||||
|
|
||||||
rep1/p-0.tgz rep1/p1-0.tgz: plist8
|
rep1/p-0.tgz rep1/p1-0.tgz: plist8
|
||||||
@${WITH} -B src13 -DLIBcoincoin_VERSION=0.0 -f plist8 $@ ${CPKG}
|
@${WITH} -B src13 -DLIBcoincoin_VERSION=0.0 -f plist8 $@ ${CPKG}
|
||||||
|
|
||||||
rep1/p2-0.tgz: plist8
|
rep1/p2-0.tgz: plist8
|
||||||
@${WITH} -DREGRESSION_TESTING -B src14 -DLIBcoincoin_VERSION=0 -f plist8 $@ ${CPKG}
|
@${WITH} ${WAVE_PLIST} -B src14 -DLIBcoincoin_VERSION=0 -f plist8 $@ ${CPKG}
|
||||||
|
|
||||||
rep0/p4-0.tgz: plist12
|
rep0/p4-0.tgz: plist12
|
||||||
@${WITH} -B src15 -DLIBa_VERSION=0.0 -f plist12 $@ ${CPKG}
|
@${WITH} -B src15 -DLIBa_VERSION=0.0 -f plist12 $@ ${CPKG}
|
||||||
@ -377,31 +379,31 @@ rep1/p4-1.tgz: plist12
|
|||||||
@${WITH} -B src31 -DLIBa_VERSION=1.0 -f plist12 $@ ${CPKG}
|
@${WITH} -B src31 -DLIBa_VERSION=1.0 -f plist12 $@ ${CPKG}
|
||||||
|
|
||||||
rep0/boost-0.tgz:
|
rep0/boost-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W'a.0.0' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W'a.0.0' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep1/boost-0.tgz:
|
rep1/boost-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W'a.1.0' -P't/p4:p4-*:p4-1' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W'a.1.0' -P't/p4:p4-*:p4-1' ${EMPTY} $@
|
||||||
|
|
||||||
rep0/Imath-0.tgz:
|
rep0/Imath-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -P't/boots:boost-*:boost-0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -P't/boots:boost-*:boost-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep1/Imath-0.tgz:
|
rep1/Imath-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -P't/boots:boost-*:boost-0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -P't/boots:boost-*:boost-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep0/o4-0.tgz:
|
rep0/o4-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W'a.1.0' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W'a.1.0' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep0/o5-0.tgz:
|
rep0/o5-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W'a.0.2' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W'a.0.2' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep0/o6-0.tgz:
|
rep0/o6-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W'a.0.0' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W'a.0.0' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep0/oo6-0.tgz:
|
rep0/oo6-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W'a.0.0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W'a.0.0' ${EMPTY} $@
|
||||||
|
|
||||||
rep0/o7-0.tgz:
|
rep0/o7-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W'dir/a.0.0' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W'dir/a.0.0' -P't/p4:p4-*:p4-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep1/b-1.tgz:
|
rep1/b-1.tgz:
|
||||||
@${CREATE_PKG} -P't/a:a-*:a-1' ${EMPTY} $@
|
@${CREATE_PKG} -P't/a:a-*:a-1' ${EMPTY} $@
|
||||||
@ -589,14 +591,14 @@ rep1/ol-1.tgz: plist21
|
|||||||
CUPS_FILES += rep2/$o.tgz
|
CUPS_FILES += rep2/$o.tgz
|
||||||
rep2/$o.tgz: ${.CURDIR}/oldcups/$o/+CONTENTS
|
rep2/$o.tgz: ${.CURDIR}/oldcups/$o/+CONTENTS
|
||||||
mkdir -p rep2
|
mkdir -p rep2
|
||||||
cd rep2 && pkg_create -DREGRESSION_TESTING -Dstub -f ${.CURDIR}/oldcups/$o/+CONTENTS
|
cd rep2 && pkg_create ${WAVE_PLIST} -Dstub -f ${.CURDIR}/oldcups/$o/+CONTENTS
|
||||||
.endfor
|
.endfor
|
||||||
|
|
||||||
.for n in cups-2.2.8 cups-filters-1.20.3 cups-libs-2.2.8 ghostscript-9.07p7
|
.for n in cups-2.2.8 cups-filters-1.20.3 cups-libs-2.2.8 ghostscript-9.07p7
|
||||||
CUPS_FILES += rep3/$n.tgz
|
CUPS_FILES += rep3/$n.tgz
|
||||||
rep3/$n.tgz: ${.CURDIR}/newcups/$n/+CONTENTS
|
rep3/$n.tgz: ${.CURDIR}/newcups/$n/+CONTENTS
|
||||||
mkdir -p rep3
|
mkdir -p rep3
|
||||||
cd rep3 && pkg_create -DREGRESSION_TESTING -Dstub -f ${.CURDIR}/newcups/$n/+CONTENTS
|
cd rep3 && pkg_create ${WAVE_PLIST} -Dstub -f ${.CURDIR}/newcups/$n/+CONTENTS
|
||||||
.endfor
|
.endfor
|
||||||
|
|
||||||
cups-bug: ${CUPS_FILES}
|
cups-bug: ${CUPS_FILES}
|
||||||
@ -651,10 +653,10 @@ rep5/gnutls-0.tgz:
|
|||||||
@${CREATE_PKG} -P't/libnettle:libnettle-*:libnettle-1' ${EMPTY} $@
|
@${CREATE_PKG} -P't/libnettle:libnettle-*:libnettle-1' ${EMPTY} $@
|
||||||
|
|
||||||
rep4/gtk+3-cups-0.tgz:
|
rep4/gtk+3-cups-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W nettle.0.0 -P't/cups-libs:cups-libs-*:cups-libs-0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W nettle.0.0 -P't/cups-libs:cups-libs-*:cups-libs-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep5/gtk+3-cups-0.tgz:
|
rep5/gtk+3-cups-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -W nettle.1.0 -P't/cups-libs:cups-libs-*:cups-libs-0' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -W nettle.1.0 -P't/cups-libs:cups-libs-*:cups-libs-0' ${EMPTY} $@
|
||||||
|
|
||||||
rep5/libnettle-1.tgz: plist22
|
rep5/libnettle-1.tgz: plist22
|
||||||
@${WITH} -B src24 -DLIBnettle_VERSION=1.0 -f plist22 $@ ${CPKG}
|
@${WITH} -B src24 -DLIBnettle_VERSION=1.0 -f plist22 $@ ${CPKG}
|
||||||
@ -766,10 +768,10 @@ rep6/avahi-0.tgz: plist25
|
|||||||
@${WITH} -B src28 -DLIBavahi_VERSION=0.0 -f plist25 $@ ${CPKG}
|
@${WITH} -B src28 -DLIBavahi_VERSION=0.0 -f plist25 $@ ${CPKG}
|
||||||
|
|
||||||
rep6/cups-0.tgz:
|
rep6/cups-0.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -P't/avahi:avahi-*:avahi-0' -W avahi.0.0 ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -P't/avahi:avahi-*:avahi-0' -W avahi.0.0 ${EMPTY} $@
|
||||||
|
|
||||||
rep7/avahi-1.tgz:
|
rep7/avahi-1.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -P't/avahi-libs:avahi-libs-*:avahi-libs-1' ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -P't/avahi-libs:avahi-libs-*:avahi-libs-1' ${EMPTY} $@
|
||||||
|
|
||||||
rep7/avahi-libs-1.tgz: plist27
|
rep7/avahi-libs-1.tgz: plist27
|
||||||
@${WITH} -B src28 -f plist27 $@ ${CPKG}
|
@${WITH} -B src28 -f plist27 $@ ${CPKG}
|
||||||
@ -778,7 +780,7 @@ rep7/avahi-glib-1.tgz: plist26
|
|||||||
@${WITH} -B src28 -DLIBavahi_VERSION=0.0 -f plist26 $@ ${CPKG}
|
@${WITH} -B src28 -DLIBavahi_VERSION=0.0 -f plist26 $@ ${CPKG}
|
||||||
|
|
||||||
rep7/cups-1.tgz:
|
rep7/cups-1.tgz:
|
||||||
@${CREATE_PKG} -DREGRESSION_TESTING -P't/avahi-libs:avahi-libs-*:avahi-libs-0' -P't/avahi-glib:avahi-glib-*:avahi-glib-1' -W avahi.0.0 ${EMPTY} $@
|
@${CREATE_PKG} ${WAVE_PLIST} -P't/avahi-libs:avahi-libs-*:avahi-libs-0' -P't/avahi-glib:avahi-glib-*:avahi-glib-1' -W avahi.0.0 ${EMPTY} $@
|
||||||
|
|
||||||
|
|
||||||
rep0/sym-0.tgz: plist19
|
rep0/sym-0.tgz: plist19
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: bioctl.c,v 1.155 2023/09/02 09:14:47 kn Exp $ */
|
/* $OpenBSD: bioctl.c,v 1.157 2023/10/07 12:20:10 kn Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2004, 2005 Marco Peereboom
|
* Copyright (c) 2004, 2005 Marco Peereboom
|
||||||
@ -90,7 +90,7 @@ int human;
|
|||||||
int verbose;
|
int verbose;
|
||||||
u_int32_t cflags = 0;
|
u_int32_t cflags = 0;
|
||||||
int rflag = -1; /* auto */
|
int rflag = -1; /* auto */
|
||||||
char *password;
|
char *passfile;
|
||||||
|
|
||||||
void *bio_cookie;
|
void *bio_cookie;
|
||||||
|
|
||||||
@ -175,7 +175,7 @@ main(int argc, char *argv[])
|
|||||||
changepass = 1;
|
changepass = 1;
|
||||||
break;
|
break;
|
||||||
case 'p':
|
case 'p':
|
||||||
password = optarg;
|
passfile = optarg;
|
||||||
break;
|
break;
|
||||||
case 'r':
|
case 'r':
|
||||||
if (strcmp(optarg, "auto") == 0) {
|
if (strcmp(optarg, "auto") == 0) {
|
||||||
@ -1334,8 +1334,8 @@ derive_key(u_int32_t type, int rounds, u_int8_t *key, size_t keysz,
|
|||||||
errx(1, "number of KDF rounds is too small: %d", rounds);
|
errx(1, "number of KDF rounds is too small: %d", rounds);
|
||||||
|
|
||||||
/* get passphrase */
|
/* get passphrase */
|
||||||
if (password) {
|
if (passfile) {
|
||||||
if ((f = fopen(password, "r")) == NULL)
|
if ((f = fopen(passfile, "r")) == NULL)
|
||||||
err(1, "invalid passphrase file");
|
err(1, "invalid passphrase file");
|
||||||
|
|
||||||
if (fstat(fileno(f), &sb) == -1)
|
if (fstat(fileno(f), &sb) == -1)
|
||||||
@ -1361,9 +1361,15 @@ derive_key(u_int32_t type, int rounds, u_int8_t *key, size_t keysz,
|
|||||||
if (readpassphrase(prompt, passphrase, sizeof(passphrase),
|
if (readpassphrase(prompt, passphrase, sizeof(passphrase),
|
||||||
rpp_flag) == NULL)
|
rpp_flag) == NULL)
|
||||||
err(1, "unable to read passphrase");
|
err(1, "unable to read passphrase");
|
||||||
|
if (*passphrase == '\0') {
|
||||||
|
warnx("invalid passphrase length");
|
||||||
|
if (interactive)
|
||||||
|
goto retry;
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (verify && !password) {
|
if (verify && !passfile) {
|
||||||
/* request user to re-type it */
|
/* request user to re-type it */
|
||||||
if (readpassphrase("Re-type passphrase: ", verifybuf,
|
if (readpassphrase("Re-type passphrase: ", verifybuf,
|
||||||
sizeof(verifybuf), rpp_flag) == NULL) {
|
sizeof(verifybuf), rpp_flag) == NULL) {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
.\" $OpenBSD: register-plist.1,v 1.6 2020/06/10 07:44:38 espie Exp $
|
.\" $OpenBSD: register-plist.1,v 1.7 2023/10/06 12:45:45 espie Exp $
|
||||||
.\"
|
.\"
|
||||||
.\" Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
.\" Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
||||||
.\"
|
.\"
|
||||||
@ -14,7 +14,7 @@
|
|||||||
.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
.\"
|
.\"
|
||||||
.Dd $Mdocdate: June 10 2020 $
|
.Dd $Mdocdate: October 6 2023 $
|
||||||
.Dt REGISTER-PLIST 1
|
.Dt REGISTER-PLIST 1
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
@ -38,10 +38,18 @@
|
|||||||
is used to check that a packing-list for a given package name doesn't change.
|
is used to check that a packing-list for a given package name doesn't change.
|
||||||
By default, it is invoked at the end of
|
By default, it is invoked at the end of
|
||||||
.Li make package ,
|
.Li make package ,
|
||||||
|
and compares a temporary package with the
|
||||||
|
.Pa ${PLIST_REPOSITORY}
|
||||||
|
before moving it to
|
||||||
|
.Pa ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/all
|
||||||
|
.Po
|
||||||
see
|
see
|
||||||
.Ev PACKAGE_REPOSITORY
|
.Ev PACKAGE_REPOSITORY
|
||||||
|
and
|
||||||
|
.Ev PLIST_REPOSITORY
|
||||||
in
|
in
|
||||||
.Xr bsd.port.mk 5 .
|
.Xr bsd.port.mk 5
|
||||||
|
.Pc .
|
||||||
Package names (package stem plus version) are used to uniquely identify
|
Package names (package stem plus version) are used to uniquely identify
|
||||||
packages.
|
packages.
|
||||||
When something in the package changes, the package name should change,
|
When something in the package changes, the package name should change,
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
.\" $OpenBSD: man.7,v 1.60 2021/08/05 14:31:06 schwarze Exp $
|
.\" $OpenBSD: man.7,v 1.61 2023/10/07 21:26:29 schwarze Exp $
|
||||||
.\"
|
.\"
|
||||||
.\" Copyright (c) 2009, 2010, 2011, 2012 Kristaps Dzonsons <kristaps@bsd.lv>
|
.\" Copyright (c) 2009, 2010, 2011, 2012 Kristaps Dzonsons <kristaps@bsd.lv>
|
||||||
.\" Copyright (c) 2011-2015, 2017-2020 Ingo Schwarze <schwarze@openbsd.org>
|
.\" Copyright (c) 2011-2015, 2017-2020 Ingo Schwarze <schwarze@openbsd.org>
|
||||||
@ -17,7 +17,7 @@
|
|||||||
.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
.\"
|
.\"
|
||||||
.Dd $Mdocdate: August 5 2021 $
|
.Dd $Mdocdate: October 7 2023 $
|
||||||
.Dt MAN 7
|
.Dt MAN 7
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
@ -97,10 +97,11 @@ but can be found in the alphabetical reference below.
|
|||||||
.It Ic SH Ta section header (one line)
|
.It Ic SH Ta section header (one line)
|
||||||
.It Ic SS Ta subsection header (one line)
|
.It Ic SS Ta subsection header (one line)
|
||||||
.It Ic PP Ta start an undecorated paragraph (no arguments)
|
.It Ic PP Ta start an undecorated paragraph (no arguments)
|
||||||
.It Ic RS , RE Ta reset the left margin: Op Ar width
|
|
||||||
.It Ic IP Ta indented paragraph: Op Ar head Op Ar width
|
.It Ic IP Ta indented paragraph: Op Ar head Op Ar width
|
||||||
.It Ic TP Ta tagged paragraph: Op Ar width
|
.It Ic TP Ta tagged paragraph: Op Ar width
|
||||||
.It Ic PD Ta set vertical paragraph distance: Op Ar height
|
.It Ic PD Ta set vertical paragraph distance: Op Ar height
|
||||||
|
.It Ic EX , EE Ta display an example (no arguments)
|
||||||
|
.It Ic RS , RE Ta reset the left margin: Op Ar width
|
||||||
.It Ic in Ta additional indent: Op Ar width
|
.It Ic in Ta additional indent: Op Ar width
|
||||||
.El
|
.El
|
||||||
.Ss Physical markup
|
.Ss Physical markup
|
||||||
@ -162,7 +163,9 @@ This has no effect unless the tabulator positions were changed with the
|
|||||||
.Ic ta
|
.Ic ta
|
||||||
request.
|
request.
|
||||||
.It Ic EE
|
.It Ic EE
|
||||||
This is a non-standard Version 9
|
End an example block started with
|
||||||
|
.Ic EX .
|
||||||
|
This is a Version 9
|
||||||
.At
|
.At
|
||||||
extension later adopted by GNU.
|
extension later adopted by GNU.
|
||||||
In
|
In
|
||||||
@ -172,7 +175,8 @@ it does the same as the
|
|||||||
.Ic fi
|
.Ic fi
|
||||||
request (switch to fill mode).
|
request (switch to fill mode).
|
||||||
.It Ic EX
|
.It Ic EX
|
||||||
This is a non-standard Version 9
|
Begin a block to display an example.
|
||||||
|
This is a Version 9
|
||||||
.At
|
.At
|
||||||
extension later adopted by GNU.
|
extension later adopted by GNU.
|
||||||
In
|
In
|
||||||
@ -234,10 +238,10 @@ A synonym for
|
|||||||
.It Ic ME
|
.It Ic ME
|
||||||
End a mailto block started with
|
End a mailto block started with
|
||||||
.Ic MT .
|
.Ic MT .
|
||||||
This is a non-standard GNU extension.
|
This is a GNU extension.
|
||||||
.It Ic MT
|
.It Ic MT
|
||||||
Begin a mailto block.
|
Begin a mailto block.
|
||||||
This is a non-standard GNU extension.
|
This is a GNU extension.
|
||||||
It has the following syntax:
|
It has the following syntax:
|
||||||
.Bd -unfilled -offset indent
|
.Bd -unfilled -offset indent
|
||||||
.Pf . Ic MT Ar address
|
.Pf . Ic MT Ar address
|
||||||
@ -246,7 +250,7 @@ link description to be shown
|
|||||||
.Ed
|
.Ed
|
||||||
.It Ic OP
|
.It Ic OP
|
||||||
Optional command-line argument.
|
Optional command-line argument.
|
||||||
This is a non-standard DWB extension.
|
This is a rarely used DWB extension.
|
||||||
It has the following syntax:
|
It has the following syntax:
|
||||||
.Pp
|
.Pp
|
||||||
.D1 Pf . Ic OP Ar key Op Ar value
|
.D1 Pf . Ic OP Ar key Op Ar value
|
||||||
@ -373,8 +377,7 @@ Begin a synopsis block with the following syntax:
|
|||||||
.Pf . Ic YS
|
.Pf . Ic YS
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
This is a non-standard GNU extension
|
This is a GNU extension and rarely used even in GNU manual pages.
|
||||||
and very rarely used even in GNU manual pages.
|
|
||||||
Formatting is similar to
|
Formatting is similar to
|
||||||
.Ic IP .
|
.Ic IP .
|
||||||
.It Ic TH
|
.It Ic TH
|
||||||
@ -437,8 +440,7 @@ unspecified, the saved or default width is used.
|
|||||||
Like
|
Like
|
||||||
.Ic TP ,
|
.Ic TP ,
|
||||||
except that no vertical spacing is inserted before the paragraph.
|
except that no vertical spacing is inserted before the paragraph.
|
||||||
This is a non-standard GNU extension
|
This is a GNU extension and rarely used even in GNU manual pages.
|
||||||
and very rarely used even in GNU manual pages.
|
|
||||||
.It Ic UC
|
.It Ic UC
|
||||||
Sets the volume for the footer for compatibility with man pages from
|
Sets the volume for the footer for compatibility with man pages from
|
||||||
.Bx
|
.Bx
|
||||||
@ -449,10 +451,10 @@ This macro is an extension that first appeared in
|
|||||||
.It Ic UE
|
.It Ic UE
|
||||||
End a uniform resource identifier block started with
|
End a uniform resource identifier block started with
|
||||||
.Ic UR .
|
.Ic UR .
|
||||||
This is a non-standard GNU extension.
|
This is a GNU extension.
|
||||||
.It Ic UR
|
.It Ic UR
|
||||||
Begin a uniform resource identifier block.
|
Begin a uniform resource identifier block.
|
||||||
This is a non-standard GNU extension.
|
This is a GNU extension.
|
||||||
It has the following syntax:
|
It has the following syntax:
|
||||||
.Bd -unfilled -offset indent
|
.Bd -unfilled -offset indent
|
||||||
.Pf . Ic UR Ar uri
|
.Pf . Ic UR Ar uri
|
||||||
@ -462,7 +464,7 @@ link description to be shown
|
|||||||
.It Ic YS
|
.It Ic YS
|
||||||
End a synopsis block started with
|
End a synopsis block started with
|
||||||
.Ic SY .
|
.Ic SY .
|
||||||
This is a non-standard GNU extension.
|
This is a GNU extension.
|
||||||
.It Ic in
|
.It Ic in
|
||||||
Indent relative to the current indentation:
|
Indent relative to the current indentation:
|
||||||
.Pp
|
.Pp
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: if_iwx.c,v 1.176 2023/08/26 09:05:34 stsp Exp $ */
|
/* $OpenBSD: if_iwx.c,v 1.177 2023/10/06 15:15:29 stsp Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2016 genua gmbh <info@genua.de>
|
* Copyright (c) 2014, 2016 genua gmbh <info@genua.de>
|
||||||
@ -10127,6 +10127,16 @@ iwx_rx_pkt(struct iwx_softc *sc, struct iwx_rx_data *data, struct mbuf_list *ml)
|
|||||||
case IWX_WIDE_ID(IWX_DATA_PATH_GROUP, IWX_RLC_CONFIG_CMD):
|
case IWX_WIDE_ID(IWX_DATA_PATH_GROUP, IWX_RLC_CONFIG_CMD):
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Ignore for now. The Linux driver only acts on this request
|
||||||
|
* with 160Mhz channels in 11ax mode.
|
||||||
|
*/
|
||||||
|
case IWX_WIDE_ID(IWX_DATA_PATH_GROUP,
|
||||||
|
IWX_THERMAL_DUAL_CHAIN_REQUEST):
|
||||||
|
DPRINTF(("%s: thermal dual-chain request received\n",
|
||||||
|
DEVNAME(sc)));
|
||||||
|
break;
|
||||||
|
|
||||||
/* undocumented notification from iwx-ty-a0-gf-a0-77 image */
|
/* undocumented notification from iwx-ty-a0-gf-a0-77 image */
|
||||||
case IWX_WIDE_ID(IWX_DATA_PATH_GROUP, 0xf8):
|
case IWX_WIDE_ID(IWX_DATA_PATH_GROUP, 0xf8):
|
||||||
break;
|
break;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: if_iwxreg.h,v 1.51 2023/03/06 11:18:37 stsp Exp $ */
|
/* $OpenBSD: if_iwxreg.h,v 1.52 2023/10/06 15:15:41 stsp Exp $ */
|
||||||
|
|
||||||
/*-
|
/*-
|
||||||
* Based on BSD-licensed source modules in the Linux iwlwifi driver,
|
* Based on BSD-licensed source modules in the Linux iwlwifi driver,
|
||||||
@ -2010,6 +2010,7 @@ struct iwx_tx_queue_cfg_rsp {
|
|||||||
#define IWX_RX_BAID_ALLOCATION_CONFIG_CMD 0x16
|
#define IWX_RX_BAID_ALLOCATION_CONFIG_CMD 0x16
|
||||||
#define IWX_SCD_QUEUE_CONFIG_CMD 0x17
|
#define IWX_SCD_QUEUE_CONFIG_CMD 0x17
|
||||||
#define IWX_RX_NO_DATA_NOTIF 0xf5
|
#define IWX_RX_NO_DATA_NOTIF 0xf5
|
||||||
|
#define IWX_THERMAL_DUAL_CHAIN_REQUEST 0xf6
|
||||||
#define IWX_TLC_MNG_UPDATE_NOTIF 0xf7
|
#define IWX_TLC_MNG_UPDATE_NOTIF 0xf7
|
||||||
|
|
||||||
/* REGULATORY_AND_NVM group subcommand IDs */
|
/* REGULATORY_AND_NVM group subcommand IDs */
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: ucom.c,v 1.77 2023/10/02 23:38:11 krw Exp $ */
|
/* $OpenBSD: ucom.c,v 1.78 2023/10/06 16:06:11 krw Exp $ */
|
||||||
/* $NetBSD: ucom.c,v 1.49 2003/01/01 00:10:25 thorpej Exp $ */
|
/* $NetBSD: ucom.c,v 1.49 2003/01/01 00:10:25 thorpej Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1256,7 +1256,7 @@ sysctl_ucominit(void)
|
|||||||
int rslt;
|
int rslt;
|
||||||
unsigned int unit;
|
unsigned int unit;
|
||||||
uint32_t route;
|
uint32_t route;
|
||||||
uint8_t bus, ifaceidx;
|
uint8_t bus, ifaceno;
|
||||||
|
|
||||||
KERNEL_ASSERT_LOCKED();
|
KERNEL_ASSERT_LOCKED();
|
||||||
|
|
||||||
@ -1272,11 +1272,11 @@ sysctl_ucominit(void)
|
|||||||
if (sc == NULL || sc->sc_iface == NULL)
|
if (sc == NULL || sc->sc_iface == NULL)
|
||||||
continue;
|
continue;
|
||||||
if (usbd_get_location(sc->sc_uparent, sc->sc_iface,
|
if (usbd_get_location(sc->sc_uparent, sc->sc_iface,
|
||||||
&bus, &route, &ifaceidx) == -1)
|
&bus, &route, &ifaceno) == -1)
|
||||||
continue;
|
continue;
|
||||||
rslt = snprintf(name, sizeof(name),
|
rslt = snprintf(name, sizeof(name),
|
||||||
"%s:usb%u.%u.%05x.%u,", sc->sc_dev.dv_xname, bus,
|
"%s:usb%u.%u.%05x.%u,", sc->sc_dev.dv_xname, bus,
|
||||||
ROUTEROOTPORT(route), ROUTESTRING(route), ifaceidx);
|
ROUTEROOTPORT(route), ROUTESTRING(route), ifaceno);
|
||||||
if (rslt < sizeof(name) && (strlen(ucoms) + rslt) <
|
if (rslt < sizeof(name) && (strlen(ucoms) + rslt) <
|
||||||
ucomslen)
|
ucomslen)
|
||||||
strlcat(ucoms, name, ucomslen);
|
strlcat(ucoms, name, ucomslen);
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: usb_subr.c,v 1.161 2023/10/02 23:38:11 krw Exp $ */
|
/* $OpenBSD: usb_subr.c,v 1.162 2023/10/06 16:06:11 krw Exp $ */
|
||||||
/* $NetBSD: usb_subr.c,v 1.103 2003/01/10 11:19:13 augustss Exp $ */
|
/* $NetBSD: usb_subr.c,v 1.103 2003/01/10 11:19:13 augustss Exp $ */
|
||||||
/* $FreeBSD: src/sys/dev/usb/usb_subr.c,v 1.18 1999/11/17 22:33:47 n_hibma Exp $ */
|
/* $FreeBSD: src/sys/dev/usb/usb_subr.c,v 1.18 1999/11/17 22:33:47 n_hibma Exp $ */
|
||||||
|
|
||||||
@ -1362,7 +1362,7 @@ usbd_get_routestring(struct usbd_device *dev, uint32_t *route)
|
|||||||
|
|
||||||
int
|
int
|
||||||
usbd_get_location(struct usbd_device *dev, struct usbd_interface *iface,
|
usbd_get_location(struct usbd_device *dev, struct usbd_interface *iface,
|
||||||
uint8_t *bus, uint32_t *route, uint8_t *ifaceidx)
|
uint8_t *bus, uint32_t *route, uint8_t *ifaceno)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
uint32_t r;
|
uint32_t r;
|
||||||
@ -1380,7 +1380,7 @@ usbd_get_location(struct usbd_device *dev, struct usbd_interface *iface,
|
|||||||
if (iface == &dev->ifaces[i]) {
|
if (iface == &dev->ifaces[i]) {
|
||||||
*bus = dev->bus->usbctl->dv_unit;
|
*bus = dev->bus->usbctl->dv_unit;
|
||||||
*route = (usbd_get_routestring(dev, &r)) ? 0 : r;
|
*route = (usbd_get_routestring(dev, &r)) ? 0 : r;
|
||||||
*ifaceidx = i;
|
*ifaceno = i;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: kern_sig.c,v 1.319 2023/09/29 12:47:34 claudio Exp $ */
|
/* $OpenBSD: kern_sig.c,v 1.320 2023/10/06 08:58:13 claudio Exp $ */
|
||||||
/* $NetBSD: kern_sig.c,v 1.54 1996/04/22 01:38:32 christos Exp $ */
|
/* $NetBSD: kern_sig.c,v 1.54 1996/04/22 01:38:32 christos Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1812,7 +1812,6 @@ sys_nosys(struct proc *p, void *v, register_t *retval)
|
|||||||
int
|
int
|
||||||
sys___thrsigdivert(struct proc *p, void *v, register_t *retval)
|
sys___thrsigdivert(struct proc *p, void *v, register_t *retval)
|
||||||
{
|
{
|
||||||
static int sigwaitsleep;
|
|
||||||
struct sys___thrsigdivert_args /* {
|
struct sys___thrsigdivert_args /* {
|
||||||
syscallarg(sigset_t) sigmask;
|
syscallarg(sigset_t) sigmask;
|
||||||
syscallarg(siginfo_t *) info;
|
syscallarg(siginfo_t *) info;
|
||||||
@ -1863,8 +1862,7 @@ sys___thrsigdivert(struct proc *p, void *v, register_t *retval)
|
|||||||
if (error != 0)
|
if (error != 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
error = tsleep_nsec(&sigwaitsleep, PPAUSE|PCATCH, "sigwait",
|
error = tsleep_nsec(&nowake, PPAUSE|PCATCH, "sigwait", nsecs);
|
||||||
nsecs);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (error == 0) {
|
if (error == 0) {
|
||||||
|
@ -25,6 +25,11 @@ THIS SOFTWARE.
|
|||||||
This file lists all bug fixes, changes, etc., made since the
|
This file lists all bug fixes, changes, etc., made since the
|
||||||
second edition of the AWK book was published in September 2023.
|
second edition of the AWK book was published in September 2023.
|
||||||
|
|
||||||
|
Sep 24, 2023:
|
||||||
|
fnematch and getrune have been overhauled to solve issues around
|
||||||
|
unicode FS and RS. also fixed gsub null match issue with unicode.
|
||||||
|
big thanks to Arnold Robbins.
|
||||||
|
|
||||||
Sep 12, 2023:
|
Sep 12, 2023:
|
||||||
Fixed a length error in u8_byte2char that set RSTART to
|
Fixed a length error in u8_byte2char that set RSTART to
|
||||||
incorrect (cannot happen) value for EOL match(str, /$/).
|
incorrect (cannot happen) value for EOL match(str, /$/).
|
||||||
|
121
usr.bin/awk/b.c
121
usr.bin/awk/b.c
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: b.c,v 1.42 2023/09/21 17:19:06 millert Exp $ */
|
/* $OpenBSD: b.c,v 1.44 2023/10/06 22:31:21 millert Exp $ */
|
||||||
/****************************************************************
|
/****************************************************************
|
||||||
Copyright (C) Lucent Technologies 1997
|
Copyright (C) Lucent Technologies 1997
|
||||||
All Rights Reserved
|
All Rights Reserved
|
||||||
@ -81,6 +81,8 @@ int patlen;
|
|||||||
fa *fatab[NFA];
|
fa *fatab[NFA];
|
||||||
int nfatab = 0; /* entries in fatab */
|
int nfatab = 0; /* entries in fatab */
|
||||||
|
|
||||||
|
extern int u8_nextlen(const char *s);
|
||||||
|
|
||||||
|
|
||||||
/* utf-8 mechanism:
|
/* utf-8 mechanism:
|
||||||
|
|
||||||
@ -114,6 +116,7 @@ int nfatab = 0; /* entries in fatab */
|
|||||||
|
|
||||||
static int get_gototab(fa*, int, int);
|
static int get_gototab(fa*, int, int);
|
||||||
static int set_gototab(fa*, int, int, int);
|
static int set_gototab(fa*, int, int, int);
|
||||||
|
static void reset_gototab(fa*, int);
|
||||||
extern int u8_rune(int *, const uschar *);
|
extern int u8_rune(int *, const uschar *);
|
||||||
|
|
||||||
static int *
|
static int *
|
||||||
@ -274,8 +277,7 @@ int makeinit(fa *f, bool anchor)
|
|||||||
}
|
}
|
||||||
if ((f->posns[2])[1] == f->accept)
|
if ((f->posns[2])[1] == f->accept)
|
||||||
f->out[2] = 1;
|
f->out[2] = 1;
|
||||||
for (i = 0; i < NCHARS; i++)
|
reset_gototab(f, 2);
|
||||||
set_gototab(f, 2, 0, 0); /* f->gototab[2][i] = 0; */
|
|
||||||
f->curstat = cgoto(f, 2, HAT);
|
f->curstat = cgoto(f, 2, HAT);
|
||||||
if (anchor) {
|
if (anchor) {
|
||||||
*f->posns[2] = k-1; /* leave out position 0 */
|
*f->posns[2] = k-1; /* leave out position 0 */
|
||||||
@ -611,6 +613,11 @@ static int get_gototab(fa *f, int state, int ch) /* hide gototab inplementation
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void reset_gototab(fa *f, int state) /* hide gototab inplementation */
|
||||||
|
{
|
||||||
|
memset(f->gototab[state], 0, f->gototab_len * sizeof(**f->gototab));
|
||||||
|
}
|
||||||
|
|
||||||
static int set_gototab(fa *f, int state, int ch, int val) /* hide gototab inplementation */
|
static int set_gototab(fa *f, int state, int ch, int val) /* hide gototab inplementation */
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
@ -760,33 +767,59 @@ int nematch(fa *f, const char *p0) /* non-empty match, for sub */
|
|||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int getrune(FILE *fp, char **pbuf, int *pbufsize, int quantum,
|
|
||||||
int *curpos, int *lastpos)
|
#define MAX_UTF_BYTES 4 // UTF-8 is up to 4 bytes long
|
||||||
|
|
||||||
|
// Read one rune at a time from the given FILE*. Return both
|
||||||
|
// the bytes and the actual rune.
|
||||||
|
|
||||||
|
struct runedata {
|
||||||
|
int rune;
|
||||||
|
size_t len;
|
||||||
|
char bytes[6];
|
||||||
|
};
|
||||||
|
|
||||||
|
struct runedata getrune(FILE *fp)
|
||||||
{
|
{
|
||||||
int c = 0;
|
struct runedata result;
|
||||||
char *buf = *pbuf;
|
int c, i, next;
|
||||||
static const int max_bytes = 4; // max multiple bytes in UTF-8 is 4
|
|
||||||
int i, rune;
|
|
||||||
uschar private_buf[max_bytes + 1];
|
|
||||||
|
|
||||||
for (i = 0; i <= max_bytes; i++) {
|
memset(&result, 0, sizeof(result));
|
||||||
if (++*curpos == *lastpos) {
|
|
||||||
if (*lastpos == *pbufsize)
|
c = getc(fp);
|
||||||
if (!adjbuf((char **) pbuf, pbufsize, *pbufsize+1, quantum, 0, "getrune"))
|
if (c == EOF)
|
||||||
FATAL("stream '%.30s...' too long", buf);
|
return result; // result.rune == 0 --> EOF
|
||||||
buf[(*lastpos)++] = (c = getc(fp)) != EOF ? c : 0;
|
else if (c < 128 || awk_mb_cur_max == 1) {
|
||||||
private_buf[i] = c;
|
result.bytes[0] = c;
|
||||||
|
result.len = 1;
|
||||||
|
result.rune = c;
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
if (c == 0 || c < 128 || (c >> 6) == 4) { // 10xxxxxx starts a new character
|
|
||||||
ungetc(c, fp);
|
// need to get bytes and fill things in
|
||||||
private_buf[i] = 0;
|
result.bytes[0] = c;
|
||||||
|
result.len = 1;
|
||||||
|
|
||||||
|
next = 1;
|
||||||
|
for (i = 1; i < MAX_UTF_BYTES; i++) {
|
||||||
|
c = getc(fp);
|
||||||
|
if (c == EOF)
|
||||||
break;
|
break;
|
||||||
}
|
result.bytes[next++] = c;
|
||||||
|
result.len++;
|
||||||
}
|
}
|
||||||
|
|
||||||
u8_rune(& rune, private_buf);
|
// put back any extra input bytes
|
||||||
|
int actual_len = u8_nextlen(result.bytes);
|
||||||
|
while (result.len > actual_len) {
|
||||||
|
ungetc(result.bytes[--result.len], fp);
|
||||||
|
}
|
||||||
|
|
||||||
return rune;
|
result.bytes[result.len] = '\0';
|
||||||
|
(void) u8_rune(& result.rune, (uschar *) result.bytes);
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -809,8 +842,8 @@ bool fnematch(fa *pfa, FILE *f, char **pbuf, int *pbufsize, int quantum)
|
|||||||
{
|
{
|
||||||
char *buf = *pbuf;
|
char *buf = *pbuf;
|
||||||
int bufsize = *pbufsize;
|
int bufsize = *pbufsize;
|
||||||
int c, i, j, k, ns, s;
|
int i, j, k, ns, s;
|
||||||
int rune;
|
struct runedata r;
|
||||||
|
|
||||||
s = pfa->initstat;
|
s = pfa->initstat;
|
||||||
patlen = 0;
|
patlen = 0;
|
||||||
@ -819,42 +852,38 @@ bool fnematch(fa *pfa, FILE *f, char **pbuf, int *pbufsize, int quantum)
|
|||||||
* All indices relative to buf.
|
* All indices relative to buf.
|
||||||
* i <= j <= k <= bufsize
|
* i <= j <= k <= bufsize
|
||||||
*
|
*
|
||||||
* i: origin of active substring
|
* i: origin of active substring (first byte of first character)
|
||||||
* j: current character
|
* j: current character (last byte of current character)
|
||||||
* k: destination of next getc()
|
* k: destination of next getc()
|
||||||
*/
|
*/
|
||||||
i = -1, k = 0;
|
i = -1, k = 0;
|
||||||
do {
|
do {
|
||||||
j = i++;
|
j = i++;
|
||||||
do {
|
do {
|
||||||
if (++j == k) {
|
r = getrune(f);
|
||||||
if (k == bufsize)
|
if ((++j + r.len) >= k) {
|
||||||
|
if (k >= bufsize)
|
||||||
if (!adjbuf(&buf, &bufsize, bufsize+1, quantum, 0, "fnematch"))
|
if (!adjbuf(&buf, &bufsize, bufsize+1, quantum, 0, "fnematch"))
|
||||||
FATAL("stream '%.30s...' too long", buf);
|
FATAL("stream '%.30s...' too long", buf);
|
||||||
buf[k++] = (c = getc(f)) != EOF ? c : 0;
|
|
||||||
}
|
|
||||||
c = (uschar)buf[j];
|
|
||||||
if (c < 128 || awk_mb_cur_max == 1)
|
|
||||||
rune = c;
|
|
||||||
else {
|
|
||||||
j--;
|
|
||||||
k--;
|
|
||||||
ungetc(c, f);
|
|
||||||
rune = getrune(f, &buf, &bufsize, quantum, &j, &k);
|
|
||||||
}
|
}
|
||||||
|
memcpy(buf + k, r.bytes, r.len);
|
||||||
|
j += r.len - 1; // incremented next time around the loop
|
||||||
|
k += r.len;
|
||||||
|
|
||||||
if ((ns = get_gototab(pfa, s, rune)) != 0)
|
if ((ns = get_gototab(pfa, s, r.rune)) != 0)
|
||||||
s = ns;
|
s = ns;
|
||||||
else
|
else
|
||||||
s = cgoto(pfa, s, rune);
|
s = cgoto(pfa, s, r.rune);
|
||||||
|
|
||||||
if (pfa->out[s]) { /* final state */
|
if (pfa->out[s]) { /* final state */
|
||||||
patlen = j - i + 1;
|
patlen = j - i + 1;
|
||||||
if (c == 0) /* don't count $ */
|
if (r.rune == 0) /* don't count $ */
|
||||||
patlen--;
|
patlen--;
|
||||||
}
|
}
|
||||||
} while (buf[j] && s != 1);
|
} while (buf[j] && s != 1);
|
||||||
s = 2;
|
s = 2;
|
||||||
|
if (r.len > 1)
|
||||||
|
i += r.len - 1; // i incremented around the loop
|
||||||
} while (buf[i] && !patlen);
|
} while (buf[i] && !patlen);
|
||||||
|
|
||||||
/* adjbuf() may have relocated a resized buffer. Inform the world. */
|
/* adjbuf() may have relocated a resized buffer. Inform the world. */
|
||||||
@ -874,10 +903,12 @@ bool fnematch(fa *pfa, FILE *f, char **pbuf, int *pbufsize, int quantum)
|
|||||||
* (except for EOF's nullbyte, if present) and null
|
* (except for EOF's nullbyte, if present) and null
|
||||||
* terminate the buffer.
|
* terminate the buffer.
|
||||||
*/
|
*/
|
||||||
do
|
do {
|
||||||
|
int ii;
|
||||||
|
for (ii = r.len; ii > 0; ii--)
|
||||||
if (buf[--k] && ungetc(buf[k], f) == EOF)
|
if (buf[--k] && ungetc(buf[k], f) == EOF)
|
||||||
FATAL("unable to ungetc '%c'", buf[k]);
|
FATAL("unable to ungetc '%c'", buf[k]);
|
||||||
while (k > i + patlen);
|
} while (k > i + patlen);
|
||||||
buf[k] = '\0';
|
buf[k] = '\0';
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1466,8 +1497,6 @@ int cgoto(fa *f, int s, int c)
|
|||||||
/* add tmpset to current set of states */
|
/* add tmpset to current set of states */
|
||||||
++(f->curstat);
|
++(f->curstat);
|
||||||
resize_state(f, f->curstat);
|
resize_state(f, f->curstat);
|
||||||
for (i = 0; i < NCHARS; i++)
|
|
||||||
set_gototab(f, f->curstat, 0, 0);
|
|
||||||
xfree(f->posns[f->curstat]);
|
xfree(f->posns[f->curstat]);
|
||||||
p = intalloc(setcnt + 1, __func__);
|
p = intalloc(setcnt + 1, __func__);
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: lib.c,v 1.51 2023/09/17 14:49:44 millert Exp $ */
|
/* $OpenBSD: lib.c,v 1.52 2023/10/06 22:29:24 millert Exp $ */
|
||||||
/****************************************************************
|
/****************************************************************
|
||||||
Copyright (C) Lucent Technologies 1997
|
Copyright (C) Lucent Technologies 1997
|
||||||
All Rights Reserved
|
All Rights Reserved
|
||||||
@ -234,6 +234,7 @@ int readrec(char **pbuf, int *pbufsize, FILE *inf, bool newflag) /* read one rec
|
|||||||
} else if (*rs && rs[1]) {
|
} else if (*rs && rs[1]) {
|
||||||
bool found;
|
bool found;
|
||||||
|
|
||||||
|
memset(buf, 0, bufsize);
|
||||||
fa *pfa = makedfa(rs, 1);
|
fa *pfa = makedfa(rs, 1);
|
||||||
if (newflag)
|
if (newflag)
|
||||||
found = fnematch(pfa, inf, &buf, &bufsize, recsize);
|
found = fnematch(pfa, inf, &buf, &bufsize, recsize);
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: main.c,v 1.62 2023/09/20 16:57:12 millert Exp $ */
|
/* $OpenBSD: main.c,v 1.63 2023/10/06 22:29:24 millert Exp $ */
|
||||||
/****************************************************************
|
/****************************************************************
|
||||||
Copyright (C) Lucent Technologies 1997
|
Copyright (C) Lucent Technologies 1997
|
||||||
All Rights Reserved
|
All Rights Reserved
|
||||||
@ -23,7 +23,7 @@ ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF
|
|||||||
THIS SOFTWARE.
|
THIS SOFTWARE.
|
||||||
****************************************************************/
|
****************************************************************/
|
||||||
|
|
||||||
const char *version = "version 20230913";
|
const char *version = "version 20231001";
|
||||||
|
|
||||||
#define DEBUG
|
#define DEBUG
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: run.c,v 1.78 2023/09/20 16:49:13 millert Exp $ */
|
/* $OpenBSD: run.c,v 1.79 2023/10/06 22:29:24 millert Exp $ */
|
||||||
/****************************************************************
|
/****************************************************************
|
||||||
Copyright (C) Lucent Technologies 1997
|
Copyright (C) Lucent Technologies 1997
|
||||||
All Rights Reserved
|
All Rights Reserved
|
||||||
@ -2587,6 +2587,7 @@ Cell *gsub(Node **a, int nnn) /* global substitute */
|
|||||||
fa *pfa;
|
fa *pfa;
|
||||||
int mflag, tempstat, num;
|
int mflag, tempstat, num;
|
||||||
int bufsz = recsize;
|
int bufsz = recsize;
|
||||||
|
int charlen = 0;
|
||||||
|
|
||||||
if ((buf = (char *) malloc(bufsz)) == NULL)
|
if ((buf = (char *) malloc(bufsz)) == NULL)
|
||||||
FATAL("out of memory in gsub");
|
FATAL("out of memory in gsub");
|
||||||
@ -2628,6 +2629,8 @@ Cell *gsub(Node **a, int nnn) /* global substitute */
|
|||||||
if (*t == '\0') /* at end */
|
if (*t == '\0') /* at end */
|
||||||
goto done;
|
goto done;
|
||||||
adjbuf(&buf, &bufsz, 2+pb-buf, recsize, &pb, "gsub");
|
adjbuf(&buf, &bufsz, 2+pb-buf, recsize, &pb, "gsub");
|
||||||
|
charlen = u8_nextlen(t);
|
||||||
|
while (charlen-- > 0)
|
||||||
*pb++ = *t++;
|
*pb++ = *t++;
|
||||||
if (pb > buf + bufsz) /* BUG: not sure of this test */
|
if (pb > buf + bufsz) /* BUG: not sure of this test */
|
||||||
FATAL("gsub result0 %.30s too big; can't happen", buf);
|
FATAL("gsub result0 %.30s too big; can't happen", buf);
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: dhcpd.c,v 1.58 2023/10/05 18:46:14 mvs Exp $ */
|
/* $OpenBSD: dhcpd.c,v 1.59 2023/10/06 05:31:54 jmc Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2004 Henning Brauer <henning@cvs.openbsd.org>
|
* Copyright (c) 2004 Henning Brauer <henning@cvs.openbsd.org>
|
||||||
@ -276,7 +276,7 @@ usage(void)
|
|||||||
{
|
{
|
||||||
extern char *__progname;
|
extern char *__progname;
|
||||||
|
|
||||||
fprintf(stderr, "usage: %s [-dfn] [-A abandoned_ip_table]",
|
fprintf(stderr, "usage: %s [-dfnv] [-A abandoned_ip_table]",
|
||||||
__progname);
|
__progname);
|
||||||
fprintf(stderr, " [-C changed_ip_table]\n");
|
fprintf(stderr, " [-C changed_ip_table]\n");
|
||||||
fprintf(stderr, "\t[-c config-file] [-L leased_ip_table]");
|
fprintf(stderr, "\t[-c config-file] [-L leased_ip_table]");
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#! /usr/bin/perl
|
#! /usr/bin/perl
|
||||||
|
|
||||||
# ex:ts=8 sw=4:
|
# ex:ts=8 sw=4:
|
||||||
# $OpenBSD: PkgAdd.pm,v 1.143 2023/07/03 19:12:08 espie Exp $
|
# $OpenBSD: PkgAdd.pm,v 1.144 2023/10/07 09:11:26 espie Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 2003-2014 Marc Espie <espie@openbsd.org>
|
# Copyright (c) 2003-2014 Marc Espie <espie@openbsd.org>
|
||||||
#
|
#
|
||||||
@ -1112,6 +1112,16 @@ sub grab_debug_package($class, $d, $dbg, $state)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub report_cantupdate($state, $cantupdate)
|
||||||
|
{
|
||||||
|
if ($state->tracker->did_something) {
|
||||||
|
$state->say("Couldn't find updates for #1",
|
||||||
|
join(' ', sort @$cantupdate));
|
||||||
|
} else {
|
||||||
|
$state->say("Couldn't find any update");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
sub inform_user_of_problems($state)
|
sub inform_user_of_problems($state)
|
||||||
{
|
{
|
||||||
my @cantupdate = $state->tracker->cant_list;
|
my @cantupdate = $state->tracker->cant_list;
|
||||||
@ -1120,10 +1130,8 @@ sub inform_user_of_problems($state)
|
|||||||
sub($quirks) {
|
sub($quirks) {
|
||||||
$quirks->filter_obsolete(\@cantupdate, $state);
|
$quirks->filter_obsolete(\@cantupdate, $state);
|
||||||
});
|
});
|
||||||
|
|
||||||
$state->say("Couldn't find updates for #1",
|
|
||||||
join(' ', sort @cantupdate)) if @cantupdate > 0;
|
|
||||||
if (@cantupdate > 0) {
|
if (@cantupdate > 0) {
|
||||||
|
report_cantupdate($state, \@cantupdate);
|
||||||
$state->{bad}++;
|
$state->{bad}++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#! /usr/bin/perl
|
#! /usr/bin/perl
|
||||||
# ex:ts=8 sw=4:
|
# ex:ts=8 sw=4:
|
||||||
# $OpenBSD: PkgCreate.pm,v 1.195 2023/07/20 17:56:37 espie Exp $
|
# $OpenBSD: PkgCreate.pm,v 1.196 2023/10/07 09:09:07 espie Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 2003-2014 Marc Espie <espie@openbsd.org>
|
# Copyright (c) 2003-2014 Marc Espie <espie@openbsd.org>
|
||||||
#
|
#
|
||||||
@ -1684,7 +1684,7 @@ sub run_command($self, $state)
|
|||||||
}
|
}
|
||||||
$state->{stash} = {};
|
$state->{stash} = {};
|
||||||
|
|
||||||
if ($state->{bad} && !$state->defines('REGRESSION_TESTING')) {
|
if ($state->{bad} && !$state->{regression}{plist_checks}) {
|
||||||
$state->fatal("can't continue");
|
$state->fatal("can't continue");
|
||||||
}
|
}
|
||||||
$state->{bad} = 0;
|
$state->{bad} = 0;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# ex:ts=8 sw=4:
|
# ex:ts=8 sw=4:
|
||||||
# $OpenBSD: Tracker.pm,v 1.31 2023/06/13 09:07:17 espie Exp $
|
# $OpenBSD: Tracker.pm,v 1.32 2023/10/07 09:10:03 espie Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 2009 Marc Espie <espie@openbsd.org>
|
# Copyright (c) 2009 Marc Espie <espie@openbsd.org>
|
||||||
#
|
#
|
||||||
@ -101,6 +101,9 @@ sub add_set($self, $set)
|
|||||||
for my $n ($set->kept) {
|
for my $n ($set->kept) {
|
||||||
delete $self->{to_update}{$n->pkgname};
|
delete $self->{to_update}{$n->pkgname};
|
||||||
$self->{uptodate}{$n->pkgname} = 1;
|
$self->{uptodate}{$n->pkgname} = 1;
|
||||||
|
if ($n->{is_firmware}) {
|
||||||
|
$self->{firmware}{$n->pkgname} = 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$self->known($set);
|
$self->known($set);
|
||||||
$self->handle_set($set);
|
$self->handle_set($set);
|
||||||
@ -134,6 +137,9 @@ sub uptodate($self, $set)
|
|||||||
$self->remove_set($set);
|
$self->remove_set($set);
|
||||||
for my $n ($set->older, $set->kept) {
|
for my $n ($set->older, $set->kept) {
|
||||||
$self->{uptodate}{$n->pkgname} = 1;
|
$self->{uptodate}{$n->pkgname} = 1;
|
||||||
|
if ($n->{is_firmware}) {
|
||||||
|
$self->{firmware}{$n->pkgname} = 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -198,6 +204,15 @@ sub cant_list($self)
|
|||||||
return keys %{$self->{cant_update}};
|
return keys %{$self->{cant_update}};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub did_something($self)
|
||||||
|
{
|
||||||
|
for my $k (keys %{$self->{uptodate}}) {
|
||||||
|
next if $self->{firmware}{$k};
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
sub cant_install_list($self)
|
sub cant_install_list($self)
|
||||||
{
|
{
|
||||||
return keys %{$self->{cant_install}};
|
return keys %{$self->{cant_install}};
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# ex:ts=8 sw=4:
|
# ex:ts=8 sw=4:
|
||||||
# $OpenBSD: Update.pm,v 1.170 2023/06/13 09:07:17 espie Exp $
|
# $OpenBSD: Update.pm,v 1.171 2023/10/07 09:10:03 espie Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 2004-2014 Marc Espie <espie@openbsd.org>
|
# Copyright (c) 2004-2014 Marc Espie <espie@openbsd.org>
|
||||||
#
|
#
|
||||||
@ -117,6 +117,7 @@ sub process_handle($self, $set, $h, $state)
|
|||||||
|
|
||||||
if ($plist->has('firmware') && !$state->defines('FW_UPDATE')) {
|
if ($plist->has('firmware') && !$state->defines('FW_UPDATE')) {
|
||||||
$set->move_kept($h);
|
$set->move_kept($h);
|
||||||
|
$h->{is_firmware} = 1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user