-
Notifications
You must be signed in to change notification settings - Fork 618
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Missing Lua bindings #392
Comments
It's just waiting for someone to put the time to get SWIG to generate them :) PRs welcome. It's not really something on my roadmap but I'm happy to give you pointers if you need it! |
Hi, @arfoll my src/lua/mraa.i
-- And simple test result (lua/luajit 5.X+) mraa = require('mraa')
print(mraa.isSubPlatformId(1)) -- false As I can see, you have typemap(in) in other bindings. Do I need to add this in my mraa.i file? |
Cool, look forward to lua bindings 😃. @Hbrinj added those for the I'm happy to merge the lua bindings without some functions working bindings
|
List of binded functions $ luajit pp.lua | grep function
getPinCount: function: 0x40e25440
getPlatformVersion: function: 0x40e253f0
isSubPlatformId: function: 0x40e27420
setLogLevel: function: 0x40e27380
pinModeTest: function: 0x40e252a0
hasSubPlatform: function: 0x40e273d0
init: function: 0x40e25110
getI2cBusCount: function: 0x40e25490
pwmFromDesc: function: 0x40e277b0
i2cFromDesc: function: 0x40e27760
uartFromDesc: function: 0x40e276c0
printError: function: 0x40e25250
gpioFromDesc: function: 0x40e27620
setPriority: function: 0x40e251b0
addSubplatform: function: 0x40e27578
getDefaultI2cBus: function: 0x40e27528
getVersion: function: 0x40e25160
getSubPlatformId: function: 0x40e27478
getPinName: function: 0x40e27330
getI2cBusId: function: 0x40e254e0
getPlatformName: function: 0x40e25398
adcSupportedBits: function: 0x40e25348
adcRawBits: function: 0x40e252f0
aioFromDesc: function: 0x40e27670
getPlatformType: function: 0x40e25200
removeSubplatform: function: 0x40e275d0
getSubPlatformIndex: function: 0x40e274d0
uint8Array_frompointer: function: 0x40e250c8
spiFromDesc: function: 0x40e27710
frompointer: function: 0x40e28330 |
Hi @dedok, to answer your earlier question, the typemap(in) functions in the swig files for certain languages are there to convert a variable type from the swigged languages to the target language. It's entirely possible that you will need some of these typemaps to be able to pass LUA type variables to C++. You may also find that you will need typemap(out) to convert from the target language to the swigged language. To answer your second question, do you have any boards you can test with? if you do then try to add LUA to the board and create a simple program to write to GPIO etc. and read from a GPIO as well, If you don't then try to initialise some IO and see if it breaks etc. when for instance you set it's direction. |
Hi, @Hbrinj
|
@dedok, so, i'm not so sure about the LUA syntax so i'll write this using something high level like python.
To achieve this above code, and have it fully work, you should be able to short 2 pins on your Edison. in this case pin 5 and 6. |
@Hbrinj thx for code. |
@dedok sweet lemme know if you run into any issues with mraa. |
@Hbrinj , hmm, why 2 args? ./pp.lua
luajit: ./pp.lua:32: Error in mraa::Gpio::dir expected 2..2 args, got 1
stack traceback:
[C]: in function 'dir'
./pp.lua:32: in main chunk
[C]: at 0x0804ba20 SWIG_check_num_args("mraa::Gpio::dir",2,2)
if(!SWIG_isptrtype(L,1)) SWIG_fail_arg("mraa::Gpio::dir",1,"mraa::Gpio *");
if(!lua_isnumber(L,2)) SWIG_fail_arg("mraa::Gpio::dir",2,"mraa::Dir");
if (!SWIG_IsOK(SWIG_ConvertPtr(L,1,(void**)&arg1,SWIGTYPE_p_mraa__Gpio,0))){
SWIG_fail_ptr("Gpio_dir",1,SWIGTYPE_p_mraa__Gpio);
} Second is number - ok (eg dir), first is Gpio object - why? I trying to figure out this behaviour by reading swig lua docs. |
I see your test code works m = require('mraa')
--tprint(mraa)
if m.init() ~= 0 then
die('mraa.init != 0')
end
IOout = m.Gpio(5)
IOin = m.Gpio(6)
IOout.dir(IOout, m.DIR_OUT)
IOin.dir(IOin, m.DIR_IN)
print("platform type: ", mraa.getPlatformType())
-- should be 0
print("read input line it was: ", IOin.read(IOin))
print("write res: ", IOout.write(IOout, 1))
-- should be 1
print("read input line it was: ", IOin.read(IOin)) platform type: 2
read input line it was: 0
write res: 0
read input line it was: 1 Also I want to figure out how to reduce numbers of args. See comment below. |
@dedok, Hi dedok, that is odd behaviour, what kind of object does |
@dedok, i was just looking at the lua swig page for c++ classes, can you access the member functions like this in lua syntax:
|
@Hbrinj Thanks. |
@dedok So did what I suggested work? And that's perfect thanks. |
@Hbrinj In lua code I did not test access to methods by ':'. I made test only for read/write to Gpio, by accessing to the object via '.'. |
Typically I think the ':' method of access is preferred as it abstracts away the need to provide the io |
@Hbrinj So, when I'm done with CMake and docs I'll do pull request. |
PR: #527 |
Why are there no bindings for Lua?
The text was updated successfully, but these errors were encountered: