DUzun's Web
Programare, proiecte personale, divertisment

DUzun it's ME
 
\ 15 aprilie 2025, 09:58:43 \  
Conținut

WAIT.PAS

x
 
uses crt,dos;
const calendar:array[1..5]of byte=(1,60,60,24,7);
{      expc:array[1..5]of longint=(1,60,3600,3600*24,3600*24*7);}
      cicl=3600*24*7;
type tm=array[1..5]of word;
var lshow,wt,current,ending:longint;
    w:string;
    k:char;
    ms,interval:word;
    i:byte;
    ToExit,Show,NoTime:boolean;
Procedure DoEnd(n:integer);
begin
writeln;
halt(n);
end;
Procedure GetTm(var wt:longint);
var i:byte;t:tm;
begin
gettime(t[3],t[2],t[1],ms);
getdate(ms,ms,t[4],t[5]);
wt:=0;
for i:=5 downto 1 do wt:=(wt+t[i])*calendar[i];
end;
function WaitTime:longint;
begin
gettm(current);
wt:=ending-current;
if wt<0 then wt:=(cicl+wt)mod cicl;
waittime:=wt;
end;
function Left:string;
var shown:tm;s2,s1:string;i:byte;lung:byte;
begin
lung:=1;
{WaitTime;}
for i:=1 to 4 do begin shown[i]:=wt mod calendar[i+1];wt:=wt div calendar[i+1];if shown[i]<>0 then lung:=i;end;shown[5]:=wt;
s2:='';
for i:=1 to lung do begin
 str(shown[i],s1);
 if i in[1..3]then if length(s1)<2 then s1:='0'+s1;
 if i<>1 then s2:=':'+s2;
 s2:=s1+s2;
end;
left:=s2;
end;
Function StrToLongi(w:string):Longint;
var wt:longint;c,i:byte;
begin
wt:=0;
for i:=1 to length(w) do begin
 c:=ord(w[i])-48;
 if c in[0..9]then wt:=wt*10+c;
end;
StrToLongi:=wt;
end;
Procedure WriteAll(s:string);
begin
gotoxy(1,wherey);write(s);
while wherex<lo(windmax)-1 do write(' ');
gotoxy(1,wherey);
end;
Procedure ShowLeft;
begin
if show then WriteAll(Left);
lshow:=current+interval;
end;
Function EnterTime:string;
var w:string;
begin
 WriteAll(' ');
 write('Enter sec. to wait: ');readln(w);gotoxy(1,wherey-1);
 EnterTime:=w;
 WriteAll(' ');
end;
{*************************************************************}
Begin
w:=paramstr(1);
if w='' then w:=EnterTime;
{Defaults}
 NoTime:=false;
 Show:=true;
 ToExit:=false;
 interval:=60;
if (paramstr(2))='/S' then show:=false;
gettm(ending);
ending:=ending+StrToLongi(w);
repeat
 if show and(lshow<=current) then begin ShowLeft;end;
 if keypressed then begin
  if ToExit then DoEnd(ord(readkey));
  k:=readkey;
  case upcase(k) of
   'S':DoEnd(2);
   'L':ShowLeft;
   'E':ending:=current+StrToLongi(EnterTime);
   #27:ToExit:=not ToExit;
  end;
 end;
until waittime=0;
End.

Aici acumulez programe şi algoritmi interesanti alcătuiţi de mine (cu mici excepţii) pe parcursul studierii unor limbaje de programare.

Cea mai mare parte din ele sunt realizate în Pascal. 

Nu am scopul creării unui curs specializat sau a descrierii detaliate a anumitor limbaje, ci doar prezint informaţii utile, plus ceva exemple interesante...

 

Răsfoitorul de fișiere (File Browser):

Codul sursă al programelor este organizat în mape şi fişiere.

Paginile care conțin cod sursă de programe de regulă au un răsfoitor de fișiere în partea stangă a paginii reprezentat de un bloc cu titlul „File Browser”.

Pentru a vizualiza un program sau conţinutul unei mape, faceţi click pe numele fişierului / mapei. Dacă fişierul nu este textual, el se va descărca automat, iar dacă este textual, conținutul lui se va afișa într-un bloc pe centrul paginii.

Pentru a descărca un fişier, faceţi click pe dimensiunea (size) lui.

arr_d Limba / Language


 


arr_r Login
 
 
Loading...