ref: 717237303d368378283ad719ee4f2c580b99fd2b
dir: /sys/src/cmd/tbl/ti.c/
/* ti.c: classify line intersections */ # include "t.h" /* determine local environment for intersections */ int interv(int i, int c) { int ku, kl; if (c >= ncol || c == 0) { if (dboxflg) { if (i == 0) return(BOT); if (i >= nlin) return(TOP); return(THRU); } if (c >= ncol) return(0); } ku = i > 0 ? lefdata(i - 1, c) : 0; if (i + 1 >= nlin && allh(i)) kl = 0; else kl = lefdata(allh(i) ? i + 1 : i, c); if (ku == 2 && kl == 2) return(THRU); if (ku == 2) return(TOP); if (kl == BOT) return(2); return(0); } int interh(int i, int c) { int kl, kr; if (fullbot[i] == '=' || (dboxflg && (i == 0 || i >= nlin - 1))) { if (c == ncol) return(LEFT); if (c == 0) return(RIGHT); return(THRU); } if (i >= nlin) return(0); kl = c > 0 ? thish (i, c - 1) : 0; if (kl <= 1 && i > 0 && allh(up1(i))) kl = c > 0 ? thish(up1(i), c - 1) : 0; kr = thish(i, c); if (kr <= 1 && i > 0 && allh(up1(i))) kr = c > 0 ? thish(up1(i), c) : 0; if (kl == '=' && kr == '=') return(THRU); if (kl == '=') return(LEFT); if (kr == '=') return(RIGHT); return(0); } int up1(int i) { i--; while (instead[i] && i > 0) i--; return(i); }