ref: 46473dabaa54037f2d0376653dfab75ff3c03301
parent: 5d347485e57b91134cd4f68b05a8a783896fed5c
author: Noam Preil <[email protected]>
date: Thu Apr 7 12:03:30 EDT 2022
op: implement word spacing
--- a/op.c
+++ b/op.c
@@ -362,8 +362,8 @@
static int
tswspace(Op *op, Page *p)
{
- USED(op, p);
- return 0;
+ p->TS.Tw = arrayget(p->stack, 0)->num.d;
+ return 1;
}
static int
@@ -449,6 +449,7 @@
p->TS.inobj = 1;
p->TS.TL = 0;
p->TS.Tc = 0;
+ p->TS.Tw = 0;
p->GSactive->Font.font = nil;
return flagless(op);
}
@@ -617,14 +618,16 @@
else
w0 = (double)p->GSactive->Font.defwidth / 1000;
tx = w0 * p->GSactive->Font.size + p->TS.Tc;
+ if(c == ' ')
+ tx += p->TS.Tw;
// Check if whitespace is needed
if(p->buf.sz > 1){
if(p->TS.y != Trm[5]){
- for(i = 0; i < (int)((p->TS.y - Trm[5]) / p->GSactive->Font.size); i += 1)
+ for(i = 0; i < (int)((p->TS.y - Trm[5]) / p->GSactive->Font.size) && i < 1; i += 1)
if(bufput(&p->buf, (uchar*)"\n", 1) != 1)
return 0;
}
- if(Trm[4] - p->TS.x > 2.5){
+ if(Trm[4] - p->TS.x > 14){
if(bufput(&p->buf, (uchar*)" ", 1) != 1)
return 0;
}
@@ -677,8 +680,7 @@
return 0;
}
else{
- double shift = 0 - (p->GSactive->Font.size * o->num.d / 1000);
- if(!tmove(p, shift, 0, 0))
+ if(!tmove(p, 0 - (o->num.d / 1000), 0, 0))
return 0;
}
}
--- a/pdf.h
+++ b/pdf.h
@@ -142,7 +142,7 @@
double Tlm[6]; /* text line matrix */
/* Tracks if we're in a text object; nesting is verboten */
int inobj;
- double TL, Tc;
+ double TL, Tc, Tw;
/* Temporary, for pdf2txt functionality: tracks the last character's position so we know whether whitespace is needed */
double x, y;
};