Merge branch '9fans:master' into htmlfmt

This commit is contained in:
RastaGraffix 2023-09-15 11:17:26 -07:00 committed by GitHub
commit dc2c2bc392
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
14 changed files with 60 additions and 38 deletions

View file

@ -37,7 +37,6 @@ for details on using Git.
Status
------
[![Build Status](https://travis-ci.org/9fans/plan9port.svg?branch=master)](https://travis-ci.org/9fans/plan9port)
[![Coverity Scan Build Status](https://scan.coverity.com/projects/plan-9-from-user-space/badge.svg)](https://scan.coverity.com/projects/plan-9-from-user-space)

View file

@ -61,7 +61,7 @@ struct Reinst{
*/
struct Reprog{
Reinst *startinst; /* start pc */
Reclass class[16]; /* .data */
Reclass class[128]; /* .data */
Reinst firstinst[5]; /* .text */
};

View file

@ -169,7 +169,7 @@ The only way to write multithreaded programs is to use the
library.
.MR Rfork (3)
exists but is not as capable as on Plan 9.
There are many unfortunate by necessary preprocessor
There are many unfortunate but necessary preprocessor
diversions to make Plan 9 and Unix libraries coexist.
See
.MR intro (3)

View file

@ -254,7 +254,7 @@ port of the rule set or the entire rule set will be skipped.
.B client
If no application has the port open, the arguments to a
.B plumb
.B start
.B client
rule specify a shell program to run in response to the message.
The message will be held, with the supposition that the program
will eventually open the port to retrieve it.

View file

@ -28,7 +28,7 @@ enum
enum
{
Blockincr = 256,
Maxblock = 8*1024,
Maxblock = 32*1024,
NRange = 10,
Infinity = 0x7FFFFFFF /* huge value for regexp address */
};

View file

@ -319,7 +319,7 @@ rowdump(Row *row, char *file)
int i, j, fd, m, n, start, dumped;
uint q0, q1;
Biobuf *b;
char *buf, *a, *fontname;
char *buf, *a, *fontname, *fontfmt, *fontnamelo, *fontnamehi;
Rune *r;
Column *c;
Window *w, *w1;
@ -394,9 +394,17 @@ rowdump(Row *row, char *file)
if(w1->nopen[QWevent])
goto Continue2;
}
fontname = "";
if(t->reffont->f != font)
fontname = t->reffont->f->name;
fontfmt = "%s";
fontnamelo = "";
fontnamehi = nil;
if(t->reffont->f != font){
fontnamelo = t->reffont->f->lodpi->name;
if(t->reffont->f->hidpi != nil){
fontfmt = "%s,%s";
fontnamehi = t->reffont->f->hidpi->name;
}
}
fontname = smprint(fontfmt, fontnamelo, fontnamehi);
if(t->file->nname)
a = runetobyte(t->file->name, t->file->nname);
else
@ -428,6 +436,7 @@ rowdump(Row *row, char *file)
100.0*(w->r.min.y-c->r.min.y)/Dy(c->r),
w->body.file->b.nc, fontname);
}
free(fontname);
free(a);
winctlprint(w, buf, 0);
Bwrite(b, buf, strlen(buf));

View file

@ -601,12 +601,12 @@ rpc_resizewindow(Client *c, Rectangle r)
- (void)scrollWheel:(NSEvent*)e
{
NSInteger s;
CGFloat s;
s = [e scrollingDeltaY];
if(s > 0)
if(s > 0.0f)
[self sendmouse:8];
else if (s < 0)
else if (s < 0.0f)
[self sendmouse:16];
}

View file

@ -96,11 +96,11 @@ threadmain(int argc, char **argv)
{
Document *doc;
Biobuf *b;
char *basename = argv[0];
enum { Ninput = 16 };
uchar buf[Ninput+1];
int readstdin;
int readstdin, haveppi;
haveppi = 0;
ARGBEGIN{
/* "temporary" debugging options */
case 'P':
@ -128,13 +128,14 @@ threadmain(int argc, char **argv)
reverse = 1;
break;
case 'p':
haveppi = 1;
ppi = atoi(EARGF(usage()));
break;
case 'b':
truetoboundingbox = 1;
break;
case 'w':
fprint(2, "%s: -w has only the effect of -R X11 systems\n", basename);
fprint(2, "warning: page -w only supported on x11 systems\n");
resizing = 1;
break;
case 'i':
@ -199,6 +200,13 @@ threadmain(int argc, char **argv)
}else
b = nil;
if(initdraw(0, 0, "page") < 0){
fprint(2, "page: initdraw failed: %r\n");
wexits("initdraw");
}
display->locking = 1;
ppi = scalesize(display, ppi);
buf[Ninput] = '\0';
if(imagemode)
doc = initgfx(nil, 0, nil, nil, 0);
@ -217,7 +225,7 @@ threadmain(int argc, char **argv)
else if(strncmp((char*)buf, "x T ", 4) == 0)
doc = inittroff(b, argc, argv, buf, Ninput);
else {
if(ppi != 100) {
if(haveppi) {
fprint(2, "page: you can't specify -p with graphic files\n");
wexits("-p and graphics");
}
@ -237,12 +245,6 @@ threadmain(int argc, char **argv)
if(reverse == -1) /* neither cmdline nor ps reader set it */
reverse = 0;
if(initdraw(0, 0, "page") < 0){
fprint(2, "page: initdraw failed: %r\n");
wexits("initdraw");
}
display->locking = 1;
truecolor = screen->depth > 8;
viewer(doc);
wexits(0);

View file

@ -38,11 +38,11 @@ verbis(int obj, Plumbmsg *m, Rule *r)
}
static void
setvar(Resub rs[10], char *match[10])
setvar(Resub rs[NMATCHSUBEXP], char *match[NMATCHSUBEXP])
{
int i, n;
for(i=0; i<10; i++){
for(i=0; i<NMATCHSUBEXP; i++){
free(match[i]);
match[i] = nil;
if(rs[i].s.sp != nil){
@ -55,7 +55,7 @@ setvar(Resub rs[10], char *match[10])
}
int
clickmatch(Reprog *re, char *text, Resub rs[10], int click)
clickmatch(Reprog *re, char *text, Resub rs[NMATCHSUBEXP], int click)
{
char *clickp;
int i, w;
@ -66,8 +66,8 @@ clickmatch(Reprog *re, char *text, Resub rs[10], int click)
w = chartorune(&r, text+i);
clickp = text+i;
for(i=0; i<=click; i++){
memset(rs, 0, 10*sizeof(Resub));
if(regexec(re, text+i, rs, 10))
memset(rs, 0, NMATCHSUBEXP*sizeof(Resub));
if(regexec(re, text+i, rs, NMATCHSUBEXP))
if(rs[0].s.sp<=clickp && clickp<=rs[0].e.ep)
return 1;
}
@ -77,7 +77,7 @@ clickmatch(Reprog *re, char *text, Resub rs[10], int click)
int
verbmatches(int obj, Plumbmsg *m, Rule *r, Exec *e)
{
Resub rs[10];
Resub rs[NMATCHSUBEXP];
char *clickval, *alltext;
int p0, p1, ntext;
@ -122,7 +122,8 @@ verbmatches(int obj, Plumbmsg *m, Rule *r, Exec *e)
/* must match full text */
if(ntext < 0)
ntext = strlen(alltext);
if(!regexec(r->regex, alltext, rs, 10) || rs[0].s.sp!=alltext || rs[0].e.ep!=alltext+ntext)
if(!regexec(r->regex, alltext, rs, NMATCHSUBEXP)
|| rs[0].s.sp!=alltext || rs[0].e.ep!=alltext+ntext)
break;
setvar(rs, e->match);
return 1;
@ -300,7 +301,7 @@ freeexec(Exec *exec)
return;
free(exec->dir);
free(exec->file);
for(i=0; i<10; i++)
for(i=0; i<NMATCHSUBEXP; i++)
free(exec->match[i]);
free(exec);
}

View file

@ -52,10 +52,15 @@ struct Ruleset
char *port;
};
enum
{
NMATCHSUBEXP = 100 /* bounded by ../../libregexp/regcomp.h:/NSUBEXP */
};
struct Exec
{
Plumbmsg *msg;
char *match[10];
char *match[NMATCHSUBEXP];
int p0; /* begin and end of match */
int p1;
int clearclick; /* click was expanded; remove attribute */

View file

@ -258,11 +258,17 @@ char*
dollar(Exec *e, char *s, int *namelen)
{
int n;
ulong m;
char *t;
static char *abuf;
*namelen = 1;
if(e!=nil && '0'<=s[0] && s[0]<='9')
return nonnil(e->match[s[0]-'0']);
if(e!=nil && '0'<=s[0] && s[0]<='9'){
m = strtoul(s, &t, 10);
*namelen = t-s;
if(t==s || m>=NMATCHSUBEXP)
return "";
return nonnil(e->match[m]);
}
n = scanvarname(s)-s;
*namelen = n;

View file

@ -122,7 +122,7 @@ scalesubfont(Subfont *f, int scale)
f->height *= scale;
f->ascent *= scale;
for(j=0; j<f->n; j++) {
for(j=0; j<=f->n; j++) {
f->info[j].x *= scale;
f->info[j].top *= scale;
f->info[j].bottom *= scale;

View file

@ -52,7 +52,7 @@ frinittick(Frame *f)
/* background color */
draw(f->tick, f->tick->r, f->cols[BACK], nil, ZP);
/* vertical line */
draw(f->tick, Rect(f->tickscale*(FRTICKW/2), 0, f->tickscale*(FRTICKW/2+1), ft->height), f->display->black, nil, ZP);
draw(f->tick, Rect(f->tickscale*(FRTICKW/2), 0, f->tickscale*(FRTICKW/2+1), ft->height), f->cols[TEXT], nil, ZP);
/* box on each end */
draw(f->tick, Rect(0, 0, f->tickscale*FRTICKW, f->tickscale*FRTICKW), f->cols[TEXT], nil, ZP);
draw(f->tick, Rect(0, ft->height-f->tickscale*FRTICKW, f->tickscale*FRTICKW, ft->height), f->cols[TEXT], nil, ZP);

View file

@ -5,7 +5,7 @@
typedef unsigned char uchar;
#define nelem(x) (sizeof(x)/sizeof((x)[0]))
#define NSUBEXP 32
#define NSUBEXP 128
typedef struct Resublist Resublist;
struct Resublist
{