+
+ Point up = START_MAIN;
+ WALK_UNTIL_MUST(up, y,-1, mainr.tl.y, '+');
+
+ Point down = START_MAIN;
+ down.y++;
+ WALK_UNTIL_MUST(down, y,+1, mainr.br.y, '+');
+
+ int xscaleunit, y,x;
+ for (y=0, xscaleunit=1; y<4; y++, xscaleunit*=10) {
+ fprintf(debug," ");
+ for (x=0; x<=width; x++) {
+ if (x % xscaleunit) fputc(' ',debug);
+ else fprintf(debug,"%d",(x / xscaleunit)%10);
+ }
+ fputc('\n',debug);
+ }
+
+ commbasey= up.y;
+ comminty= down.y - up.y + 2;
+ fprintf(debug, "up.y=%d down.y=%d commbasey=%d comminty=%d\n",
+ up.y,down.y, commbasey,comminty);
+
+ Point across= { mainr.tl.x, commbasey };
+ int colno=0;
+ for (;;) {
+ eassert(get_p(across) != '+');
+ WALK_UNTIL(across, x,+1, mainr.br.x, '+');
+ eassert(colno < MAX_COLUMNS);
+ int colrx= across.x;
+ if (colrx > mainr.br.x) colrx= mainr.br.x;
+ if (colno < INTERESTING_COLUMNS) {
+ colrightx[colno]= colrx;
+ fprintf(debug,"colrightx[%d]= %d\n",colno,colrx);
+ } else {
+ fprintf(debug,"extra colr %d %d\n",colno,colrx);
+ }
+
+ colno++;
+
+ if (across.x >= mainr.br.x-1)
+ break;
+
+ across.x++;
+ require_rectangle(across.x,mainr.tl.y, across.x,mainr.br.y, "+");
+ across.x++;
+ }
+