Sophie

Sophie

distrib > Mandriva > 2009.1 > x86_64 > media > main-testing > by-pkgid > 2292bb029a6b72bf3992f7f601b8fa3b > files > 2004

fpc-2.2.4-1.1mdv2009.1.x86_64.rpm

{
}
//{$mode objfpc}
{$INLINE OFF}
{$ifdef FPC_PROFILE}
{$INLINE OFF}
{$endif FPC_PROFILE}
program firework;
uses
  ncurses;

CONST
  my_bg = COLOR_BLACK;

Procedure showit;
begin
  refresh;
  napms(120);
end;

Function get_colour(Var bold : chtype) : longint;
Var
  attr : longint;
begin
  attr:=random(16) + 1;
  bold:=A_NORMAL;
  if (attr > 8) then
   begin
     bold:=A_BOLD;
     attr:=attr and 7;
   end;
  get_colour:=attr;
end;


Procedure explode(Row,Col : longint);
var
  Bold : chtype;
begin
  ncurses.erase;
  mvaddstr(row,col,'-');
  showit;

  init_pair(1,get_colour(bold),my_bg);
  attrset(COLOR_PAIR(1) or bold);
  mvaddstr(row-1,col-1,' - ');
  mvaddstr(row,col-1,'-+-');
  mvaddstr(row+1,col-1,' - ');
  showit;

  init_pair(1,get_colour(bold),my_bg);
  attrset(COLOR_PAIR(1) or bold);
  mvaddstr(row-2,col-2,' --- ');
  mvaddstr(row-1,col-2,'-+++-');
  mvaddstr(row,  col-2,'-+#+-');
  mvaddstr(row+1,col-2,'-+++-');
  mvaddstr(row+2,col-2,' --- ');
  showit;


  init_pair(1,get_colour(bold),my_bg);
  attrset(COLOR_PAIR(1) or bold);
  mvaddstr(row-2,col-2,' +++ ');
  mvaddstr(row-1,col-2,'++#++');
  mvaddstr(row,  col-2,'+# #+');
  mvaddstr(row+1,col-2,'++#++');
  mvaddstr(row+2,col-2,' +++ ');
  showit;

  init_pair(1,get_colour(bold),my_bg);
  attrset(COLOR_PAIR(1) or bold);
  mvaddstr(row-2,col-2,'  #  ');
  mvaddstr(row-1,col-2,'## ##');
  mvaddstr(row,  col-2,'#   #');
  mvaddstr(row+1,col-2,'## ##');
  mvaddstr(row+2,col-2,'  #  ');
  showit;

  init_pair(1,get_colour(bold),my_bg);
  attrset(COLOR_PAIR(1) or bold);
  mvaddstr(row-2,col-2,' # # ');
  mvaddstr(row-1,col-2,'#   #');
  mvaddstr(row,  col-2,'     ');
  mvaddstr(row+1,col-2,'#   #');
  mvaddstr(row+2,col-2,' # # ');
  showit;
end;

Var
  startp,endp,row,diff,flag : longint;
  direction : boolean;
begin
  flag:=0;
  initscr;
  //if (has_colors<>0) then
  if has_colors then
   start_color;
  curs_set(0);
  randomize;
  cbreak;
  nodelay(stdscr, true);
  While getch=ERR do
   begin
     repeat
       startp:=random (COLS -3);
       endp:=random (COLS - 3);
       If startp < 2 then
        startp:=2;
       If endp <2  then
        endp:=2;
       direction:=startp > endp ;
       diff:=abs(startp-endp);
     until (diff>2) and (diff<(LINES-2));
     attrset(A_NORMAL);
     for row:=0 to diff do
      begin;
        If direction then
         mvaddstr(LINES - row,startp + row ,'/')
        else
         mvaddstr(LINES - row,startp - row ,'\');
        inc(flag);
        if flag<>0 then
         begin
           showit;
           erase;
           flag:=0;
         end;
      end;
     inc(flag);
     if (flag<>0) then
      begin
        showit;
        flag:=0;
      end;
     randomize;
     If Direction then
      explode(LINES-row,startp+diff)
     Else
      explode(LINES-row,startp-diff);
     erase;
     showit;
   end;
   endwin();
   halt(0);
end.