SourceFormatX

軟體簡介

主要功能

為什麼要使用

源碼美化演示

整合和插件

界面預覽

常見問題

升級歷史

所獲獎項

用戶評價

許可協議

CodeToHtml

C/C++原始碼美化效果演示

現在購買
下載試用

原始碼美化工具功能

SourceFormatX 使用強大的C/C++詞法解析引擎全面地分析您的原始碼並根據用戶自定義的C語言程式碼風格重構和美化C和C++原始碼檔案,因此它能精細地根據不同的程式碼風格美化多種原始碼,甚至是下面這些極度混亂的原始碼:

C/C++ Java C# Delphi (Pascal)
PHP JSP ASP JavaScript
Visual Basic VB.NET VBScript HTML Components
80x86 ASM 8051 ASM CORBA IDL


  C/C++原始碼美化範例:     範例1   |   範例2   |   範例3   |   範例4   |   範例5

這是一個非常極端的範例,其目的是為了展示一下 SourceFormatX 程式碼美化工具 詞法解析引擎的強大威力。這份C語言原始碼是 IOCCC Flight Simulator 案件中一部分,這是一個運行于 Unix/Linux X Window 上的模擬飛行游戲系統。如果你想編譯此C原始碼,你需要 X11 庫。

  /* 原始碼美化之前的C/C++程式碼 */

  #include                                     <math.h>
  #include                                   <sys/time.h>
  #include                                   <X11/Xlib.h>
  #include                                  <X11/keysym.h>
                                            double L ,o ,P
                                           ,_=dt,T,Z,D=1,d,
                                           s[999],E,h= 8,I,
                                           J,K,w[999],M,m,O
                                          ,n[999],j=33e-3,i=
                                          1E3,r,t, u,v ,W,S=
                                          74.5,l=221,X=7.26,
                                          a,B,A=32.2,c, F,H;
                                          int N,q, C, y,p,U;
                                         Window z; char f[52]
                                      ; GC k; main(){ Display*e=
   XOpenDisplay( 0); z=RootWindow(e,0); for (XSetForeground(e,k=XCreateGC (e,z,0,0),BlackPixel(e,0))
  ; scanf("%lf%lf%lf",y +n,w+y, y+s)+1; y ++); XSelectInput(e,z= XCreateSimpleWindow(e,z,0,0,400,400,
  0,0,WhitePixel(e,0) ),KeyPressMask); for(XMapWindow(e,z); ; T=sin(O)){ struct timeval G={ 0,dt*1e6}
  ; K= cos(j); N=1e4; M+= H*_; Z=D*K; F+=_*P; r=E*K; W=cos( O); m=K*W; H=K*T; O+=D*_*F/ K+d/K*E*_; B=
  sin(j); a=B*T*D-E*W; XClearWindow(e,z); t=T*E+ D*B*W; j+=d*_*D-_*F*E; P=W*E*B-T*D; for (o+=(I=D*W+E
  *T*B,E*d/K *B+v+B/K*F*D)*_; p<y; ){ T=p[s]+i; E=c-p[w]; D=n[p]-L; K=D*m-B*T-H*E; if(p [n]+w[ p]+p[s
  ]== 0|K <fabs(W=T*r-I*E +D*P) |fabs(D=t *D+Z *T-a *E)> K)N=1e4; else{ q=W/K *4E2+2e2; C= 2E2+4e2/ K
   *D; N-1E4&& XDrawLine(e ,z,k,N ,U,q,C); N=q; U=C; } ++p; } L+=_* (X*t +P*M+m*l); T=X*X+ l*l+M *M;
    XDrawString(e,z,k ,20,380,f,17); D=v/l*15; i+=(B *l-M*r -X*Z)*_; for(; XPending(e); u *=CS!=N){
                                     XEvent z; XNextEvent(e ,&z);
                                         ++*((N=XLookupKeysym
                                           (&z.xkey,0))-IT?
                                           N-LT? UP-N?& E:&
                                           J:& u: &h); --*(
                                           DN -N? N-DT ?N==
                                           RT?&u: & W:&h:&J
                                            ); } m=15*F/l;
                                            c+=(I=M/ l,l*H
                                            +I*M+a*X)*_; H
                                            =A*r+v*X-F*l+(
                                            E=.1+X*4.9/l,t
                                            =T*m/32-I*T/24
                                             )/S; K=F*M+(
                                             h* 1e4/l-(T+
                                             E*5*T*E)/3e2
                                             )/S-X*d-B*A;
                                             a=2.63 /l*d;
                                             X+=( d*l-T/S
                                              *(.19*E +a
                                              *.64+J/1e3
                                              )-M* v +A*
                                              Z)*_; l +=
                                              K *_; W=d;
                                              sprintf(f,
                                              "%5d  %3d"
                                              "%7d",p =l
                                             /1.7,(C=9E3+
                                O*57.3)%0550,(int)i); d+=T*(.45-14/l*
                               X-a*130-J* .14)*_/125e2+F*_*v; P=(T*(47
                               *I-m* 52+E*94 *D-t*.38+u*.21*E) /1e2+W*
                               179*v)/2312; select(p=0,0,0,0,&G); v-=(
                                W*F-T*(.63*m-I*.086+m*E*19-D*25-.11*u
                                 )/107e2)*_; D=cos(o); E=sin(o); } }

  /* 原始碼美化之後的C/C++程式碼 */

  #include <math.h>
  #include <sys/time.h>
  #include <X11/Xlib.h>
  #include <X11/keysym.h>
  double L, o, P, _ = dt, T, Z, D = 1, d, s[999], E, h = 8, I,
	 J, K, w[999],
         M, m, O, n[999], j = 3.3e-2, i = 1e3, r, t, u, v, W, S = 7.45e1,
         l = 221, X = 7.26, a, B, A = 3.22e1, c, F, H;
  int N, q, C, y, p, U;
  Window z;
  char f[52];
  GC k;
  main()
  {
    Display * e = XOpenDisplay(0);
    z = RootWindow(e, 0);
    for (XSetForeground(e, k = XCreateGC(e, z, 0, 0), BlackPixel(e, 0));
    scanf("%lf%lf%lf", y + n, w + y, y + s) + 1; y++);
    XSelectInput(e, z = XCreateSimpleWindow(e, z, 0, 0, 400, 400,
                 0, 0, WhitePixel(e, 0)), KeyPressMask);
    for (XMapWindow(e, z);; T = sin(O))
      {
        struct timeval G = { 0, dt * 1e6 };
        K = cos(j);
        N = 1e4;
        M += H * _;
        Z = D * K;
        F += _ * P;
        r = E * K;
        W = cos(O);
        m = K * W;
        H = K * T;
        O += D * _ * F / K + d / K * E * _;
        B = sin(j);
        a = B * T * D - E * W;
        XClearWindow(e, z);
        t = T * E + D * B * W;
        j += d * _ * D - _ * F * E;
        P = W * E * B - T * D;
        for (o += (I = D * W + E * T * B, E * d / K * B + v + B / K * F * D) * _; p < y;)
          {
            T = p[s] + i;
            E = c - p[w];
            D = n[p] - L;
            K = D * m - B * T - H * E;
            if (p[n] + w[p] + p[s] == 0 | K < fabs(W = T * r - I * E + D * P) |
						fabs(D = t * D + Z * T - a * E) > K)
              N = 1e4;
            else
              {
                q = W / K * 4e2 + 2e2;
                C = 2e2 + 4e2 / K * D;
                N - 1e4 && XDrawLine(e, z, k, N, U, q, C);
                N = q;
                U = C;
              }
            ++p;
          }
        L += _ * (X * t + P * M + m * l);
        T = X * X + l * l + M * M;
        XDrawString(e, z, k, 20, 380, f, 17);
        D = v / l * 15;
        i += (B * l - M * r - X * Z) * _;
        for (; XPending(e); u *= CS != N)
          {
            XEvent z;
            XNextEvent(e, & z);
            ++ * ((N = XLookupKeysym(& z.xkey, 0)) - IT ? N - LT ? UP - N ? & E : & J : & u : & h);
            -- * (DN - N ? N - DT ? N == RT ? & u : & W : & h : & J);
          }
        m = 15 * F / l;
        c += (I = M / l, l * H + I * M + a * X) * _;
        H = A * r + v * X - F * l + (E = 1e-1 + X * 4.9 / l, t = T * m / 32 - I * T / 24) / S;
        K = F * M + (h * 1e4 / l - (T + E * 5 * T * E) / 3e2) / S - X * d - B * A;
        a = 2.63 / l * d;
        X += (d * l - T / S * (1.9e-1 * E + a * 6.4e-1 + J / 1e3) - M * v + A * Z) * _;
        l += K * _;
        W = d;
        sprintf(f, "%5d  %3d"
                   "%7d", p = l / 1.7, (C = 9e3 + O * 5.73e1) % 0550, (int) i);
        d += T * (4.5e-1 - 14 / l * X - a * 130 - J * 1.4e-1) * _ / 1.25e4 + F * _ * v;
        P = (T * (47 * I - m * 52 + E * 94 * D - t * 3.8e-1 + u * 2.1e-1 * E) / 1e2 + W * 179 *
				v) / 2312;
        select(p = 0, 0, 0, 0, & G);
        v -= (W * F - T * (6.3e-1 * m - I * 8.6e-2 + m * E * 19 - D * 25 - 1.1e-1 * u) / 1.07e4) * _;
        D = cos(o);
        E = sin(o);
      }
  }

範例1   |   範例2   |   範例3   |   範例4   |   範例5