How to make a cycling counter from commandline?

D

darenbell

Hi, I'm looking for a way to implement this idea:


-------------------------------------
count=1
total=15

until count>total
print "Record #{count} of #{total} processed."
count+=1
end
-------------------------------------


I want this to print out in a Linux shell. However, I'd prefer it if
there was a way to have this counter increment without printing a new
line. As in, from the user's perspective the 'count' would just
increment until it matched the total... all taking place on the same
line.

I know I've seen this done, but can Ruby do this?
 
J

Jan Svitok

Hi, I'm looking for a way to implement this idea:


-------------------------------------
count=1
total=15

until count>total
print "Record #{count} of #{total} processed."
count+=1
end
-------------------------------------


I want this to print out in a Linux shell. However, I'd prefer it if
there was a way to have this counter increment without printing a new
line. As in, from the user's perspective the 'count' would just
increment until it matched the total... all taking place on the same
line.

I know I've seen this done, but can Ruby do this?

Search the archives for count or counter. It was discussed last week or so.
 
T

Tim Pease

Hi, I'm looking for a way to implement this idea:


-------------------------------------
count=1
total=15

until count>total
print "Record #{count} of #{total} processed."
count+=1
end

$ cat tmp.rb

STDOUT.sync = true

total = ARGV[0] || 15
count = 1

until count>total
print "\rRecord #{count} of #{total} processed"
count += 1
sleep 0.25
end

print "\n"


That should do you what you want. The secret is the carriage return
"\r" at the beginning of the print string. That will bring the cursor
back to the beginning of the line and then overwrite anything
currently on that line.

Blessings,
TwP
 
T

Tim Pease

Hi, I'm looking for a way to implement this idea:


-------------------------------------
count=1
total=15

until count>total
print "Record #{count} of #{total} processed."
count+=1
end

$ cat tmp.rb

STDOUT.sync = true

total = ARGV[0] || 15

total = ARGV[0] || 15
total = Integer(total) # need to turn any passed in arguments into an integer
 
A

ara.t.howard

$ cat tmp.rb

STDOUT.sync = true

total = ARGV[0] || 15
count = 1

until count>total
print "\rRecord #{count} of #{total} processed"
count += 1
sleep 0.25
end

print "\n"


That should do you what you want. The secret is the carriage return
"\r" at the beginning of the print string. That will bring the cursor
back to the beginning of the line and then overwrite anything
currently on that line.

Blessings,
TwP

man, you learn something every day! that's pretty sweet.

-a
 
C

Carlos

Tim said:
Hi, I'm looking for a way to implement this idea:


-------------------------------------
count=1
total=15

until count>total
print "Record #{count} of #{total} processed."
count+=1
end

$ cat tmp.rb

STDOUT.sync = true

total = ARGV[0] || 15
count = 1

until count>total
print "\rRecord #{count} of #{total} processed"
count += 1
sleep 0.25
end

print "\n"


That should do you what you want. The secret is the carriage return
"\r" at the beginning of the print string. That will bring the cursor
back to the beginning of the line and then overwrite anything
currently on that line.

From my BBS years I remember adding... mmm... ¿"\033[K"? at the end of
the string when I did this kind of overwriting. That ANSI code (if I
remembered it correctly) clears everything until the end of line
--useful in case the new string is shorter than the overwritten one.
(This doesn't happen in this case, but maybe the OP wants to print
"#{total} record processed" afterwards.)

Greetings.
--
 
T

Tim Pease

From my BBS years I remember adding... mmm... =BF"\033[K"? at the end of
the string when I did this kind of overwriting. That ANSI code (if I
remembered it correctly) clears everything until the end of line
--useful in case the new string is shorter than the overwritten one.
(This doesn't happen in this case, but maybe the OP wants to print
"#{total} record processed" afterwards.)

Yeah, that was the fatal flaw in my little post there. That is one
very cool ANSI code though. I've used the color codes, but did not
know about that one :)

I just tried it out, and that is the correct code :)

clear =3D "\e[K"
print "a very long line of text that is longer than the next line"
sleep 1
print "\rshort line of text#{clear}"
sleep 1
print "\n"

By the way "\e" =3D=3D "\033"

Blessings,
TwP
 
D

David Vallner

--------------enig304471240A49EC52E0E9E22B
Content-Type: text/plain; charset=ISO-8859-1
Content-Transfer-Encoding: quoted-printable

Tim said:
That should do you what you want. The secret is the carriage return
"\r" at the beginning of the print string. That will bring the cursor
back to the beginning of the line and then overwrite anything
currently on that line.
=20

Smells unportable between Linux, Windows, and Mac Classic. Then again, I
don't know what approach Ruby takes to newline-handling on non-Unix
platforms.

Ah, the good old days of high-school Turbo Pascal, when gotoxy() Just
Worked (tm). Nary a control character or escape sequence in sight.

David Vallner


--------------enig304471240A49EC52E0E9E22B
Content-Type: application/pgp-signature; name="signature.asc"
Content-Description: OpenPGP digital signature
Content-Disposition: attachment; filename="signature.asc"

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.5 (MingW32)

iD8DBQFFUROYy6MhrS8astoRAqewAJ4+D5Ina7rAgTHzwgvwSnT5kAb6hACeJs+3
5AqydLhrYAqgD+r7y0Mazjw=
=JjN7
-----END PGP SIGNATURE-----

--------------enig304471240A49EC52E0E9E22B--
 
G

Gabriele Marrone

Il giorno 08/nov/06, alle ore 00:15, David Vallner ha scritto:
Smells unportable between Linux, Windows, and Mac Classic. Then
again, I
don't know what approach Ruby takes to newline-handling on non-Unix
platforms.

A portable way (but maybe overkill for this) is by using the ncurses
library.
I never tried ncurses-ruby, though.
Ah, the good old days of high-school Turbo Pascal, when gotoxy() Just
Worked (tm). Nary a control character or escape sequence in sight.

ncurses also has gotoxy :)
 
T

Tim Pease

Smells unportable between Linux, Windows, and Mac Classic. Then again, I
don't know what approach Ruby takes to newline-handling on non-Unix
platforms.

"\r" is completely portable. win32 platforms use a "\r\n" for the end
of a line, and *NIX uses just a single "\n" -- hence the dos2unix
utility.

Now, the ANSI control character to clear to the end of a line
(mentioned earlier in this thread) is definitely not portable to the
win32 cmd shell.

TwP
 
P

Peña, Botp

David Vallner [mailto:[email protected]]=20
# Tim Pease wrote:
# > That should do you what you want. The secret is the carriage return
# > "\r" at the beginning of the print string. That will bring=20
# the cursor
# > back to the beginning of the line and then overwrite anything
# > currently on that line.
#=20
# Smells unportable between Linux, Windows, and Mac Classic.=20
# Then again, I
# don't know what approach Ruby takes to newline-handling on non-Unix
# platforms.

fyi, code posted by TwP runs on linux and windows.

kind regards -botp
 
P

Peña, Botp

Tim Pease [mailto:[email protected]]=20
# I just tried it out, and that is the correct code :)
# clear =3D "\e[K"
# print "a very long line of text that is longer than the next line"
# sleep 1
# print "\rshort line of text#{clear}"
# sleep 1
# print "\n"

i just do something like

MAX=3Dfoo_integer||80
CR=3D"\r"
s=3Dfoo_string[0..MAX].ljust(MAX) #or rjust or center

print CR+s

kind regards -botp
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
473,755
Messages
2,569,536
Members
45,009
Latest member
GidgetGamb

Latest Threads

Top