Quantcast
Channel: Rainmeter Forums
Viewing all articles
Browse latest Browse all 482

Formulas within nested inline Lua causing unexpected behavior

$
0
0
This is a separate issue from the since confirmed bug in the other thread (though it uses some similar functions). What is occurring is one inline Lua function is obtaining an inline function from a custom option stored in a meter but is getting mangled when it contains certain formulas due to some unexpected parsing.

It appears to be related to parentheses and possibly quotes but I've tried with multiple different quoting methods and can't seem to avoid the behavior.

The `Chk()` function (correctly) parses and returns the `Cust` option stored in its own meter (uncomment the `print()` line from the script to view the returned string). This option itself contains an inline function. For the `ExampleText` meter this just returns a concatenation of the two input arguments which are then displayed as a string.

However despite displaying the strings as expected in the string meter if one uncomments the `print()` line in the `Disp()` function and looks at the Rainmeter log it's showing that on subsequent skin updates the second argument gets mangled and becomes a nil value.

This is made more obvious in the second `Example` meter. The first commented out `Cust` option function of that meter works as expected, both strings are equivalent so it returns the third arg (there are also no formulas in this version). However the uncommented `Cust` function fails due to unexpected parsing (see log), so no shape height is produced due to the errors.

Test case with various examples to play around with (see Rainmeter log and comments):

INI:

Code:

[Variables]S=20H=50W=200[Rainmeter]AccurateText=1DynamicWindowSize=1Update=3000[Sc]Measure=ScriptScriptFile=Script.lua[ExampleText]Meter=StringW=#W#H=#H#Cust=[&Sc:Disp('([#CURRENTSECTION#:W] / 2)','([#CURRENTSECTION#:W] * 2)')]Text=[&Sc:Chk('#CURRENTSECTION#','Cust')] [ExampleText:W]FontColor=230,230,230SolidColor=0,0,0DynamicVariables=1[Example]Meter=ShapeX=0rY=0RShape=Rectangle 0,0,#W#,[&Sc:Chk('#CURRENTSECTION#','Cust')],0 | Fill Color 244,119,111 | StrokeWidth 0; Working as expected:; Cust=[&Sc:Repl('true','true','10','100')]; Here the equivalence comparison of first two args should produce a return value of '10' but it parses incorrectly altogether (see log):Cust=[&Sc:Repl('([#CURRENTSECTION#:W] / 2)','([#CURRENTSECTION#:W] / 2)','10','100')]; Another example of unexpected behavior:; Cust=[&Sc:Repl('([#CURRENTSECTION#:W] / 2)','(#W# / 2)','(Round([#CURRENTSECTION#:H] / 2))','[#CURRENTSECTION#:H]')]DynamicVariables=1
Script:

Code:

function Initialize()endfunction Disp(in1,in2)    -- print("Disp(): ",in1,in2)    return in1.." "..in2endfunction Repl(in1,in2,ret,el)    print("Repl(): ",in1,in2,ret,el)    if in1 == in2 then        return ret    else        if el then            return el        else            return ""        end    endendfunction Chk(name,op)    local m = SKIN:GetMeter(name)    local o = m:GetOption(op,'',false)    if o then        -- Notice the return value is as expected:        -- print(o)        return o    else        return 0    endend

Statistics: Posted by Crest — Today, 8:02 am — Replies 4 — Views 65



Viewing all articles
Browse latest Browse all 482

Trending Articles