Module:SimpleDebug/doc: Difference between revisions
m Update |
Mabega sura (talk | contribs) No edit summary Tags: Mobile edit Mobile web edit Advanced mobile edit |
||
Line 99: | Line 99: | ||
==Examples== |
==Examples== |
||
One point to watch Following the flow |
|||
syntaxhighlight lang Lua |
|||
==== Following the flow ==== |
|||
local SD require Module SimpleDebug |
|||
<syntaxhighlight lang="Lua"> |
|||
return SD.v Here is reached |
|||
local SD = require "Module:SimpleDebug" |
|||
syntaxhighlight |
|||
return SD.v ('Here is reached') |
|||
returns |
|||
</syntaxhighlight> |
|||
Here is reached Number of decimal places and value of a variable |
|||
returns: |
|||
syntaxhighlight lang Lua |
|||
local SD require Module SimpleDebug" |
|||
Here is reached |
|||
SD.dec 2 |
|||
return SD.v 1/3 syntaxhighlight |
|||
return No html |
|||
==== Number of decimal places and value of a variable ==== |
|||
syntaxhighlight lang Lua |
|||
local SD |
local SD require Module Simple Debug |
||
SD no html true |
|||
SD.dec = 2 |
|||
return SD |
return SD v bbold b |
||
syntaxhighlight |
|||
return Plaintext lang Lua local SD require Module Simple Debug |
|||
returns: |
|||
SD.plaintext true |
|||
return SDv bold b |
|||
0.33 |
|||
syntaxhighlight |
|||
return The value of several variables syntaxhighlight lang Lua |
|||
local SD require Module SimpleDebug" |
|||
==== Nohtml ==== |
|||
local a 12 |
|||
<syntaxhighlight lang="Lua"> |
|||
local b Hello |
|||
local SD = require "Module:SimpleDebug" |
|||
return SD v a bsyntaxhighlight |
|||
SD.nohtml = true |
|||
return |
return 12 Hello |
||
Non-assigned variable detection syntaxhighlight lang Lua local SD require Module Simple Debug |
|||
</syntaxhighlight> |
|||
local a true |
|||
returns: |
|||
return SD v a b |
|||
syntaxhighlight |
|||
"⪡b⪢bold⪡/b⪢" |
|||
returns true The value of a tablesyntaxhighlight lang Lua |
|||
local SD require Module Simple Debug |
|||
local a 1 tab a b |
|||
==== Plaintext ==== |
|||
return SD v a |
|||
<syntaxhighlight lang="Lua"> |
|||
syntax highlight returns 1 b tab a |
|||
local SD = require "Module:SimpleDebug" |
|||
syntaxhighlight lang Lua |
|||
SD.plaintext = true |
|||
local SD require Module SimpleDebug |
|||
return SD.v ("<b>bold</b>") |
|||
local a 1 2 3 4 5 6 7 8 9 return SD v syntaxhighlight |
|||
returns |
returns 1 2 3 2 4 5 6 |
||
3 7 8 9 syntaxhighlight lang Lua |
|||
local SD require Module SimpleDebug" |
|||
"bold" |
|||
local a First 1 2 3 4 Second 5 6 7 8 9 |
|||
==== The value of several variables ==== |
|||
<syntaxhighlight lang="Lua"> |
|||
local SD = require "Module:SimpleDebug" |
|||
local a = 12 |
|||
local b = 'Hello' |
|||
return SD.v (a,b) |
|||
</syntaxhighlight> |
|||
returns: |
|||
12 • "Hello" |
|||
==== Non-assigned variable detection ==== |
|||
<syntaxhighlight lang="Lua"> |
|||
local SD = require "Module:SimpleDebug" |
|||
local a = true |
|||
return SD.v (a,b) |
|||
</syntaxhighlight> |
|||
returns: |
|||
true • nil |
|||
====The value of a table==== |
|||
<syntaxhighlight lang="Lua"> |
|||
local SD = require "Module:SimpleDebug" |
|||
local a = {1, tab='a', 'b'} |
|||
return SD.v (a) |
return SD.v (a) |
||
syntaxhighlight |
|||
returns 1 2 3 First 1 |
|||
2 4 6 Second 5 3 7 8 9 |
|||
returns: |
|||
syntaxhighlight lang Lua |
|||
{ 1, "b", [tab]="a", } |
|||
local SD require Module SimpleDebug |
|||
SD.tab allidx true |
|||
local a 1 2 3 4 6 7 8 9 |
|||
<syntaxhighlight lang="Lua"> |
|||
return SD v a |
|||
local SD = require "Module:SimpleDebug" |
|||
Ssyntaxhighligh 1 2 2 3 2 1 4 3 6 3 1 7 2 8 3 9 |
|||
local a = {{1,2,3},{4,5,6},{7,8,9}} |
|||
Usually you implement these functions with error function |
|||
return SD.v (a) |
|||
syntaxhighlight lang |
|||
local SD require Modul Simple Debug |
|||
returns: |
|||
local a 1 2 3 4 5 6 7 8 9 |
|||
error SD v a |
|||
{ |
|||
syntaxhighlight |
|||
[1] = {1, 2, 3, }, |
|||
displays color red Lua errorModule Your Module Line |
|||
[2] = {4, 5, 6, }, |
|||
div style color red;font family monospace monospace b |
|||
[3] = {7, 8, 9, }, |
|||
  1 1 2 3 b |
|||
} |
|||
  2 4 5 6 br |
|||
    3 78 9 br |
|||
nbsp |
|||
<syntaxhighlight lang="Lua"> |
|||
b div All values of a table in multiline |
|||
local SD = require "Module:SimpleDebug" |
|||
<syntaxhighlight lang Lua |
|||
local a = {{First=1,2,3},{4,Second=5,6},{7,8,9}} |
|||
return SD.v (a) |
|||
</syntaxhighlight> |
|||
returns: |
|||
{ |
|||
[1] = {2, 3, [First]=1, }, |
|||
[2] = {4, 6, [Second]=5, }, |
|||
[3] = {7, 8, 9, }, |
|||
} |
|||
<syntaxhighlight lang="Lua"> |
|||
local SD = require "Module:SimpleDebug" |
|||
SD.tab.allidx = true |
|||
local a = {{1,2,3},{4,nil,6},{7,8,9}} |
|||
return SD.v (a) |
|||
</syntaxhighlight> |
|||
returns: |
|||
{ |
|||
[1]={[1]=1, [2]=2, [3]=3, }, |
|||
[2]={[1]=4, [3]=6, }, |
|||
[3]={[1]=7, [2]=8, [3]=9, }, |
|||
} |
|||
Usually, you implement these functions with error function: |
|||
<syntaxhighlight lang="Lua"> |
|||
local SD = require "Module:SimpleDebug" |
|||
local a = {{1,2,3},{4,5,6},{7,8,9}} |
|||
error (SD.v (a)) |
|||
</syntaxhighlight> |
|||
displays: |
|||
{{color|red|'''Lua error:Module:''YourModule'':''Line'':{'''}} |
|||
<div style="color:red; font-family:monospace, monospace"><b> |
|||
[1] = {1, 2, 3, },<br> |
|||
[2] = {4, 5, 6, },<br> |
|||
[3] = {7, 8, 9, },<br> |
|||
} |
|||
</b></div> |
|||
==== All values of a table in multiline ==== |
|||
<syntaxhighlight lang="Lua"> |
|||
local SD = require "Module:SimpleDebug" |
local SD = require "Module:SimpleDebug" |
||
SD.tab.oneline = false |
SD.tab.oneline = false |
||
local |
local First1 2 3 Middle4 Second 5 6 |
||
return |
return SDv a |
||
syntaxhighlight |
|||
retorna |
retorna |
||
pre1 2 2 3 |
|||
First 1 2 Middle 3 1 4 |
|||
<pre> |
|||
26 |
|||
{ |
|||
Second 5 |
|||
[1] = { |
|||
pre |
|||
[1] = 2, |
|||
The value of several variables with their name in a point |
|||
[2] = 3, |
|||
syntaxhighlight lang Lua |
|||
["First"] = 1, |
|||
local SD require ModuleSimpleDebug |
|||
}, |
|||
local a 12 |
|||
[2] = "Middle", |
|||
local b Hello |
|||
[3] = { |
|||
return SDnv a b syntaxhighlight> |
|||
[1] = 4, |
|||
returns |
|||
[2] = 6, |
|||
["Second"] = 5, |
|||
}, |
|||
} |
|||
</pre> |
|||
==== The value of several variables with their name in a point ==== |
|||
<syntaxhighlight lang="Lua"> |
|||
local SD = require "Module:SimpleDebug" |
|||
local a = 12 |
|||
local b = 'Hello' |
|||
return SD.nv ('a',a,'b',b) |
|||
</syntaxhighlight> |
|||
returns: |
|||
a: 12 • b: "Hello" |
|||
a 12 b Hello |
|||
===Several points to watch=== |
===Several points to watch=== |
Revision as of 08:02, 17 August 2020
Contains a functions to help debug the lua modules. It allows to collect and view the values of several variables and/or points in your lua program, from a module (which is usual) or in several modules (which are required from the main module).
It is designed so that its functions are called from within the module that is to be debugged, calls that will have to be part of the code (of the module that you have designed, or that you want to improve or adapt) until you decide to delete them (when you already have determined the bug). Thus, you do not have to call any of its functions from an invoke.
Uses
One or several points to watch | ||
---|---|---|
Function abbreviations: w : where. n : names. v : variables. s : string.
| ||
Variables | ||
Name | Default | |
tab.oneline |
true |
|
tab.allidx |
false |
If it is true then also displays the numerical indexes of a table. |
dec |
-1 |
Spaces for the decimals:
|
enabled |
true |
If it is false all calls to the below functions do nothing. |
nohtml |
false |
In strings, it replaces < for ⪡ and > for ⪢. |
plaintext |
false |
Deletes html format. |
One point to watch | ||
Functions | ||
w (where) |
| |
v (...) |
| |
wv (where, ...) |
| |
nv (...) |
| |
wnv (where, ...) |
| |
Several points to watch | ||
Variables | ||
Name | Default | |
s |
The string variable that holds the returned values from the next functions. | |
maxlines.num |
100 |
The maxim number of lines (on calling the next functions). |
maxlines.doerror |
true |
If it is true and |
counter |
false |
Adds an autoincremental number at the beginning of each call of a function. |
Functions | ||
breakline () |
Adds a break line in | |
wtos (where) |
Equal to | |
vtos (...) |
Equal to | |
wvtos (where, ...) |
Equal to | |
nvtos (...) |
Equal to | |
wnvtos (where, ...) |
Igual a |
Examples
One point to watch Following the flow syntaxhighlight lang Lua local SD require Module SimpleDebug return SD.v Here is reached syntaxhighlight returns Here is reached Number of decimal places and value of a variable syntaxhighlight lang Lua local SD require Module SimpleDebug" SD.dec 2 return SD.v 1/3 syntaxhighlight return No html syntaxhighlight lang Lua local SD require Module Simple Debug SD no html true return SD v bbold b syntaxhighlight return Plaintext lang Lua local SD require Module Simple Debug SD.plaintext true return SDv bold b syntaxhighlight return The value of several variables syntaxhighlight lang Lua local SD require Module SimpleDebug" local a 12 local b Hello return SD v a bsyntaxhighlight return 12 Hello
Non-assigned variable detection syntaxhighlight lang Lua local SD require Module Simple Debug
local a true return SD v a b syntaxhighlight returns true The value of a tablesyntaxhighlight lang Lua local SD require Module Simple Debug local a 1 tab a b return SD v a syntax highlight returns 1 b tab a syntaxhighlight lang Lua local SD require Module SimpleDebug local a 1 2 3 4 5 6 7 8 9 return SD v syntaxhighlight returns 1 2 3 2 4 5 6 3 7 8 9 syntaxhighlight lang Lua local SD require Module SimpleDebug" local a First 1 2 3 4 Second 5 6 7 8 9 return SD.v (a) syntaxhighlight returns 1 2 3 First 1 2 4 6 Second 5 3 7 8 9 syntaxhighlight lang Lua local SD require Module SimpleDebug SD.tab allidx true local a 1 2 3 4 6 7 8 9 return SD v a Ssyntaxhighligh 1 2 2 3 2 1 4 3 6 3 1 7 2 8 3 9 Usually you implement these functions with error function syntaxhighlight lang local SD require Modul Simple Debug local a 1 2 3 4 5 6 7 8 9 error SD v a syntaxhighlight displays color red Lua errorModule Your Module Line div style color red;font family monospace monospace b   1 1 2 3 b   2 4 5 6 br     3 78 9 br nbsp b div All values of a table in multiline
returns
a 12 b Hello
===Several points to watch===
==== Following the flow ====
<syntaxhighlight lang="lua">
local SD = require "Module:SimpleDebug"
local tab = {1,12,7}
function p.CheckValues ()
local function LittleNum()
SD.wtos ('little number')
end
local function BigNum(num)
SD.wtos ('big='..num)
end
for i, num in ipairs(tab) do
if num > 9 then
BigNum(num)
else
LittleNum()
end
end
error (SD.s)
end
returns:
Lua Error:Module:Your module:Line:
little number
big=12
little number.
With counter
local SD = require "Module:SimpleDebug"
function Increm()
local n = 0
for i = 1, 3 do
n = n + 2
SD.vtos (n)
end
end
SD.counter = true
Increm()
return SD.s
returns:
1 • 2
2 • 4
3 • 6
Monitoring of several variables
local SD = require "Module:SimpleDebug"
a = 12
b = 'Hello'
SD.vtos (1,a,b)
a = a + a
b = b..' world!'
SD.vtos ('Finally',a,b)
return SD.s
returns:
1 => 12 • "Hello"
Finally => 24 • "Hello world!"
local SD = require "Module:SimpleDebug"
SD.breakline ()
a = 12
b = 'Hello'
c = false
SD.nvtos (1,'a',a,'b',b,'c',c)
a = a + a
b = b..' world!'
SD.nvtos ('Finally','a',a,'b',b)
error (SD.s)
displays:
Lua error:Module:YourModule:Line:
1 => a: 12 • b: "Hello" • c: false
Finally => a: 24 • b: "Hello world!"
Variables and their presentation with conditions
local SD = require "Module:SimpleDebug"
SD.breakline()
SD.enabled = false
SD.maxlines.num = 3
local a = 'AA'
for i = 1, 10 do
a = a + 'AA'
if i == 3 then
SD.enabled = true
end
SD.nvtos (i, string.len(a), a)
end
displays:
Lua error:Module:YourModule:Line:
3 => 8 • "AAAAAAAA"
4 => 10 • "AAAAAAAAAA"
5 => 12 • "AAAAAAAAAAAA".