2002-09-08 22:31:01 +00:00
|
|
|
/*
|
|
|
|
* Hamlib bindings - Rig interface
|
2008-05-04 21:42:04 +00:00
|
|
|
* Copyright (c) 2001-2008 by Stephane Fillod
|
2002-09-08 22:31:01 +00:00
|
|
|
*
|
|
|
|
*
|
2011-08-20 23:22:51 +00:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
2002-09-08 22:31:01 +00:00
|
|
|
*
|
2011-08-20 23:22:51 +00:00
|
|
|
* This library is distributed in the hope that it will be useful,
|
2002-09-08 22:31:01 +00:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2011-08-20 23:22:51 +00:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
2002-09-08 22:31:01 +00:00
|
|
|
*
|
2011-08-20 23:22:51 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2002-09-08 22:31:01 +00:00
|
|
|
* License along with this library; if not, write to the Free Software
|
2011-08-20 23:22:51 +00:00
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
2002-09-08 22:31:01 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
%inline %{
|
|
|
|
|
|
|
|
typedef struct Rig {
|
|
|
|
RIG *rig;
|
|
|
|
struct rig_caps *caps; /* shortcut to RIG->caps */
|
|
|
|
struct rig_state *state; /* shortcut to RIG->state */
|
2002-09-16 06:50:13 +00:00
|
|
|
int error_status;
|
|
|
|
int do_exception;
|
2002-09-08 22:31:01 +00:00
|
|
|
} Rig;
|
|
|
|
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
typedef char * char_string;
|
|
|
|
typedef channel_t * channel_t_p;
|
|
|
|
typedef channel_t * const_channel_t_p;
|
|
|
|
|
2002-09-08 22:31:01 +00:00
|
|
|
%}
|
|
|
|
|
2002-10-08 21:54:58 +00:00
|
|
|
%extend channel {
|
|
|
|
channel(vfo_t vfo = RIG_VFO_CURR, int ch = 0) {
|
|
|
|
channel_t *chan;
|
|
|
|
|
|
|
|
chan = (channel_t*)malloc(sizeof(channel_t));
|
|
|
|
if (!chan)
|
|
|
|
return NULL;
|
|
|
|
memset(chan, 0, sizeof(channel_t));
|
|
|
|
chan->vfo = vfo;
|
|
|
|
chan->channel_num = ch;
|
|
|
|
return chan;
|
|
|
|
}
|
|
|
|
~channel (void) {
|
2008-05-04 21:42:04 +00:00
|
|
|
/* TODO: free ext_levels */
|
2002-10-08 21:54:58 +00:00
|
|
|
free(self);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-05-04 21:42:04 +00:00
|
|
|
%include "carrays.i"
|
|
|
|
%array_class(struct channel, channelArray);
|
|
|
|
%array_class(tone_t, toneArray);
|
2002-10-08 21:54:58 +00:00
|
|
|
|
2002-09-08 22:31:01 +00:00
|
|
|
/*
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
* declare wrapper method with one argument besides RIG* and optional no target vfo
|
2002-09-08 22:31:01 +00:00
|
|
|
*/
|
2002-10-07 21:44:51 +00:00
|
|
|
#define METHOD1(f, t1) void f (t1 _##t1 _VFO_DECL) \
|
|
|
|
{ self->error_status = rig_##f(self->rig _VFO_ARG, _##t1); }
|
|
|
|
#define METHOD2(f, t1, t2) void f (t1 _##t1##_1, t2 _##t2##_2 _VFO_DECL) \
|
|
|
|
{ self->error_status = rig_##f(self->rig _VFO_ARG, _##t1##_1, _##t2##_2); }
|
2004-01-15 22:40:44 +00:00
|
|
|
#define METHOD2_INIT(f, t1, t2, i2) void f (t1 _##t1##_1, t2 _##t2##_2 = i2 _VFO_DECL) \
|
|
|
|
{ self->error_status = rig_##f(self->rig _VFO_ARG, _##t1##_1, _##t2##_2); }
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
#define METHOD3(f, t1) void f ( vfo_t vfo, t1 _##t1) \
|
|
|
|
{ self->error_status = rig_##f(self->rig _VFO_ARG, _##t1); }
|
2020-03-04 16:05:23 +00:00
|
|
|
#define METHOD3_INIT(f, t1, t2, t3, i3) void f (t1 _##t1##_1, t2 _##t2##_2, t3 _##t3##_3 = i3 _VFO_DECL) \
|
|
|
|
{ self->error_status = rig_##f(self->rig _VFO_ARG, _##t1##_1, _##t2##_2, _##t3##_3); }
|
2021-03-09 05:26:44 +00:00
|
|
|
#define METHOD4(f, t1) void f ( vfo_t vfo, t1 _##t1) \
|
|
|
|
{ self->error_status = rig_##f(self->rig _VFO_ARG, _##t1); }
|
|
|
|
#define METHOD4_INIT(f, t1, t2, t3, t4, i4) void f (t1 _##t1##_1, t2 _##t2##_2, t3 _##t3##_3, ##t4##_4 = i4 _VFO_DECL) \
|
|
|
|
{ self->error_status = rig_##f(self->rig _VFO_ARG, _##t1##_1, _##t2##_2, _##t3##_3 _##t4##_4); }
|
2002-09-16 06:50:13 +00:00
|
|
|
/*
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
* declare wrapper method with one output argument besides RIG* (no target vfo)
|
2002-09-16 06:50:13 +00:00
|
|
|
*/
|
|
|
|
#define METHOD1GET(f, t1) t1 f (void) \
|
|
|
|
{ t1 _##t1; self->error_status = rig_##f(self->rig, &_##t1); return _##t1; }
|
2022-01-18 23:29:21 +00:00
|
|
|
#define METHOD1SET(f, t1) t1 f (void) \
|
|
|
|
{ t1 _##t1; self->error_status = rig_##f(self->rig, _##t1); return _##t1; }
|
2002-09-16 06:50:13 +00:00
|
|
|
|
|
|
|
/*
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
* declare wrapper method with one output argument besides RIG* and vfo
|
2002-09-16 06:50:13 +00:00
|
|
|
*/
|
|
|
|
#define METHOD1VGET(f, t1) t1 f (vfo_t vfo = RIG_VFO_CURR) \
|
|
|
|
{ t1 _##t1; self->error_status = rig_##f(self->rig, vfo, &_##t1); return _##t1; }
|
2002-09-08 22:31:01 +00:00
|
|
|
|
2016-11-03 12:04:40 +00:00
|
|
|
#ifndef SWIGLUA
|
2002-10-07 21:44:51 +00:00
|
|
|
#define METHODSIMPLESET(f, t1, fld, chk) void set_##f (setting_t stg, t1 fld _VFO_DECL) \
|
2020-03-14 17:10:47 +00:00
|
|
|
{ value_t val = {0}; if (chk) { \
|
2002-10-07 21:44:51 +00:00
|
|
|
self->error_status = -RIG_EINVAL; /* invalid type */ \
|
|
|
|
return; \
|
|
|
|
} \
|
|
|
|
val.fld = fld; \
|
|
|
|
self->error_status = rig_set_##f(self->rig _VFO_ARG , stg, val); \
|
|
|
|
}
|
2016-11-03 12:04:40 +00:00
|
|
|
#else
|
|
|
|
#define METHODSIMPLESET(f, t1, fld, chk) void set_##f (setting_t stg, t1 fld _VFO_DECL) \
|
2020-03-14 17:10:47 +00:00
|
|
|
{ value_t val = {0}; \
|
2016-11-03 12:04:40 +00:00
|
|
|
if (chk) { \
|
|
|
|
int ival = (int)fld; \
|
|
|
|
val.i = fld; \
|
|
|
|
} \
|
|
|
|
else { \
|
|
|
|
val.fld = fld; \
|
|
|
|
} \
|
|
|
|
self->error_status = rig_set_##f(self->rig _VFO_ARG , stg, val); \
|
|
|
|
}
|
|
|
|
#endif
|
2002-10-07 21:44:51 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* RIG_CONF_ extparm's type:
|
|
|
|
* NUMERIC: val.f
|
|
|
|
* COMBO: val.i, starting from 0
|
|
|
|
* STRING: val.s
|
|
|
|
* CHECKBUTTON: val.i 0/1
|
|
|
|
*/
|
|
|
|
|
2016-11-03 12:04:40 +00:00
|
|
|
#ifndef SWIGLUA
|
2002-10-07 21:44:51 +00:00
|
|
|
#define METHODSUPERSET(f, t1, fld, chk) void set_##f (const char *name, t1 fld _VFO_DECL) \
|
2020-03-14 17:10:47 +00:00
|
|
|
{ setting_t stg; value_t val = {0}; \
|
2004-05-17 21:09:45 +00:00
|
|
|
stg = rig_parse_##f(name); \
|
2002-10-07 21:44:51 +00:00
|
|
|
if (!rig_has_set_##f(self->rig, stg)) { \
|
|
|
|
const struct confparams *cfp; \
|
|
|
|
cfp = rig_ext_lookup(self->rig, name); \
|
|
|
|
if (!cfp) { \
|
|
|
|
self->error_status = -RIG_EINVAL; /* no such parameter */ \
|
|
|
|
return; \
|
|
|
|
} \
|
|
|
|
switch (cfp->type) { \
|
|
|
|
case RIG_CONF_NUMERIC: \
|
|
|
|
val.fld = fld; \
|
|
|
|
break; \
|
|
|
|
case RIG_CONF_CHECKBUTTON: \
|
|
|
|
case RIG_CONF_COMBO: \
|
|
|
|
val.i = (int)fld; \
|
|
|
|
break; \
|
|
|
|
case RIG_CONF_STRING: \
|
|
|
|
self->error_status = -RIG_EINVAL; /* invalid type */ \
|
|
|
|
return; \
|
|
|
|
default: \
|
|
|
|
self->error_status = -RIG_ECONF; \
|
|
|
|
return; \
|
|
|
|
} \
|
|
|
|
self->error_status = rig_set_ext_##f(self->rig _VFO_ARG, cfp->token, val); \
|
|
|
|
return; \
|
|
|
|
} \
|
2002-11-14 19:27:46 +00:00
|
|
|
if (chk) { \
|
2002-10-07 21:44:51 +00:00
|
|
|
self->error_status = -RIG_EINVAL; /* invalid type */ \
|
|
|
|
return; \
|
|
|
|
} \
|
|
|
|
val.fld = fld; \
|
|
|
|
self->error_status = rig_set_##f(self->rig _VFO_ARG , stg, val); \
|
|
|
|
}
|
2016-11-03 12:04:40 +00:00
|
|
|
#else
|
|
|
|
#define METHODSUPERSET(f, t1, fld, chk) void set_##f (const char *name, t1 fld _VFO_DECL) \
|
2020-03-14 17:10:47 +00:00
|
|
|
{ setting_t stg; value_t val = {0}; \
|
2016-11-03 12:04:40 +00:00
|
|
|
stg = rig_parse_##f(name); \
|
|
|
|
if (!rig_has_set_##f(self->rig, stg)) { \
|
|
|
|
const struct confparams *cfp; \
|
|
|
|
cfp = rig_ext_lookup(self->rig, name); \
|
|
|
|
if (!cfp) { \
|
|
|
|
self->error_status = -RIG_EINVAL; /* no such parameter */ \
|
|
|
|
return; \
|
|
|
|
} \
|
|
|
|
switch (cfp->type) { \
|
|
|
|
case RIG_CONF_NUMERIC: \
|
|
|
|
val.fld = fld; \
|
|
|
|
break; \
|
|
|
|
case RIG_CONF_CHECKBUTTON: \
|
|
|
|
case RIG_CONF_COMBO: \
|
|
|
|
val.i = (int)fld; \
|
|
|
|
break; \
|
|
|
|
case RIG_CONF_STRING: \
|
|
|
|
self->error_status = -RIG_EINVAL; /* invalid type */ \
|
|
|
|
return; \
|
|
|
|
default: \
|
|
|
|
self->error_status = -RIG_ECONF; \
|
|
|
|
return; \
|
|
|
|
} \
|
|
|
|
self->error_status = rig_set_ext_##f(self->rig _VFO_ARG, cfp->token, val); \
|
|
|
|
return; \
|
|
|
|
} \
|
|
|
|
if (chk) { \
|
|
|
|
int ival = (int)fld; \
|
|
|
|
val.i = ival; \
|
|
|
|
} \
|
|
|
|
else { \
|
|
|
|
val.fld = fld; \
|
|
|
|
} \
|
|
|
|
self->error_status = rig_set_##f(self->rig _VFO_ARG , stg, val); \
|
|
|
|
}
|
|
|
|
#endif
|
2002-10-07 21:44:51 +00:00
|
|
|
|
|
|
|
#define METHODSTRSET(f) void set_##f (const char *name, const char *s _VFO_DECL) \
|
2020-03-14 17:10:47 +00:00
|
|
|
{ value_t val = {0}; /* only ext_level/parm's can have string values */ \
|
2002-10-07 21:44:51 +00:00
|
|
|
const struct confparams *cfp; \
|
|
|
|
cfp = rig_ext_lookup(self->rig, name); \
|
|
|
|
if (!cfp) { \
|
|
|
|
self->error_status = -RIG_EINVAL; /* no such parameter */ \
|
|
|
|
return; \
|
|
|
|
} \
|
|
|
|
if (cfp->type != RIG_CONF_STRING) { \
|
|
|
|
self->error_status = -RIG_EINVAL; /* invalid type */ \
|
|
|
|
return; \
|
|
|
|
} \
|
|
|
|
val.cs = s; \
|
|
|
|
self->error_status = rig_set_ext_##f(self->rig _VFO_ARG, cfp->token, val); \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define METHODSIMPLEGET(f, t1, fld, chk) t1 get_##f##_##fld (setting_t stg _VFO_DECL) \
|
2020-03-14 17:10:47 +00:00
|
|
|
{ value_t val = {0}; if (chk) { \
|
2002-10-07 21:44:51 +00:00
|
|
|
self->error_status = -RIG_EINVAL; /* invalid type */ \
|
|
|
|
return val.fld; /* undefined value */ \
|
|
|
|
} \
|
|
|
|
self->error_status = rig_get_##f(self->rig _VFO_ARG , stg, &val); \
|
|
|
|
return val.fld; \
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define METHODSUPERGET(fct, t1, fld, chk) t1 get_##fct##_##fld(const char *name _VFO_DECL) \
|
2020-03-14 17:10:47 +00:00
|
|
|
{ setting_t stg; value_t val = {0}; \
|
2004-05-17 21:09:45 +00:00
|
|
|
stg = rig_parse_##fct(name); \
|
2002-10-07 21:44:51 +00:00
|
|
|
if (!rig_has_get_##fct(self->rig, stg)) { \
|
|
|
|
const struct confparams *cfp; \
|
|
|
|
cfp = rig_ext_lookup(self->rig, name); \
|
|
|
|
if (!cfp) { \
|
|
|
|
self->error_status = -RIG_EINVAL; /* no such parameter */ \
|
|
|
|
return val.fld; /* undefined */ \
|
|
|
|
} \
|
|
|
|
if (cfp->type == RIG_CONF_STRING) { \
|
|
|
|
self->error_status = -RIG_EINVAL; \
|
|
|
|
return val.fld; /* undefined */ \
|
|
|
|
} \
|
|
|
|
self->error_status = rig_get_ext_##fct(self->rig _VFO_ARG, cfp->token, &val); \
|
|
|
|
switch (cfp->type) { \
|
|
|
|
case RIG_CONF_NUMERIC: \
|
|
|
|
return (t1)val.f; \
|
|
|
|
case RIG_CONF_CHECKBUTTON: \
|
|
|
|
case RIG_CONF_COMBO: \
|
|
|
|
return (t1)val.i; \
|
|
|
|
default: \
|
|
|
|
self->error_status = -RIG_ECONF; \
|
|
|
|
return val.fld; /* undefined */ \
|
|
|
|
} \
|
|
|
|
} \
|
2002-11-14 19:27:46 +00:00
|
|
|
if (chk) { \
|
2002-10-07 21:44:51 +00:00
|
|
|
self->error_status = -RIG_EINVAL; /* invalid type */ \
|
|
|
|
return val.fld; /* undefined */ \
|
|
|
|
} \
|
|
|
|
self->error_status = rig_get_##fct(self->rig _VFO_ARG , stg, &val); \
|
|
|
|
return val.fld; \
|
|
|
|
}
|
|
|
|
|
2008-05-04 21:42:04 +00:00
|
|
|
#define METHODSTRGET(f) void get_##f (const char *name, char *returnstr _VFO_DECL) \
|
2020-03-14 17:10:47 +00:00
|
|
|
{ value_t val = {0}; /* only ext_level/parm's can have string values */ \
|
2002-10-07 21:44:51 +00:00
|
|
|
const struct confparams *cfp; \
|
2008-05-04 21:42:04 +00:00
|
|
|
returnstr[0] = '\0'; \
|
2002-10-07 21:44:51 +00:00
|
|
|
cfp = rig_ext_lookup(self->rig, name); \
|
2008-05-04 21:42:04 +00:00
|
|
|
if (!cfp || cfp->type != RIG_CONF_STRING) { \
|
|
|
|
self->error_status = -RIG_EINVAL; /* no such parameter/invalid type */ \
|
|
|
|
return; \
|
2002-10-07 21:44:51 +00:00
|
|
|
} \
|
2008-05-04 21:42:04 +00:00
|
|
|
val.s = returnstr; \
|
2002-10-07 21:44:51 +00:00
|
|
|
self->error_status = rig_get_ext_##f(self->rig _VFO_ARG, cfp->token, &val); \
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-05-04 21:42:04 +00:00
|
|
|
/*
|
|
|
|
* string as return value
|
|
|
|
* NB: The %apply has to be outside the %extend,
|
|
|
|
* but the %cstring_bounded_output must be inside.
|
|
|
|
*/
|
|
|
|
%ignore MAX_RETURNSTR;
|
|
|
|
#define MAX_RETURNSTR 256
|
|
|
|
|
2020-03-14 04:40:32 +00:00
|
|
|
#ifndef SWIGJAVA
|
2008-05-04 21:42:04 +00:00
|
|
|
%apply char *OUTPUT { char *returnstr };
|
2020-03-14 04:40:32 +00:00
|
|
|
#endif
|
2008-05-04 21:42:04 +00:00
|
|
|
|
2002-10-07 21:44:51 +00:00
|
|
|
/*
|
|
|
|
* Rig class alike
|
|
|
|
*/
|
2002-09-08 22:31:01 +00:00
|
|
|
%extend Rig {
|
2008-05-04 21:42:04 +00:00
|
|
|
|
2016-11-03 12:04:40 +00:00
|
|
|
#ifndef SWIGLUA
|
2016-05-20 20:08:10 +00:00
|
|
|
#ifndef SWIG_CSTRING_UNIMPL
|
2020-03-14 04:40:32 +00:00
|
|
|
#ifndef SWIGJAVA
|
2008-05-04 21:42:04 +00:00
|
|
|
%cstring_bounded_output(char *returnstr, MAX_RETURNSTR);
|
2016-11-03 12:04:40 +00:00
|
|
|
#endif
|
2020-03-14 04:40:32 +00:00
|
|
|
#endif
|
2016-05-20 20:08:10 +00:00
|
|
|
#endif
|
2008-05-04 21:42:04 +00:00
|
|
|
|
|
|
|
Rig(int rig_model) {
|
2002-09-08 22:31:01 +00:00
|
|
|
Rig *r;
|
|
|
|
|
|
|
|
r = (Rig*)malloc(sizeof(Rig));
|
|
|
|
if (!r)
|
|
|
|
return NULL;
|
|
|
|
r->rig = rig_init(rig_model);
|
|
|
|
if (!r->rig) {
|
|
|
|
free(r);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
/* install shortcuts */
|
|
|
|
r->caps = r->rig->caps;
|
|
|
|
r->state = &r->rig->state;
|
2002-09-16 06:50:13 +00:00
|
|
|
r->do_exception = 0; /* default is disabled */
|
|
|
|
r->error_status = RIG_OK;
|
2002-09-08 22:31:01 +00:00
|
|
|
return r;
|
|
|
|
}
|
|
|
|
~Rig () {
|
|
|
|
rig_cleanup(self->rig);
|
|
|
|
free(self);
|
|
|
|
}
|
2002-09-16 06:50:13 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* return code checking
|
|
|
|
*/
|
|
|
|
%exception {
|
|
|
|
arg1->error_status = RIG_OK;
|
|
|
|
$action
|
|
|
|
if (arg1->error_status != RIG_OK && arg1->do_exception)
|
|
|
|
SWIG_exception(SWIG_UnknownError, rigerror(arg1->error_status));
|
|
|
|
}
|
|
|
|
|
|
|
|
void open () {
|
|
|
|
self->error_status = rig_open(self->rig);
|
2002-09-08 22:31:01 +00:00
|
|
|
}
|
2002-09-16 06:50:13 +00:00
|
|
|
void close () {
|
|
|
|
self->error_status = rig_close(self->rig);
|
2002-09-08 22:31:01 +00:00
|
|
|
}
|
2002-10-07 21:44:51 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* group all vfo, and non vfo apart
|
|
|
|
*/
|
|
|
|
#define _VFO_ARG ,vfo
|
|
|
|
#define _VFO_DECL ,vfo_t vfo = RIG_VFO_CURR
|
|
|
|
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
METHOD3(set_freq, freq_t)
|
2004-01-15 22:40:44 +00:00
|
|
|
METHOD2_INIT(set_mode, rmode_t, pbwidth_t, RIG_PASSBAND_NORMAL)
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
METHOD3(set_ptt, ptt_t)
|
|
|
|
METHOD3(set_rptr_shift, rptr_shift_t)
|
|
|
|
METHOD3(set_rptr_offs, shortfreq_t)
|
|
|
|
METHOD3(set_ctcss_tone, tone_t)
|
|
|
|
METHOD3(set_dcs_code, tone_t)
|
|
|
|
METHOD3(set_ctcss_sql, tone_t)
|
2002-10-07 21:44:51 +00:00
|
|
|
METHOD1(set_dcs_sql, tone_t)
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
METHOD3(set_split_freq, freq_t)
|
2004-01-15 22:40:44 +00:00
|
|
|
METHOD2_INIT(set_split_mode, rmode_t, pbwidth_t, RIG_PASSBAND_NORMAL)
|
2020-03-04 16:05:23 +00:00
|
|
|
METHOD3_INIT(set_split_freq_mode, freq_t, rmode_t, pbwidth_t, RIG_PASSBAND_NORMAL)
|
2003-04-06 18:48:36 +00:00
|
|
|
METHOD2(set_split_vfo, split_t, vfo_t)
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
METHOD3(set_rit, shortfreq_t)
|
|
|
|
METHOD3(set_xit, shortfreq_t)
|
|
|
|
METHOD3(set_ts, shortfreq_t)
|
2020-01-21 23:53:12 +00:00
|
|
|
METHOD2(set_ant, ant_t, value_t)
|
2002-10-07 21:44:51 +00:00
|
|
|
METHOD2(set_func, setting_t, int)
|
2020-03-04 17:42:39 +00:00
|
|
|
METHOD2(set_ext_func, token_t, int)
|
rig.swg: New properly formatted macro
I made a patch, you can see in that there is the solution, which
describe the error: if a function in hamlib looks 3 argument
(rig, vfo, any 3rd arg), the order of the 2nd and 3rd argument
were reversed, because the macro METHOD1 reversed them.
I've collected these functions, compared its arguments with
hamlib docs (http://hamlib.sourceforge.net/manuals/1.2.15/), and
where 1st arg is rig, 2nd arg is vfo, and 3rd is any kind of
type, changed to METHOD3, which is a new macro, and keeps the
correct order of original function - see the patch. (I didn't
find any info about the expected diff format, so I just created
the `diff -uprN ORIG NEW'.)
To check my theory, I've tested with another function, which uses
vfo type at 2nd argument, eg. rig_set_freq; here is the Python
code:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7013200.0)
and the original code drop the exception:
my_rig.set_freq(Hamlib.RIG_VFO_A, 7012500.0)
File "/usr/local/lib/python2.7/dist-packages/Hamlib.py", line 2513, in
set_freq
def set_freq(self, *args): return _Hamlib.Rig_set_freq(self, *args)
TypeError: in method 'Rig_set_freq', argument 3 of type 'vfo_t'
As you can see, it's same as my original error above.
So, after I patched the source and recompiled it again, these two
function works correctly - I will test it at soon, but I think
_this_ is good and stable.
Signed-off-by: Nate Bargmann <n0nb@n0nb.us>
2013-02-12 20:43:19 +00:00
|
|
|
METHOD3(set_bank, int)
|
|
|
|
METHOD3(set_mem, int)
|
|
|
|
METHOD3(send_dtmf, const_char_string)
|
|
|
|
METHOD3(send_morse, const_char_string)
|
|
|
|
METHOD3(vfo_op, vfo_op_t)
|
2002-10-07 21:44:51 +00:00
|
|
|
METHOD2(scan, scan_t, int)
|
2002-11-14 19:27:46 +00:00
|
|
|
METHODSIMPLESET(level, int, i, RIG_LEVEL_IS_FLOAT(stg))
|
|
|
|
METHODSIMPLESET(level, float, f, !RIG_LEVEL_IS_FLOAT(stg))
|
|
|
|
METHODSUPERSET(level, int, i, RIG_LEVEL_IS_FLOAT(stg))
|
|
|
|
METHODSUPERSET(level, float, f, !RIG_LEVEL_IS_FLOAT(stg))
|
2002-10-07 21:44:51 +00:00
|
|
|
METHODSTRSET(level)
|
|
|
|
METHOD2(set_ext_level, token_t, value_t)
|
|
|
|
|
2002-11-14 19:27:46 +00:00
|
|
|
METHODSIMPLEGET(level, int, i, RIG_LEVEL_IS_FLOAT(stg))
|
|
|
|
METHODSIMPLEGET(level, float, f, !RIG_LEVEL_IS_FLOAT(stg))
|
|
|
|
METHODSUPERGET(level, int, i, RIG_LEVEL_IS_FLOAT(stg))
|
|
|
|
METHODSUPERGET(level, float, f, !RIG_LEVEL_IS_FLOAT(stg))
|
2002-10-07 21:44:51 +00:00
|
|
|
METHODSTRGET(level)
|
|
|
|
|
|
|
|
/*
|
2004-01-15 22:40:44 +00:00
|
|
|
* these ones take no vfo arg
|
2002-10-07 21:44:51 +00:00
|
|
|
*/
|
|
|
|
#undef _VFO_ARG
|
|
|
|
#undef _VFO_DECL
|
|
|
|
#define _VFO_ARG
|
|
|
|
#define _VFO_DECL
|
|
|
|
METHOD1(set_vfo, vfo_t) /* particular case */
|
2002-09-08 22:31:01 +00:00
|
|
|
METHOD1(set_powerstat, powerstat_t)
|
|
|
|
METHOD1(set_trn, int)
|
2020-03-04 17:42:39 +00:00
|
|
|
METHOD1(has_get_level, setting_t)
|
2002-09-08 22:31:01 +00:00
|
|
|
METHOD1(has_set_parm, setting_t)
|
|
|
|
METHOD1(has_set_func, setting_t)
|
|
|
|
METHOD1(reset, reset_t)
|
|
|
|
METHOD1(has_scan, scan_t)
|
|
|
|
METHOD1(has_vfo_op, vfo_op_t)
|
|
|
|
METHOD1(passband_normal, rmode_t)
|
|
|
|
METHOD1(passband_narrow, rmode_t)
|
|
|
|
METHOD1(passband_wide, rmode_t)
|
2022-01-22 22:42:22 +00:00
|
|
|
METHOD1(set_vfo_opt, int)
|
2002-09-08 22:31:01 +00:00
|
|
|
|
|
|
|
METHOD1(ext_token_lookup, const_char_string) /* level & parm */
|
|
|
|
METHOD1(token_lookup, const_char_string) /* conf */
|
|
|
|
|
|
|
|
METHOD2(set_conf, token_t, const_char_string)
|
|
|
|
METHOD2(set_ext_parm, token_t, value_t)
|
2002-10-07 21:44:51 +00:00
|
|
|
|
2002-11-14 19:27:46 +00:00
|
|
|
METHODSIMPLESET(parm, int, i, RIG_PARM_IS_FLOAT(stg))
|
|
|
|
METHODSIMPLESET(parm, float, f, !RIG_PARM_IS_FLOAT(stg))
|
|
|
|
METHODSUPERSET(parm, int, i, RIG_PARM_IS_FLOAT(stg))
|
|
|
|
METHODSUPERSET(parm, float, f, !RIG_PARM_IS_FLOAT(stg))
|
2002-10-07 21:44:51 +00:00
|
|
|
METHODSTRSET(parm)
|
|
|
|
|
2002-11-14 19:27:46 +00:00
|
|
|
METHODSIMPLEGET(parm, int, i, RIG_PARM_IS_FLOAT(stg))
|
|
|
|
METHODSIMPLEGET(parm, float, f, !RIG_PARM_IS_FLOAT(stg))
|
|
|
|
METHODSUPERGET(parm, int, i, RIG_PARM_IS_FLOAT(stg))
|
|
|
|
METHODSUPERGET(parm, float, f, !RIG_PARM_IS_FLOAT(stg))
|
2002-10-07 21:44:51 +00:00
|
|
|
METHODSTRGET(parm)
|
|
|
|
|
2002-09-08 22:31:01 +00:00
|
|
|
|
2002-10-07 21:44:51 +00:00
|
|
|
void set_conf(const char *name, const char *val) {
|
|
|
|
token_t tok = rig_token_lookup(self->rig, name);
|
|
|
|
if (tok == RIG_CONF_END)
|
|
|
|
self->error_status = -RIG_EINVAL;
|
|
|
|
else
|
|
|
|
self->error_status = rig_set_conf(self->rig, tok, val);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-09-16 06:50:13 +00:00
|
|
|
|
2002-09-08 22:31:01 +00:00
|
|
|
/* TODO: get_ext_parm_list, level, conf, .. */
|
|
|
|
|
2002-10-07 21:44:51 +00:00
|
|
|
/* get functions */
|
2002-09-16 06:50:13 +00:00
|
|
|
|
|
|
|
METHOD1VGET(get_freq, freq_t)
|
2018-12-27 21:10:10 +00:00
|
|
|
extern void get_mode(rmode_t * OUTPUT, pbwidth_t * OUTPUT, vfo_t vfo = RIG_VFO_CURR);
|
|
|
|
extern void get_split_mode(rmode_t * OUTPUT, pbwidth_t * OUTPUT, vfo_t vfo = RIG_VFO_CURR);
|
2002-09-16 06:50:13 +00:00
|
|
|
METHOD1GET(get_vfo, vfo_t)
|
|
|
|
METHOD1VGET(get_ptt, ptt_t)
|
|
|
|
METHOD1VGET(get_rptr_shift, rptr_shift_t)
|
|
|
|
METHOD1VGET(get_rptr_offs, shortfreq_t)
|
|
|
|
METHOD1VGET(get_ctcss_tone, tone_t)
|
|
|
|
METHOD1VGET(get_dcs_code, tone_t)
|
|
|
|
METHOD1VGET(get_ctcss_sql, tone_t)
|
|
|
|
METHOD1VGET(get_dcs_sql, tone_t)
|
|
|
|
METHOD1VGET(get_split_freq, freq_t)
|
2003-04-06 18:48:36 +00:00
|
|
|
void get_split_vfo(split_t *split, vfo_t *tx_vfo, vfo_t vfo = RIG_VFO_CURR)
|
|
|
|
{ self->error_status = rig_get_split_vfo(self->rig, vfo, split, tx_vfo); }
|
|
|
|
|
2002-09-16 06:50:13 +00:00
|
|
|
METHOD1VGET(get_rit, shortfreq_t)
|
|
|
|
METHOD1VGET(get_xit, shortfreq_t)
|
|
|
|
METHOD1VGET(get_ts, shortfreq_t)
|
2020-03-04 14:30:11 +00:00
|
|
|
extern void get_ant(ant_t *ant_rx, ant_t *ant_tx, ant_t *ant_curr, value_t * OUTPUT, ant_t ant, vfo_t vfo = RIG_VFO_CURR);
|
2021-04-29 14:00:59 +00:00
|
|
|
extern void get_vfo_info (int *satmode, split_t *split, pbwidth_t *width, rmode_t *mode, freq_t *freq, vfo_t vfo = RIG_VFO_CURR);
|
2002-09-16 06:50:13 +00:00
|
|
|
METHOD1VGET(get_mem, int)
|
|
|
|
METHOD1GET(get_powerstat, powerstat_t)
|
|
|
|
METHOD1GET(get_trn, int)
|
2020-03-04 17:42:39 +00:00
|
|
|
METHOD1VGET(get_dcd, dcd_t)
|
2002-10-07 21:44:51 +00:00
|
|
|
|
2008-05-04 21:42:04 +00:00
|
|
|
int mem_count(void) {
|
|
|
|
return rig_mem_count(self->rig);
|
|
|
|
}
|
|
|
|
|
|
|
|
const chan_t *lookup_mem_caps(int channel_num = RIG_MEM_CAPS_ALL)
|
|
|
|
{
|
|
|
|
return rig_lookup_mem_caps(self->rig, channel_num);
|
|
|
|
}
|
|
|
|
|
2002-10-08 21:54:58 +00:00
|
|
|
void set_channel(const struct channel *chan) {
|
2020-11-30 05:32:14 +00:00
|
|
|
self->error_status = rig_set_channel(self->rig, RIG_VFO_NONE, chan);
|
2002-10-08 21:54:58 +00:00
|
|
|
}
|
|
|
|
|
2020-04-30 14:14:39 +00:00
|
|
|
void get_channel(struct channel *chan, int read_only) {
|
2020-11-30 05:32:14 +00:00
|
|
|
self->error_status = rig_get_channel(self->rig, RIG_VFO_NONE, chan, read_only);
|
2002-10-08 21:54:58 +00:00
|
|
|
/* TODO: handle ext_level's */
|
|
|
|
}
|
|
|
|
|
2008-05-04 21:42:04 +00:00
|
|
|
void chan_clear(struct channel *chans, int nb_chans = 1) {
|
|
|
|
memset(chans, 0, sizeof(struct channel)*nb_chans);
|
|
|
|
}
|
|
|
|
|
|
|
|
void get_chan_all(struct channel *chans) {
|
2020-11-30 05:32:14 +00:00
|
|
|
self->error_status = rig_get_chan_all(self->rig, RIG_VFO_NONE, chans);
|
2008-05-04 21:42:04 +00:00
|
|
|
/* TODO: handle ext_level's */
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Rem: does swig has to be told that returned object need to be handled by gc?
|
|
|
|
*/
|
|
|
|
struct channel *get_chan_all(void);
|
|
|
|
|
2002-10-07 21:44:51 +00:00
|
|
|
/* get_channel() returns current VFO data
|
|
|
|
* get_channel(10) returns content of memory #10
|
|
|
|
* get_channel(0, RIG_VFO_A) returns VFO A data
|
2008-05-04 21:42:04 +00:00
|
|
|
* Rem: does swig has to be told that returned object need to be handled by gc?
|
2002-10-07 21:44:51 +00:00
|
|
|
*/
|
2020-04-30 14:14:39 +00:00
|
|
|
struct channel *get_channel(int read_only, int channel_num = INT_MAX, vfo_t vfo = RIG_VFO_MEM) {
|
2003-04-06 18:48:36 +00:00
|
|
|
struct channel *chan;
|
2008-05-04 21:42:04 +00:00
|
|
|
chan = new_channel(channel_num != INT_MAX ? vfo : RIG_VFO_CURR, channel_num);
|
|
|
|
if (!chan)
|
|
|
|
{
|
|
|
|
self->error_status = -RIG_ENOMEM;
|
|
|
|
return NULL;
|
|
|
|
}
|
2020-11-30 05:32:14 +00:00
|
|
|
self->error_status = rig_get_channel(self->rig, RIG_VFO_NONE, chan, read_only);
|
2002-10-07 21:44:51 +00:00
|
|
|
/* TODO: copy ext_level's */
|
2002-10-08 21:54:58 +00:00
|
|
|
return chan;
|
2002-10-07 21:44:51 +00:00
|
|
|
}
|
|
|
|
|
2008-05-04 21:42:04 +00:00
|
|
|
void get_conf(token_t tok, char *returnstr) {
|
|
|
|
returnstr[0] = '\0';
|
|
|
|
self->error_status = rig_get_conf(self->rig, tok, returnstr);
|
2002-10-07 21:44:51 +00:00
|
|
|
}
|
|
|
|
|
2008-05-04 21:42:04 +00:00
|
|
|
void get_conf(const char *name, char *returnstr) {
|
|
|
|
returnstr[0] = '\0';
|
2002-10-07 21:44:51 +00:00
|
|
|
token_t tok = rig_token_lookup(self->rig, name);
|
|
|
|
if (tok == RIG_CONF_END)
|
|
|
|
self->error_status = -RIG_EINVAL;
|
|
|
|
else
|
2008-05-04 21:42:04 +00:00
|
|
|
self->error_status = rig_get_conf(self->rig, tok, returnstr);
|
2002-10-07 21:44:51 +00:00
|
|
|
}
|
|
|
|
|
2008-05-04 21:42:04 +00:00
|
|
|
void recv_dtmf(char *returnstr, vfo_t vfo = RIG_VFO_CURR) {
|
|
|
|
int len = MAX_RETURNSTR;
|
|
|
|
self->error_status = rig_recv_dtmf(self->rig, vfo, returnstr, &len);
|
|
|
|
returnstr[len] = '\0';
|
2002-10-07 21:44:51 +00:00
|
|
|
}
|
|
|
|
const char * get_info(void) {
|
|
|
|
const char *s;
|
|
|
|
s = rig_get_info(self->rig);
|
|
|
|
self->error_status = s ? RIG_OK : -RIG_EINVAL;
|
|
|
|
return s;
|
|
|
|
}
|
2002-09-16 06:50:13 +00:00
|
|
|
|
2011-08-20 23:22:51 +00:00
|
|
|
int get_func(setting_t func, vfo_t vfo = RIG_VFO_CURR) {
|
2002-09-16 06:50:13 +00:00
|
|
|
int status;
|
|
|
|
self->error_status = rig_get_func(self->rig, vfo, func, &status);
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
2020-03-04 17:42:39 +00:00
|
|
|
int get_ext_func(token_t func, vfo_t vfo = RIG_VFO_CURR) {
|
|
|
|
int status;
|
|
|
|
self->error_status = rig_get_ext_func(self->rig, vfo, func, &status);
|
|
|
|
return status;
|
|
|
|
}
|
2002-10-07 21:44:51 +00:00
|
|
|
|
2020-03-14 17:10:47 +00:00
|
|
|
//#ifndef SWIGJAVA
|
2008-05-04 21:42:04 +00:00
|
|
|
/* TODO */
|
2002-09-16 06:50:13 +00:00
|
|
|
void get_level(setting_t level, vfo_t vfo = RIG_VFO_CURR)
|
2020-03-14 17:10:47 +00:00
|
|
|
{ value_t val = {0}; self->error_status = rig_get_level(self->rig, vfo, level, &val);
|
2002-09-16 06:50:13 +00:00
|
|
|
//if (RIG_LEVEL_IS_FLOAT(level))
|
|
|
|
/* TODO: dynamic casting */
|
|
|
|
}
|
2020-03-04 16:16:27 +00:00
|
|
|
|
2020-03-04 17:42:39 +00:00
|
|
|
void get_ext_level(token_t token, vfo_t vfo = RIG_VFO_CURR)
|
2020-03-14 17:10:47 +00:00
|
|
|
{ value_t val = {0}; self->error_status = rig_get_level(self->rig, vfo, token, &val);
|
2020-03-04 17:42:39 +00:00
|
|
|
//if (RIG_LEVEL_IS_FLOAT(level))
|
|
|
|
/* TODO: dynamic casting */
|
|
|
|
}
|
|
|
|
|
2020-03-04 16:16:27 +00:00
|
|
|
void get_parm(setting_t parm)
|
2020-03-14 17:10:47 +00:00
|
|
|
{ value_t val = {0}; self->error_status = rig_get_parm(self->rig, parm, &val);
|
2020-03-04 16:16:27 +00:00
|
|
|
//if (RIG_LEVEL_IS_FLOAT(parm))
|
|
|
|
/* TODO: dynamic casting */
|
|
|
|
}
|
2020-03-04 17:42:39 +00:00
|
|
|
|
|
|
|
void get_ext_parm(token_t parm)
|
2020-03-14 17:10:47 +00:00
|
|
|
{ value_t val = {0}; self->error_status = rig_get_parm(self->rig, parm, &val);
|
2020-03-04 17:42:39 +00:00
|
|
|
//if (RIG_LEVEL_IS_FLOAT(parm))
|
|
|
|
/* TODO: dynamic casting */
|
|
|
|
}
|
|
|
|
|
2020-03-14 17:10:47 +00:00
|
|
|
//#endif
|
2008-05-04 21:42:04 +00:00
|
|
|
|
2002-09-08 22:31:01 +00:00
|
|
|
};
|
|
|
|
|
2002-09-16 06:50:13 +00:00
|
|
|
%{
|
|
|
|
|
2011-08-20 23:22:51 +00:00
|
|
|
/*
|
2020-03-04 16:05:23 +00:00
|
|
|
* these ones return 2 values, here is a perl example:
|
2002-09-16 06:50:13 +00:00
|
|
|
* ($mode, $width) = $rig->get_mode();
|
|
|
|
*/
|
2018-12-27 21:10:10 +00:00
|
|
|
void Rig_get_mode(Rig *self, rmode_t *mode, pbwidth_t *width, vfo_t vfo)
|
2002-09-16 06:50:13 +00:00
|
|
|
{
|
2018-12-27 21:10:10 +00:00
|
|
|
self->error_status = rig_get_mode(self->rig, vfo, mode, width);
|
2002-09-16 06:50:13 +00:00
|
|
|
}
|
|
|
|
|
2018-12-27 21:10:10 +00:00
|
|
|
void Rig_get_split_mode(Rig *self, rmode_t *mode, pbwidth_t *width, vfo_t vfo)
|
2002-09-16 06:50:13 +00:00
|
|
|
{
|
2018-12-27 21:10:10 +00:00
|
|
|
self->error_status = rig_get_split_mode(self->rig, vfo, mode, width);
|
2002-09-16 06:50:13 +00:00
|
|
|
}
|
|
|
|
|
2020-03-04 16:05:23 +00:00
|
|
|
/*
|
|
|
|
* these ones return 3 values
|
|
|
|
*/
|
|
|
|
void Rig_get_split_freq_mode(Rig *self, vfo_t vfo, freq_t *tx_freq, rmode_t *tx_mode, pbwidth_t *tx_width)
|
|
|
|
{
|
|
|
|
self->error_status = rig_get_split_freq_mode(self->rig, vfo, tx_freq, tx_mode, tx_width);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-03-04 14:30:11 +00:00
|
|
|
/*
|
|
|
|
* these ones return 4 values
|
|
|
|
*/
|
|
|
|
void Rig_get_ant(Rig *self, ant_t *ant_rx, ant_t *ant_tx, ant_t *ant_curr, value_t *option, ant_t ant, vfo_t vfo)
|
2020-01-21 23:53:12 +00:00
|
|
|
{
|
2020-03-04 14:30:11 +00:00
|
|
|
self->error_status = rig_get_ant(self->rig, vfo, ant, option, ant_curr, ant_tx, ant_rx);
|
2020-01-21 23:53:12 +00:00
|
|
|
}
|
2021-04-29 14:00:59 +00:00
|
|
|
void Rig_get_vfo_info (Rig *self, int *satmode, split_t *split, pbwidth_t *width, rmode_t *mode, freq_t *freq, vfo_t vfo)
|
2021-03-09 05:26:44 +00:00
|
|
|
{
|
2021-04-29 14:00:59 +00:00
|
|
|
self->error_status = rig_get_vfo_info(self->rig, vfo, freq, mode, width, split, satmode);
|
2021-03-09 05:26:44 +00:00
|
|
|
}
|
|
|
|
|
2020-01-21 23:53:12 +00:00
|
|
|
|
2008-05-04 21:42:04 +00:00
|
|
|
struct channel *Rig_get_chan_all(Rig *self)
|
|
|
|
{
|
|
|
|
struct channel *chans;
|
|
|
|
int nb_chans = rig_mem_count(self->rig);
|
|
|
|
|
|
|
|
/* TODO: memleak: typemap to release that memory */
|
|
|
|
chans = calloc(sizeof (struct channel), nb_chans);
|
|
|
|
if (!chans)
|
|
|
|
{
|
|
|
|
self->error_status = -RIG_ENOMEM;
|
|
|
|
return NULL;
|
|
|
|
}
|
2020-11-30 05:32:14 +00:00
|
|
|
self->error_status = rig_get_chan_all(self->rig, RIG_VFO_NONE, chans);
|
2008-05-04 21:42:04 +00:00
|
|
|
/* TODO: copy ext_level's */
|
|
|
|
return chans;
|
|
|
|
}
|
|
|
|
|
2021-03-09 05:26:44 +00:00
|
|
|
|
2002-09-16 06:50:13 +00:00
|
|
|
%}
|