Asterisk-13-Application_Macro_29394560.html 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Asterisk Project : Asterisk 13 Application_Macro</title>
  5. <link rel="stylesheet" href="styles/site.css" type="text/css" />
  6. <META http-equiv="Content-Type" content="text/html; charset=UTF-8">
  7. </head>
  8. <body class="theme-default aui-theme-default">
  9. <div id="page">
  10. <div id="main" class="aui-page-panel">
  11. <div id="main-header">
  12. <div id="breadcrumb-section">
  13. <ol id="breadcrumbs">
  14. <li class="first">
  15. <span><a href="index.html">Asterisk Project</a></span>
  16. </li>
  17. <li>
  18. <span><a href="Asterisk-13-Command-Reference_29394274.html">Asterisk 13 Command Reference</a></span>
  19. </li>
  20. <li>
  21. <span><a href="Asterisk-13-Dialplan-Applications_29394285.html">Asterisk 13 Dialplan Applications</a></span>
  22. </li>
  23. </ol>
  24. </div>
  25. <h1 id="title-heading" class="pagetitle">
  26. <span id="title-text">
  27. Asterisk Project : Asterisk 13 Application_Macro
  28. </span>
  29. </h1>
  30. </div>
  31. <div id="content" class="view">
  32. <div class="page-metadata">
  33. Created by <span class='author'> wikibot</span> on Aug 08, 2014
  34. </div>
  35. <div id="main-content" class="wiki-content group">
  36. <h1 id="Asterisk13Application_Macro-Macro()">Macro()</h1>
  37. <h3 id="Asterisk13Application_Macro-Synopsis">Synopsis</h3>
  38. <p>Macro Implementation.</p>
  39. <h3 id="Asterisk13Application_Macro-Description">Description</h3>
  40. <p>Executes a macro using the context macro- <em>name</em>, jumping to the <code>s</code> extension of that context and executing each step, then returning when the steps end.</p>
  41. <p>The calling extension, context, and priority are stored in <code>MACRO_EXTEN</code>, <code>MACRO_CONTEXT</code> and <code>MACRO_PRIORITY</code> respectively. Arguments become <code>ARG1</code>, <code>ARG2</code>, etc in the macro context.</p>
  42. <p>If you Goto out of the Macro context, the Macro will terminate and control will be returned at the location of the Goto.</p>
  43. <p>If <code>MACRO_OFFSET</code> is set at termination, Macro will attempt to continue at priority MACRO_OFFSET + N + 1 if such a step exists, and N + 1 otherwise.</p>
  44. <div class="aui-message problem shadowed information-macro">
  45. <p class="title">Warning</p>
  46. <span class="aui-icon icon-problem">Icon</span>
  47. <div class="message-content">
  48. <p>Because of the way Macro is implemented (it executes the priorities contained within it via sub-engine), and a fixed per-thread memory stack allowance, macros are limited to 7 levels of nesting (macro calling macro calling macro, etc.); It may be possible that stack-intensive applications in deeply nested macros could cause asterisk to crash earlier than this limit. It is advised that if you need to deeply nest macro calls, that you use the Gosub application (now allows arguments like a Macro) with explict Return() calls instead.</p>
  49. </div>
  50. </div>
  51. <div class="aui-message problem shadowed information-macro">
  52. <p class="title">Warning</p>
  53. <span class="aui-icon icon-problem">Icon</span>
  54. <div class="message-content">
  55. <p>Use of the application <code>WaitExten</code> within a macro will not function as expected. Please use the <code>Read</code> application in order to read DTMF from a channel currently executing a macro.</p>
  56. </div>
  57. </div>
  58. <h3 id="Asterisk13Application_Macro-Syntax">Syntax</h3>
  59. <div class="preformatted panel" style="border-width: 1px;"><div class="preformattedContent panelContent">
  60. <pre>Macro(name,arg1,[arg2[,...]])</pre>
  61. </div></div>
  62. <h5 id="Asterisk13Application_Macro-Arguments">Arguments</h5>
  63. <ul>
  64. <li><code>name</code> - The name of the macro</li>
  65. <li><code>args</code>
  66. <ul>
  67. <li><code>arg1</code></li>
  68. <li><code>arg2</code></li>
  69. </ul>
  70. </li>
  71. </ul>
  72. <h3 id="Asterisk13Application_Macro-SeeAlso">See Also</h3>
  73. <ul>
  74. <li><a href="Asterisk-13-Application_MacroExit_29394563.html">Asterisk 13 Application_MacroExit</a></li>
  75. <li><a href="Asterisk-13-Application_Goto_29394703.html">Asterisk 13 Application_Goto</a></li>
  76. <li><a href="Asterisk-13-Application_Gosub_29394564.html">Asterisk 13 Application_Gosub</a></li>
  77. </ul>
  78. <h3 id="Asterisk13Application_Macro-ImportVersion">Import Version</h3>
  79. <p>This documentation was imported from Asterisk Version SVN-branch-13-r420538</p>
  80. </div>
  81. </div> </div>
  82. <div id="footer">
  83. <section class="footer-body">
  84. <p>Document generated by Confluence on Aug 11, 2014 13:45</p>
  85. </section>
  86. </div>
  87. </div> </body>
  88. </html>