From WikiChip
Difference between revisions of "mirc/commands/timer"
< mirc‎ | commands

(Example)
(Example)
Line 58: Line 58:
  
 
<syntaxhighlight lang="mIRC">
 
<syntaxhighlight lang="mIRC">
.timer 1 10 echo -a This command worked with a delay of 10 seconds
+
//timer 1 10 echo -a This command worked with a delay of 10 seconds
 
</syntaxhighlight>
 
</syntaxhighlight>
  
Line 64: Line 64:
  
 
<syntaxhighlight lang="mIRC">
 
<syntaxhighlight lang="mIRC">
.timer 1 10 test_timer
+
//timer 1 10 test_timer
  
 
alias test_timer {
 
alias test_timer {

Revision as of 05:31, 14 August 2023

The /timer command can be used to create a general purpose timer. A timer is a way to execute code at some specific interval or time and delay. Timers can be named and unnamed. Unnamed timers will get the lowest numeric timer index available. Named timers are specifically useful if you need to recall that timer at a later period - to pause it, resume it, or simply reset it. Starting a timer with a name that already exists will override the old timer. Timers are not blocking command, they only get executed after the alias/event/etc is complete, losing the access to the local scope.

Synopsis

/timers [off]
/timer[n|name] [off]
/timer[n|name] [-cdeomhipPrzN] [time] <repetitions> <interval> <code>

Switches

Creation Manipulators

  • -o - Creates a offline timer
  • -c - Creates a catch-up timer
  • -h - Creates a high-resolution timer (interval is in millisecond just like -m)

Attributes

  • -m - Treats the interval parameter as milliseconds instead of seconds
  • -d - Keeps the order of all -d timers
  • -i - Dynamically associates itself with the active connection

Manipulator

  • -e - Executes the code associated with a timer (note: it decrease the number of repetition of the timer, probably resets the time counter as well)
  • -p - Pauses a timer, but the countdown is not paused, this switch should serve no real purpose because of the countdown weirdness, -P was added to pause correctly the countdown.
  • -P - Makes a real pause of the timer, countdown included.
  • -r - Resumes a timer paused with -p or -P
  • -zN - Resets an online timer; N=2 resets total time, N=1, resets current time, and N=0 is the same as N=1 AND N=2

Parameters

  • [off] - A literal 'off' keyword, used to turn off a timer.
  • [n|name] - The name or index of the timer
  • [time] - Time to activate the timer, for example '15:30' for 3:30PM
  • <repetitions> - The amount of times the timer should repeat itself. A repetition value of '0' will repeat forever.
  • <interval> - The delay between two consecutive timer executions
  • <code> - Code to be executed.

$ctimer & $ltimer

$ctimer can be used to return the name of the timer which triggered the current script while $ltimer returns the name of the last timer which triggered.

Quirks

You can check the msl injection page to learn more about /timer's double evaluation issues.

/timer also has a special evaluation routine which checks for variable assignement (except /var), for example:

 //timer -ho 1 0 set -s %test 5 $(|) unset -s %test

Works correctly: /timer does not evaluate the variable %test both times as it recognize the assignement.

However this behavior is too intrusive, it is not possible to properly check for variable assigment:

 //var -s %a inc,%b somevalue | timer -ho 1 0 echo -s %a %b

here the variable %b's value disappear completely

Example

If you want the command to work 1 time through 10 seconds, then:

//timer 1 10 echo -a This command worked with a delay of 10 seconds

You can pass the name of an alias that should fire in 10 seconds:

//timer 1 10 test_timer
 
alias test_timer {
  echo -a This command worked with a delay of 10 seconds
}


Below is a simple count down timer that uses a call-back alias once per second:

alias example {
  ; start cou
  var %reps = 5
 
  ; call the timer %reps times after 1 second delay each
  .timer %reps 1 count-down
 
  ; print the first count
  count-down
}
alias -l count-down {
  echo -a Count: $timer($ltimer).reps
}

The above code will generate the following output:

Count: 5
Count: 4
Count: 3
Count: 2
Count: 1
Count: 0

A more basic example of a message being delayed for 3 seconds:

on *:text:!foo:#foo:{
  ; delay the message for 3 seconds
  timer 1 3 msg #foo Bar!
}

A repetition of '0' can also be used to mean an repeat forever:

alias cur_time {
  timer 0 1 echo -s $!time(hh:nn:ss)
}

Ending timers by using 'off' parameter, you can also end timers using wildcards.

alias test_timers {
  ; /test_timers
 
  ; creating 3 different names timers
  /timer[test_one] 1 3 echo -a Test one
  /timer[test_two] 1 6 echo -a Test two
  /timer[test_three] 1 10 echo -at Test three
 
  ; End only one of them
  /timer[test_one] off
 
  ; Ending all the timers created with 'test_' prefix
  /timer[test_*] off
}

Compatibility

Added: mIRC 3.3, 3.4

See also

v · d · e mIRC commands list

A /abook, /action, /add, /ajinvite, /alias, /aline, /ame, /amsg, /anick, /aop, /auser, /auto, /autojoin, /avoice, /away

B /background, /ban, /bcopy, /beep, /bindip, /bread, /break, /breplace, /bset, /btrunc, /bunset, /bwrite

C /channel, /clear, /clearall, /clearial, /cline, /clipboard, /close, /closechats, /closedccs, /closefserves, /closemsg, /cnick, /color, /colour, /comclose, /comlist, /commands, /comopen, /comreg, /continue, /copy, /creq, /ctcp, /ctcpreply, /ctcps

D /dcc, /dccserver, /dde, /ddeserver, /debug, /dec, /describe, /dialog, /did, /didtok, /disable, /disconnect, /dlevel, /dline, /dll, Template:mIRC/donotdisturb, /dns, /dqwindow, /drawcopy, /drawdot, /drawfill, /drawline, /drawpic, /drawrect, /drawreplace, /drawrot, /drawsave, /drawscroll, /drawsize /drawtext

E /ebeeps, /echo, /editbox, /else, /elseif, /emailaddr, /enable, /events, /exit

F /fclose, /filter, /findtext, /finger, /firewall, /flash, /flist, /flood, /flush, /flushini, /fnord, /font, /fopen, /fseek, /fsend, /fserve, /fullname, /fupdate, /fwrite

G /ghide, /gload, /gmove, /gopts, /goto, /gplay, /gpoint, /gqreq, /groups, /gshow, /gsize, /gstop, /gtalk, /gunload, /guser

H /hadd, /halt, /haltdef, /hdec, /hdel, /help, /hfree, /hinc, /hload, /hmake, /hotlink, /hop, /hsave

I /ial, /ialclear, /ialmark, /identd, /if, /ignore, /iline, /inc, /iuser

J /join

L /leave, /linesep, /links, /list, /load, /loadbuf, /localinfo, /log, /logview

M /maxdepth, /mdi, /me, /menubar, /mkdir, /mnick, /mode, /msg

N /noop, /notice, /notify

O /onotice, /omsg

P /pareline, /part, /partall, /pdcc, /perform, /play, /playctrl, /pop, /protect, /proxy, /pvoice

Q /qme, /qmsg, /query, /queryrn, /quit, /quote

R /raw, /registration, /reload, /remini, /remote, /remove, /rename, /renwin, /reseterror, /resetidle, /return, /returnex, /rlevel, /rline, /rmdir, /run, /ruser

S /save, /savebuf, /saveini, /say, /scid, /scon, /server, /set, /setlayer, /showmirc, /signal, /sline, /sockaccept, /sockclose, /socklist, /socklisten, /sockmark, /sockopen, /sockpause, /sockread, /sockrename, /sockudp, /sockwrite, /sound, /speak, /splay, /sreq, /strip, /switchbar

T /timer, /timestamp, /tip, /tips, /titlebar, /tnick, /tokenize, /toolbar, /topic /tray, /treebar

U /ulist, /unload, /unset, /unsetall, /updatenl, /url, /username, /uwho

V /var, /vcadd, /vcmd, /vcrem, /vol

W

X /xyzzy