Hex Artifact Content
Not logged in

Artifact f57afdee031ae5c34f2635010ac030d9c8502b16:

File src/translate.c part of check-in [d5e7891b07] - Add a more advanced commit-hook mechanism that allows us to specify multiple procedures in a particular order prior to commit. Continuing work toward getting tickets going. by drh on 2007-11-18 20:48:07. Also file src/translate.c part of check-in [d0305b305a] - Merged mainline into my branch to get the newest application. by aku on 2007-12-05 08:07:46.

0000: 2f 2a 0a 2a 2a 20 43 6f 70 79 72 69 67 68 74 20  /*.** Copyright 
0010: 28 63 29 20 32 30 30 32 20 44 2e 20 52 69 63 68  (c) 2002 D. Rich
0020: 61 72 64 20 48 69 70 70 0a 2a 2a 0a 2a 2a 20 54  ard Hipp.**.** T
0030: 68 69 73 20 70 72 6f 67 72 61 6d 20 69 73 20 66  his program is f
0040: 72 65 65 20 73 6f 66 74 77 61 72 65 3b 20 79 6f  ree software; yo
0050: 75 20 63 61 6e 20 72 65 64 69 73 74 72 69 62 75  u can redistribu
0060: 74 65 20 69 74 20 61 6e 64 2f 6f 72 0a 2a 2a 20  te it and/or.** 
0070: 6d 6f 64 69 66 79 20 69 74 20 75 6e 64 65 72 20  modify it under 
0080: 74 68 65 20 74 65 72 6d 73 20 6f 66 20 74 68 65  the terms of the
0090: 20 47 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62   GNU General Pub
00a0: 6c 69 63 0a 2a 2a 20 4c 69 63 65 6e 73 65 20 61  lic.** License a
00b0: 73 20 70 75 62 6c 69 73 68 65 64 20 62 79 20 74  s published by t
00c0: 68 65 20 46 72 65 65 20 53 6f 66 74 77 61 72 65  he Free Software
00d0: 20 46 6f 75 6e 64 61 74 69 6f 6e 3b 20 65 69 74   Foundation; eit
00e0: 68 65 72 0a 2a 2a 20 76 65 72 73 69 6f 6e 20 32  her.** version 2
00f0: 20 6f 66 20 74 68 65 20 4c 69 63 65 6e 73 65 2c   of the License,
0100: 20 6f 72 20 28 61 74 20 79 6f 75 72 20 6f 70 74   or (at your opt
0110: 69 6f 6e 29 20 61 6e 79 20 6c 61 74 65 72 20 76  ion) any later v
0120: 65 72 73 69 6f 6e 2e 0a 2a 2a 0a 2a 2a 20 54 68  ersion..**.** Th
0130: 69 73 20 70 72 6f 67 72 61 6d 20 69 73 20 64 69  is program is di
0140: 73 74 72 69 62 75 74 65 64 20 69 6e 20 74 68 65  stributed in the
0150: 20 68 6f 70 65 20 74 68 61 74 20 69 74 20 77 69   hope that it wi
0160: 6c 6c 20 62 65 20 75 73 65 66 75 6c 2c 0a 2a 2a  ll be useful,.**
0170: 20 62 75 74 20 57 49 54 48 4f 55 54 20 41 4e 59   but WITHOUT ANY
0180: 20 57 41 52 52 41 4e 54 59 3b 20 77 69 74 68 6f   WARRANTY; witho
0190: 75 74 20 65 76 65 6e 20 74 68 65 20 69 6d 70 6c  ut even the impl
01a0: 69 65 64 20 77 61 72 72 61 6e 74 79 20 6f 66 0a  ied warranty of.
01b0: 2a 2a 20 4d 45 52 43 48 41 4e 54 41 42 49 4c 49  ** MERCHANTABILI
01c0: 54 59 20 6f 72 20 46 49 54 4e 45 53 53 20 46 4f  TY or FITNESS FO
01d0: 52 20 41 20 50 41 52 54 49 43 55 4c 41 52 20 50  R A PARTICULAR P
01e0: 55 52 50 4f 53 45 2e 20 20 53 65 65 20 74 68 65  URPOSE.  See the
01f0: 20 47 4e 55 0a 2a 2a 20 47 65 6e 65 72 61 6c 20   GNU.** General 
0200: 50 75 62 6c 69 63 20 4c 69 63 65 6e 73 65 20 66  Public License f
0210: 6f 72 20 6d 6f 72 65 20 64 65 74 61 69 6c 73 2e  or more details.
0220: 0a 2a 2a 20 0a 2a 2a 20 59 6f 75 20 73 68 6f 75  .** .** You shou
0230: 6c 64 20 68 61 76 65 20 72 65 63 65 69 76 65 64  ld have received
0240: 20 61 20 63 6f 70 79 20 6f 66 20 74 68 65 20 47   a copy of the G
0250: 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62 6c 69  NU General Publi
0260: 63 0a 2a 2a 20 4c 69 63 65 6e 73 65 20 61 6c 6f  c.** License alo
0270: 6e 67 20 77 69 74 68 20 74 68 69 73 20 6c 69 62  ng with this lib
0280: 72 61 72 79 3b 20 69 66 20 6e 6f 74 2c 20 77 72  rary; if not, wr
0290: 69 74 65 20 74 6f 20 74 68 65 0a 2a 2a 20 46 72  ite to the.** Fr
02a0: 65 65 20 53 6f 66 74 77 61 72 65 20 46 6f 75 6e  ee Software Foun
02b0: 64 61 74 69 6f 6e 2c 20 49 6e 63 2e 2c 20 35 39  dation, Inc., 59
02c0: 20 54 65 6d 70 6c 65 20 50 6c 61 63 65 20 2d 20   Temple Place - 
02d0: 53 75 69 74 65 20 33 33 30 2c 0a 2a 2a 20 42 6f  Suite 330,.** Bo
02e0: 73 74 6f 6e 2c 20 4d 41 20 20 30 32 31 31 31 2d  ston, MA  02111-
02f0: 31 33 30 37 2c 20 55 53 41 2e 0a 2a 2a 0a 2a 2a  1307, USA..**.**
0300: 20 41 75 74 68 6f 72 20 63 6f 6e 74 61 63 74 20   Author contact 
0310: 69 6e 66 6f 72 6d 61 74 69 6f 6e 3a 0a 2a 2a 20  information:.** 
0320: 20 20 64 72 68 40 68 77 61 63 69 2e 63 6f 6d 0a    drh@hwaci.com.
0330: 2a 2a 20 20 20 68 74 74 70 3a 2f 2f 77 77 77 2e  **   http://www.
0340: 68 77 61 63 69 2e 63 6f 6d 2f 64 72 68 2f 0a 2a  hwaci.com/drh/.*
0350: 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  *.**************
0360: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0370: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0380: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0390: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
03a0: 2a 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 70 72 6f  *.**.** This pro
03b0: 67 72 61 6d 20 72 65 61 64 73 20 43 20 73 6f 75  gram reads C sou
03c0: 72 63 65 20 63 6f 64 65 20 66 72 6f 6d 20 73 74  rce code from st
03d0: 61 6e 64 61 72 64 20 69 6e 70 75 74 2e 20 20 4c  andard input.  L
03e0: 69 6e 65 73 20 74 68 61 74 0a 2a 2a 20 62 65 67  ines that.** beg
03f0: 69 6e 20 77 69 74 68 20 74 68 65 20 22 40 22 20  in with the "@" 
0400: 63 68 61 72 61 63 74 65 72 20 61 72 65 20 74 72  character are tr
0410: 61 6e 73 6c 61 74 65 64 20 69 6e 74 6f 20 63 67  anslated into cg
0420: 69 5f 70 72 69 6e 74 66 28 29 20 73 74 61 74 65  i_printf() state
0430: 6d 65 6e 74 73 0a 2a 2a 20 61 6e 64 20 74 68 65  ments.** and the
0440: 20 74 72 61 6e 73 6c 61 74 65 64 20 63 6f 64 65   translated code
0450: 20 69 73 20 77 72 69 74 74 65 6e 20 6f 6e 20 73   is written on s
0460: 74 61 6e 64 61 72 64 20 6f 75 74 70 75 74 2e 0a  tandard output..
0470: 2a 2a 0a 2a 2a 20 54 68 65 20 70 72 6f 62 6c 65  **.** The proble
0480: 6d 20 74 68 69 73 20 70 72 6f 67 72 61 6d 20 69  m this program i
0490: 73 20 61 74 74 65 6d 70 74 20 74 6f 20 73 6f 6c  s attempt to sol
04a0: 76 65 20 69 73 20 61 73 20 66 6f 6c 6c 6f 77 73  ve is as follows
04b0: 3a 20 20 57 68 65 6e 0a 2a 2a 20 77 72 69 74 69  :  When.** writi
04c0: 6e 67 20 43 47 49 20 70 72 6f 67 72 61 6d 73 20  ng CGI programs 
04d0: 69 6e 20 43 2c 20 77 65 20 74 79 70 69 63 61 6c  in C, we typical
04e0: 6c 79 20 77 61 6e 74 20 74 6f 20 6f 75 74 70 75  ly want to outpu
04f0: 74 20 61 20 6c 6f 74 20 6f 66 20 48 54 4d 4c 0a  t a lot of HTML.
0500: 2a 2a 20 74 65 78 74 20 74 6f 20 73 74 61 6e 64  ** text to stand
0510: 61 72 64 20 6f 75 74 70 75 74 2e 20 20 49 6e 20  ard output.  In 
0520: 70 75 72 65 20 43 20 63 6f 64 65 2c 20 74 68 69  pure C code, thi
0530: 73 20 69 6e 76 6f 6c 76 65 73 20 64 6f 69 6e 67  s involves doing
0540: 20 61 0a 2a 2a 20 70 72 69 6e 74 66 28 29 20 77   a.** printf() w
0550: 69 74 68 20 61 20 62 69 67 20 73 74 72 69 6e 67  ith a big string
0560: 20 63 6f 6e 74 61 69 6e 69 6e 67 20 61 6c 6c 20   containing all 
0570: 74 68 61 74 20 74 65 78 74 2e 20 20 42 75 74 20  that text.  But 
0580: 77 65 20 68 61 76 65 0a 2a 2a 20 74 6f 20 69 6e  we have.** to in
0590: 73 65 72 74 20 73 70 65 63 69 61 6c 20 63 6f 64  sert special cod
05a0: 65 73 20 28 65 78 3a 20 5c 6e 20 61 6e 64 20 5c  es (ex: \n and \
05b0: 22 29 20 66 6f 72 20 6d 61 6e 79 20 63 6f 6d 6d  ") for many comm
05c0: 6f 6e 20 63 68 61 72 61 63 74 65 72 73 2c 0a 2a  on characters,.*
05d0: 2a 20 77 68 69 63 68 20 69 6e 74 65 72 66 65 72  * which interfer
05e0: 65 73 20 77 69 74 68 20 74 68 65 20 72 65 61 64  es with the read
05f0: 61 62 69 6c 69 74 79 20 6f 66 20 74 68 65 20 48  ability of the H
0600: 54 4d 4c 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20  TML..**.** This 
0610: 74 6f 6f 6c 20 61 6c 6c 6f 77 73 20 75 73 20 74  tool allows us t
0620: 6f 20 70 75 74 20 72 61 77 20 48 54 4d 4c 2c 20  o put raw HTML, 
0630: 77 69 74 68 6f 75 74 20 74 68 65 20 73 70 65 63  without the spec
0640: 69 61 6c 20 63 6f 64 65 73 2c 20 69 6e 0a 2a 2a  ial codes, in.**
0650: 20 74 68 65 20 6d 69 64 64 6c 65 20 6f 66 20 61   the middle of a
0660: 20 43 20 70 72 6f 67 72 61 6d 2e 20 20 54 68 69   C program.  Thi
0670: 73 20 70 72 6f 67 72 61 6d 20 74 68 65 6e 20 74  s program then t
0680: 72 61 6e 73 6c 61 74 65 73 20 74 68 65 20 74 65  ranslates the te
0690: 78 74 0a 2a 2a 20 69 6e 74 6f 20 73 74 61 6e 64  xt.** into stand
06a0: 61 72 64 20 43 20 62 79 20 69 6e 73 65 72 74 69  ard C by inserti
06b0: 6e 67 20 61 6c 6c 20 6e 65 63 65 73 73 61 72 79  ng all necessary
06c0: 20 62 61 63 6b 73 6c 61 73 68 65 73 20 61 6e 64   backslashes and
06d0: 20 6f 74 68 65 72 0a 2a 2a 20 70 75 6e 63 74 75   other.** punctu
06e0: 61 74 69 6f 6e 2e 0a 2a 2f 0a 23 69 6e 63 6c 75  ation..*/.#inclu
06f0: 64 65 20 3c 73 74 64 69 6f 2e 68 3e 0a 23 69 6e  de <stdio.h>.#in
0700: 63 6c 75 64 65 20 3c 63 74 79 70 65 2e 68 3e 0a  clude <ctype.h>.
0710: 23 69 6e 63 6c 75 64 65 20 3c 73 74 64 6c 69 62  #include <stdlib
0720: 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74  .h>.#include <st
0730: 72 69 6e 67 2e 68 3e 0a 0a 2f 2a 0a 2a 2a 20 53  ring.h>../*.** S
0740: 70 61 63 65 20 74 6f 20 68 6f 6c 64 20 61 72 67  pace to hold arg
0750: 75 6d 65 6e 74 73 20 61 74 20 74 68 65 20 65 6e  uments at the en
0760: 64 20 6f 66 20 74 68 65 20 63 67 69 5f 70 72 69  d of the cgi_pri
0770: 6e 74 66 28 29 0a 2a 2f 0a 23 64 65 66 69 6e 65  ntf().*/.#define
0780: 20 4d 58 5f 41 52 47 5f 53 50 20 31 30 30 30 30   MX_ARG_SP 10000
0790: 0a 73 74 61 74 69 63 20 63 68 61 72 20 7a 41 72  .static char zAr
07a0: 67 5b 4d 58 5f 41 52 47 5f 53 50 5d 3b 0a 73 74  g[MX_ARG_SP];.st
07b0: 61 74 69 63 20 69 6e 74 20 6e 41 72 67 20 3d 20  atic int nArg = 
07c0: 30 3b 0a 0a 2f 2a 0a 2a 2a 20 54 72 75 65 20 69  0;../*.** True i
07d0: 66 20 77 65 20 61 72 65 20 63 75 72 72 65 6e 74  f we are current
07e0: 6c 79 20 69 6e 20 61 20 63 67 69 5f 70 72 69 6e  ly in a cgi_prin
07f0: 74 66 28 29 0a 2a 2f 0a 73 74 61 74 69 63 20 69  tf().*/.static i
0800: 6e 74 20 69 6e 50 72 69 6e 74 20 3d 20 30 3b 0a  nt inPrint = 0;.
0810: 0a 2f 2a 0a 2a 2a 20 54 72 75 65 20 69 66 20 77  ./*.** True if w
0820: 65 20 61 72 65 20 63 75 72 72 65 6e 74 6c 79 20  e are currently 
0830: 64 6f 69 6e 67 20 61 20 66 72 65 65 20 73 74 72  doing a free str
0840: 69 6e 67 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  ing.*/.static in
0850: 74 20 69 6e 53 74 72 20 3d 20 30 3b 0a 0a 2f 2a  t inStr = 0;../*
0860: 0a 2a 2a 20 54 65 72 6d 69 6e 61 74 65 20 61 6e  .** Terminate an
0870: 20 61 63 74 69 76 65 20 63 67 69 5f 70 72 69 6e   active cgi_prin
0880: 74 66 28 29 20 6f 72 20 66 72 65 65 20 73 74 72  tf() or free str
0890: 69 6e 67 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f  ing.*/.static vo
08a0: 69 64 20 65 6e 64 5f 62 6c 6f 63 6b 28 46 49 4c  id end_block(FIL
08b0: 45 20 2a 6f 75 74 29 7b 0a 20 20 69 66 28 20 69  E *out){.  if( i
08c0: 6e 50 72 69 6e 74 20 29 7b 0a 20 20 20 20 7a 41  nPrint ){.    zA
08d0: 72 67 5b 6e 41 72 67 5d 20 3d 20 30 3b 0a 20 20  rg[nArg] = 0;.  
08e0: 20 20 66 70 72 69 6e 74 66 28 6f 75 74 2c 20 22    fprintf(out, "
08f0: 25 73 29 3b 5c 6e 22 2c 20 7a 41 72 67 29 3b 0a  %s);\n", zArg);.
0900: 20 20 20 20 6e 41 72 67 20 3d 20 30 3b 0a 20 20      nArg = 0;.  
0910: 20 20 69 6e 50 72 69 6e 74 20 3d 20 30 3b 0a 20    inPrint = 0;. 
0920: 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 72 61 6e   }.}../*.** Tran
0930: 73 6c 61 74 65 20 74 68 65 20 69 6e 70 75 74 20  slate the input 
0940: 73 74 72 65 61 6d 20 69 6e 74 6f 20 74 68 65 20  stream into the 
0950: 6f 75 74 70 75 74 20 73 74 72 65 61 6d 0a 2a 2f  output stream.*/
0960: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 74 72 61  .static void tra
0970: 6e 73 28 46 49 4c 45 20 2a 69 6e 2c 20 46 49 4c  ns(FILE *in, FIL
0980: 45 20 2a 6f 75 74 29 7b 0a 20 20 69 6e 74 20 69  E *out){.  int i
0990: 2c 20 6a 2c 20 6b 3b 20 20 20 20 20 20 20 20 2f  , j, k;        /
09a0: 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74 65 72 73 20  * Loop counters 
09b0: 2a 2f 0a 20 20 63 68 61 72 20 63 31 2c 20 63 32  */.  char c1, c2
09c0: 3b 20 20 20 20 20 20 20 20 2f 2a 20 43 68 61 72  ;        /* Char
09d0: 61 63 74 65 72 73 20 75 73 65 64 20 74 6f 20 73  acters used to s
09e0: 74 61 72 74 20 61 20 63 6f 6d 6d 65 6e 74 20 2a  tart a comment *
09f0: 2f 0a 20 20 69 6e 74 20 6c 61 73 74 57 61 73 45  /.  int lastWasE
0a00: 71 20 3d 20 30 3b 20 20 2f 2a 20 54 72 75 65 20  q = 0;  /* True 
0a10: 69 66 20 6c 61 73 74 20 6e 6f 6e 2d 77 68 69 74  if last non-whit
0a20: 65 73 70 61 63 65 20 63 68 61 72 61 63 74 65 72  espace character
0a30: 20 77 61 73 20 22 3d 22 20 2a 2f 0a 20 20 63 68   was "=" */.  ch
0a40: 61 72 20 7a 4c 69 6e 65 5b 32 30 30 30 5d 3b 20  ar zLine[2000]; 
0a50: 20 20 2f 2a 20 41 20 73 69 6e 67 6c 65 20 6c 69    /* A single li
0a60: 6e 65 20 6f 66 20 69 6e 70 75 74 20 2a 2f 0a 20  ne of input */. 
0a70: 20 63 68 61 72 20 7a 4f 75 74 5b 34 30 30 30 5d   char zOut[4000]
0a80: 3b 20 20 20 20 2f 2a 20 54 68 65 20 69 6e 70 75  ;    /* The inpu
0a90: 74 20 6c 69 6e 65 20 74 72 61 6e 73 6c 61 74 65  t line translate
0aa0: 64 20 69 6e 74 6f 20 61 70 70 72 6f 70 72 69 61  d into appropria
0ab0: 74 65 20 6f 75 74 70 75 74 20 2a 2f 0a 0a 20 20  te output */..  
0ac0: 63 31 20 3d 20 63 32 20 3d 20 27 2d 27 3b 0a 20  c1 = c2 = '-';. 
0ad0: 20 77 68 69 6c 65 28 20 66 67 65 74 73 28 7a 4c   while( fgets(zL
0ae0: 69 6e 65 2c 20 73 69 7a 65 6f 66 28 7a 4c 69 6e  ine, sizeof(zLin
0af0: 65 29 2c 20 69 6e 29 20 29 7b 0a 20 20 20 20 66  e), in) ){.    f
0b00: 6f 72 28 69 3d 30 3b 20 7a 4c 69 6e 65 5b 69 5d  or(i=0; zLine[i]
0b10: 20 26 26 20 69 73 73 70 61 63 65 28 7a 4c 69 6e   && isspace(zLin
0b20: 65 5b 69 5d 29 3b 20 69 2b 2b 29 7b 7d 0a 20 20  e[i]); i++){}.  
0b30: 20 20 69 66 28 20 7a 4c 69 6e 65 5b 69 5d 21 3d    if( zLine[i]!=
0b40: 27 40 27 20 29 7b 0a 20 20 20 20 20 20 69 66 28  '@' ){.      if(
0b50: 20 69 6e 50 72 69 6e 74 20 7c 7c 20 69 6e 53 74   inPrint || inSt
0b60: 72 20 29 20 65 6e 64 5f 62 6c 6f 63 6b 28 6f 75  r ) end_block(ou
0b70: 74 29 3b 0a 20 20 20 20 20 20 66 70 72 69 6e 74  t);.      fprint
0b80: 66 28 6f 75 74 2c 22 25 73 22 2c 7a 4c 69 6e 65  f(out,"%s",zLine
0b90: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  );.             
0ba0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 30 31 32            /* 012
0bb0: 33 34 35 36 37 38 39 20 31 32 33 34 35 20 2a 2f  3456789 12345 */
0bc0: 0a 20 20 20 20 20 20 69 66 28 20 73 74 72 6e 63  .      if( strnc
0bd0: 6d 70 28 7a 4c 69 6e 65 2c 20 22 2f 2a 20 40 2d  mp(zLine, "/* @-
0be0: 63 6f 6d 6d 65 6e 74 3a 20 22 2c 20 31 34 29 3d  comment: ", 14)=
0bf0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 63 31  =0 ){.        c1
0c00: 20 3d 20 7a 4c 69 6e 65 5b 31 34 5d 3b 0a 20 20   = zLine[14];.  
0c10: 20 20 20 20 20 20 63 32 20 3d 20 7a 4c 69 6e 65        c2 = zLine
0c20: 5b 31 35 5d 3b 0a 20 20 20 20 20 20 7d 0a 20 20  [15];.      }.  
0c30: 20 20 20 20 69 20 2b 3d 20 73 74 72 6c 65 6e 28      i += strlen(
0c40: 26 7a 4c 69 6e 65 5b 69 5d 29 3b 0a 20 20 20 20  &zLine[i]);.    
0c50: 20 20 77 68 69 6c 65 28 20 69 3e 30 20 26 26 20    while( i>0 && 
0c60: 69 73 73 70 61 63 65 28 7a 4c 69 6e 65 5b 69 2d  isspace(zLine[i-
0c70: 31 5d 29 20 29 7b 20 69 2d 2d 3b 20 7d 0a 20 20  1]) ){ i--; }.  
0c80: 20 20 20 20 6c 61 73 74 57 61 73 45 71 20 3d 20      lastWasEq = 
0c90: 69 3e 30 20 26 26 20 7a 4c 69 6e 65 5b 69 2d 31  i>0 && zLine[i-1
0ca0: 5d 3d 3d 27 3d 27 3b 0a 20 20 20 20 7d 65 6c 73  ]=='=';.    }els
0cb0: 65 20 69 66 28 20 6c 61 73 74 57 61 73 45 71 20  e if( lastWasEq 
0cc0: 29 7b 0a 20 20 20 20 20 20 2f 2a 20 49 66 20 74  ){.      /* If t
0cd0: 68 65 20 6c 61 73 74 20 6e 6f 6e 2d 77 68 69 74  he last non-whit
0ce0: 65 73 70 61 63 65 20 63 68 61 72 61 63 74 65 72  espace character
0cf0: 20 62 65 66 6f 72 65 20 74 68 65 20 66 69 72 73   before the firs
0d00: 74 20 40 20 77 61 73 0a 20 20 20 20 20 20 2a 2a  t @ was.      **
0d10: 20 61 6e 20 22 3d 22 20 74 68 65 6e 20 67 65 6e   an "=" then gen
0d20: 65 72 61 74 65 20 61 20 73 74 72 69 6e 67 20 6c  erate a string l
0d30: 69 74 65 72 61 6c 2e 20 20 42 75 74 20 73 6b 69  iteral.  But ski
0d40: 70 20 63 6f 6d 6d 65 6e 74 73 0a 20 20 20 20 20  p comments.     
0d50: 20 2a 2a 20 63 6f 6e 73 69 73 74 69 6e 67 20 6f   ** consisting o
0d60: 66 20 61 6c 6c 20 74 65 78 74 20 62 65 74 77 65  f all text betwe
0d70: 65 6e 20 63 31 20 61 6e 64 20 63 32 20 28 64 65  en c1 and c2 (de
0d80: 66 61 75 6c 74 20 22 2d 2d 22 29 0a 20 20 20 20  fault "--").    
0d90: 20 20 2a 2a 20 61 6e 64 20 65 6e 64 20 6f 66 20    ** and end of 
0da0: 6c 69 6e 65 2e 0a 20 20 20 20 20 20 2a 2f 0a 20  line..      */. 
0db0: 20 20 20 20 20 69 6e 74 20 69 6e 64 65 6e 74 2c       int indent,
0dc0: 20 6f 6d 69 74 6c 69 6e 65 3b 0a 20 20 20 20 20   omitline;.     
0dd0: 20 69 2b 2b 3b 0a 20 20 20 20 20 20 69 66 28 20   i++;.      if( 
0de0: 69 73 73 70 61 63 65 28 7a 4c 69 6e 65 5b 69 5d  isspace(zLine[i]
0df0: 29 20 29 7b 20 69 2b 2b 3b 20 7d 0a 20 20 20 20  ) ){ i++; }.    
0e00: 20 20 69 6e 64 65 6e 74 20 3d 20 69 20 2d 20 32    indent = i - 2
0e10: 3b 0a 20 20 20 20 20 20 69 66 28 20 69 6e 64 65  ;.      if( inde
0e20: 6e 74 3c 30 20 29 20 69 6e 64 65 6e 74 20 3d 20  nt<0 ) indent = 
0e30: 30 3b 0a 20 20 20 20 20 20 6f 6d 69 74 6c 69 6e  0;.      omitlin
0e40: 65 20 3d 20 30 3b 0a 20 20 20 20 20 20 66 6f 72  e = 0;.      for
0e50: 28 6a 3d 30 3b 20 7a 4c 69 6e 65 5b 69 5d 20 26  (j=0; zLine[i] &
0e60: 26 20 7a 4c 69 6e 65 5b 69 5d 21 3d 27 5c 72 27  & zLine[i]!='\r'
0e70: 20 26 26 20 7a 4c 69 6e 65 5b 69 5d 21 3d 27 5c   && zLine[i]!='\
0e80: 6e 27 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  n'; i++){.      
0e90: 20 20 69 66 28 20 7a 4c 69 6e 65 5b 69 5d 3d 3d    if( zLine[i]==
0ea0: 63 31 20 26 26 20 28 63 32 3d 3d 27 20 27 20 7c  c1 && (c2==' ' |
0eb0: 7c 20 7a 4c 69 6e 65 5b 69 2b 31 5d 3d 3d 63 32  | zLine[i+1]==c2
0ec0: 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20  ) ){.           
0ed0: 6f 6d 69 74 6c 69 6e 65 20 3d 20 31 3b 20 62 72  omitline = 1; br
0ee0: 65 61 6b 3b 20 0a 20 20 20 20 20 20 20 20 7d 0a  eak; .        }.
0ef0: 20 20 20 20 20 20 20 20 69 66 28 20 7a 4c 69 6e          if( zLin
0f00: 65 5b 69 5d 3d 3d 27 22 27 20 7c 7c 20 7a 4c 69  e[i]=='"' || zLi
0f10: 6e 65 5b 69 5d 3d 3d 27 5c 5c 27 20 29 7b 20 7a  ne[i]=='\\' ){ z
0f20: 4f 75 74 5b 6a 2b 2b 5d 20 3d 20 27 5c 5c 27 3b  Out[j++] = '\\';
0f30: 20 7d 0a 20 20 20 20 20 20 20 20 7a 4f 75 74 5b   }.        zOut[
0f40: 6a 2b 2b 5d 20 3d 20 7a 4c 69 6e 65 5b 69 5d 3b  j++] = zLine[i];
0f50: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 77  .      }.      w
0f60: 68 69 6c 65 28 20 6a 3e 30 20 26 26 20 69 73 73  hile( j>0 && iss
0f70: 70 61 63 65 28 7a 4f 75 74 5b 6a 2d 31 5d 29 20  pace(zOut[j-1]) 
0f80: 29 7b 20 6a 2d 2d 3b 20 7d 0a 20 20 20 20 20 20  ){ j--; }.      
0f90: 7a 4f 75 74 5b 6a 5d 20 3d 20 30 3b 0a 20 20 20  zOut[j] = 0;.   
0fa0: 20 20 20 69 66 28 20 6a 3c 3d 30 20 26 26 20 6f     if( j<=0 && o
0fb0: 6d 69 74 6c 69 6e 65 20 29 7b 0a 20 20 20 20 20  mitline ){.     
0fc0: 20 20 20 66 70 72 69 6e 74 66 28 6f 75 74 2c 22     fprintf(out,"
0fd0: 5c 6e 22 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73  \n");.      }els
0fe0: 65 7b 0a 20 20 20 20 20 20 20 20 66 70 72 69 6e  e{.        fprin
0ff0: 74 66 28 6f 75 74 2c 22 25 2a 73 5c 22 25 73 5c  tf(out,"%*s\"%s\
1000: 5c 6e 5c 22 5c 6e 22 2c 69 6e 64 65 6e 74 2c 20  \n\"\n",indent, 
1010: 22 22 2c 20 7a 4f 75 74 29 3b 0a 20 20 20 20 20  "", zOut);.     
1020: 20 7d 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20   }.    }else{.  
1030: 20 20 20 20 2f 2a 20 4f 74 68 65 72 77 69 73 65      /* Otherwise
1040: 20 28 69 66 20 74 68 65 20 6c 61 73 74 20 6e 6f   (if the last no
1050: 6e 2d 77 68 69 74 65 73 70 61 63 65 20 77 61 73  n-whitespace was
1060: 20 6e 6f 74 20 27 3d 27 29 20 74 68 65 6e 20 67   not '=') then g
1070: 65 6e 65 72 61 74 65 0a 20 20 20 20 20 20 2a 2a  enerate.      **
1080: 20 61 20 63 67 69 5f 70 72 69 6e 74 66 28 29 20   a cgi_printf() 
1090: 73 74 61 74 65 6d 65 6e 74 20 77 68 6f 73 65 20  statement whose 
10a0: 66 6f 72 6d 61 74 20 69 73 20 74 68 65 20 74 65  format is the te
10b0: 78 74 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 68 65  xt following the
10c0: 20 27 40 27 2e 0a 20 20 20 20 20 20 2a 2a 20 53   '@'..      ** S
10d0: 75 62 73 74 72 69 6e 67 73 20 6f 66 20 74 68 65  ubstrings of the
10e0: 20 66 6f 72 6d 20 22 25 43 28 2e 2e 2e 29 22 20   form "%C(...)" 
10f0: 77 68 65 72 65 20 43 20 69 73 20 61 6e 79 20 63  where C is any c
1100: 68 61 72 61 63 74 65 72 20 77 69 6c 6c 0a 20 20  haracter will.  
1110: 20 20 20 20 2a 2a 20 70 75 74 73 20 22 25 43 22      ** puts "%C"
1120: 20 69 6e 20 74 68 65 20 66 6f 72 6d 61 74 20 61   in the format a
1130: 6e 64 20 61 64 64 20 74 68 65 20 22 2e 2e 2e 22  nd add the "..."
1140: 20 61 73 20 61 6e 20 61 72 67 75 6d 65 6e 74 20   as an argument 
1150: 74 6f 20 74 68 65 0a 20 20 20 20 20 20 2a 2a 20  to the.      ** 
1160: 63 67 69 5f 70 72 69 6e 74 66 20 63 61 6c 6c 2e  cgi_printf call.
1170: 0a 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20  .      */.      
1180: 69 6e 74 20 69 6e 64 65 6e 74 3b 0a 20 20 20 20  int indent;.    
1190: 20 20 69 2b 2b 3b 0a 20 20 20 20 20 20 69 66 28    i++;.      if(
11a0: 20 69 73 73 70 61 63 65 28 7a 4c 69 6e 65 5b 69   isspace(zLine[i
11b0: 5d 29 20 29 7b 20 69 2b 2b 3b 20 7d 0a 20 20 20  ]) ){ i++; }.   
11c0: 20 20 20 69 6e 64 65 6e 74 20 3d 20 69 3b 0a 20     indent = i;. 
11d0: 20 20 20 20 20 66 6f 72 28 6a 3d 30 3b 20 7a 4c       for(j=0; zL
11e0: 69 6e 65 5b 69 5d 20 26 26 20 7a 4c 69 6e 65 5b  ine[i] && zLine[
11f0: 69 5d 21 3d 27 5c 72 27 20 26 26 20 7a 4c 69 6e  i]!='\r' && zLin
1200: 65 5b 69 5d 21 3d 27 5c 6e 27 3b 20 69 2b 2b 29  e[i]!='\n'; i++)
1210: 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 7a 4c  {.        if( zL
1220: 69 6e 65 5b 69 5d 3d 3d 27 22 27 20 7c 7c 20 7a  ine[i]=='"' || z
1230: 4c 69 6e 65 5b 69 5d 3d 3d 27 5c 5c 27 20 29 7b  Line[i]=='\\' ){
1240: 20 7a 4f 75 74 5b 6a 2b 2b 5d 20 3d 20 27 5c 5c   zOut[j++] = '\\
1250: 27 3b 20 7d 0a 20 20 20 20 20 20 20 20 7a 4f 75  '; }.        zOu
1260: 74 5b 6a 2b 2b 5d 20 3d 20 7a 4c 69 6e 65 5b 69  t[j++] = zLine[i
1270: 5d 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 7a  ];.        if( z
1280: 4c 69 6e 65 5b 69 5d 21 3d 27 25 27 20 7c 7c 20  Line[i]!='%' || 
1290: 7a 4c 69 6e 65 5b 69 2b 31 5d 3d 3d 27 25 27 20  zLine[i+1]=='%' 
12a0: 7c 7c 20 7a 4c 69 6e 65 5b 69 2b 31 5d 3d 3d 30  || zLine[i+1]==0
12b0: 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20   ) continue;.   
12c0: 20 20 20 20 20 69 66 28 20 7a 4c 69 6e 65 5b 69       if( zLine[i
12d0: 2b 32 5d 21 3d 27 28 27 20 29 20 63 6f 6e 74 69  +2]!='(' ) conti
12e0: 6e 75 65 3b 0a 20 20 20 20 20 20 20 20 69 2b 2b  nue;.        i++
12f0: 3b 0a 20 20 20 20 20 20 20 20 7a 4f 75 74 5b 6a  ;.        zOut[j
1300: 2b 2b 5d 20 3d 20 7a 4c 69 6e 65 5b 69 5d 3b 0a  ++] = zLine[i];.
1310: 20 20 20 20 20 20 20 20 7a 41 72 67 5b 6e 41 72          zArg[nAr
1320: 67 2b 2b 5d 20 3d 20 27 2c 27 3b 0a 20 20 20 20  g++] = ',';.    
1330: 20 20 20 20 69 20 2b 3d 20 32 3b 0a 20 20 20 20      i += 2;.    
1340: 20 20 20 20 6b 20 3d 20 31 3b 0a 20 20 20 20 20      k = 1;.     
1350: 20 20 20 77 68 69 6c 65 28 20 7a 4c 69 6e 65 5b     while( zLine[
1360: 69 5d 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  i] ){.          
1370: 69 66 28 20 7a 4c 69 6e 65 5b 69 5d 3d 3d 27 29  if( zLine[i]==')
1380: 27 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20  ' ){.           
1390: 20 6b 2d 2d 3b 0a 20 20 20 20 20 20 20 20 20 20   k--;.          
13a0: 20 20 69 66 28 20 6b 3d 3d 30 20 29 20 62 72 65    if( k==0 ) bre
13b0: 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 65  ak;.          }e
13c0: 6c 73 65 20 69 66 28 20 7a 4c 69 6e 65 5b 69 5d  lse if( zLine[i]
13d0: 3d 3d 27 28 27 20 29 7b 0a 20 20 20 20 20 20 20  =='(' ){.       
13e0: 20 20 20 20 20 6b 2b 2b 3b 0a 20 20 20 20 20 20       k++;.      
13f0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
1400: 7a 41 72 67 5b 6e 41 72 67 2b 2b 5d 20 3d 20 7a  zArg[nArg++] = z
1410: 4c 69 6e 65 5b 69 2b 2b 5d 3b 0a 20 20 20 20 20  Line[i++];.     
1420: 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20     }.      }.   
1430: 20 20 20 7a 4f 75 74 5b 6a 5d 20 3d 20 30 3b 0a     zOut[j] = 0;.
1440: 20 20 20 20 20 20 69 66 28 20 21 69 6e 50 72 69        if( !inPri
1450: 6e 74 20 29 7b 0a 20 20 20 20 20 20 20 20 66 70  nt ){.        fp
1460: 72 69 6e 74 66 28 6f 75 74 2c 22 25 2a 73 63 67  rintf(out,"%*scg
1470: 69 5f 70 72 69 6e 74 66 28 5c 22 25 73 5c 5c 6e  i_printf(\"%s\\n
1480: 5c 22 22 2c 69 6e 64 65 6e 74 2d 32 2c 22 22 2c  \"",indent-2,"",
1490: 20 7a 4f 75 74 29 3b 0a 20 20 20 20 20 20 20 20   zOut);.        
14a0: 69 6e 50 72 69 6e 74 20 3d 20 31 3b 0a 20 20 20  inPrint = 1;.   
14b0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
14c0: 20 20 66 70 72 69 6e 74 66 28 6f 75 74 2c 22 5c    fprintf(out,"\
14d0: 6e 25 2a 73 5c 22 25 73 5c 5c 6e 5c 22 22 2c 69  n%*s\"%s\\n\"",i
14e0: 6e 64 65 6e 74 2b 35 2c 20 22 22 2c 20 7a 4f 75  ndent+5, "", zOu
14f0: 74 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  t);.      }.    
1500: 7d 20 20 20 20 20 20 0a 20 20 7d 0a 7d 0a 0a 69  }      .  }.}..i
1510: 6e 74 20 6d 61 69 6e 28 69 6e 74 20 61 72 67 63  nt main(int argc
1520: 2c 20 63 68 61 72 20 2a 2a 61 72 67 76 29 7b 0a  , char **argv){.
1530: 20 20 69 66 28 20 61 72 67 63 3d 3d 32 20 29 7b    if( argc==2 ){
1540: 0a 20 20 20 20 46 49 4c 45 20 2a 69 6e 20 3d 20  .    FILE *in = 
1550: 66 6f 70 65 6e 28 61 72 67 76 5b 31 5d 2c 20 22  fopen(argv[1], "
1560: 72 22 29 3b 0a 20 20 20 20 69 66 28 20 69 6e 3d  r");.    if( in=
1570: 3d 30 20 29 7b 0a 20 20 20 20 20 20 66 70 72 69  =0 ){.      fpri
1580: 6e 74 66 28 73 74 64 65 72 72 2c 22 63 61 6e 20  ntf(stderr,"can 
1590: 6e 6f 74 20 6f 70 65 6e 20 25 73 5c 6e 22 2c 20  not open %s\n", 
15a0: 61 72 67 76 5b 31 5d 29 3b 0a 20 20 20 20 20 20  argv[1]);.      
15b0: 65 78 69 74 28 31 29 3b 0a 20 20 20 20 7d 0a 20  exit(1);.    }. 
15c0: 20 20 20 74 72 61 6e 73 28 69 6e 2c 20 73 74 64     trans(in, std
15d0: 6f 75 74 29 3b 0a 20 20 20 20 66 63 6c 6f 73 65  out);.    fclose
15e0: 28 69 6e 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20  (in);.  }else{. 
15f0: 20 20 20 74 72 61 6e 73 28 73 74 64 69 6e 2c 20     trans(stdin, 
1600: 73 74 64 6f 75 74 29 3b 0a 20 20 7d 0a 20 20 72  stdout);.  }.  r
1610: 65 74 75 72 6e 20 30 3b 0a 7d 0a                 eturn 0;.}.