2001-03-20 22:17:25 +00:00
|
|
|
[FIXME: this doc is out dated! --SF 03/20/01]
|
|
|
|
|
2000-07-18 21:09:51 +00:00
|
|
|
hamlib - (C) Frank Singleton 2000 (vk3fcs@ix.netcom.com)
|
|
|
|
|
2000-08-20 21:52:27 +00:00
|
|
|
Take a look at http://sourceforge.net/projects/hamlib/
|
|
|
|
Here you will find a mail list, and the latest CVS releases.
|
|
|
|
|
|
|
|
|
2000-09-24 02:19:42 +00:00
|
|
|
See README for frontend/backend outline.
|
|
|
|
|
2000-07-18 21:09:51 +00:00
|
|
|
General Guidelines.
|
|
|
|
-------------------
|
|
|
|
|
2000-07-18 21:26:14 +00:00
|
|
|
0. The top level directory looks like thus.
|
|
|
|
|
2000-07-28 22:11:20 +00:00
|
|
|
[frank@kirk hamlib]$ tree -d
|
|
|
|
.
|
|
|
|
|-- CVS
|
|
|
|
|-- common
|
|
|
|
| `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
|-- ft1000
|
2000-07-28 22:11:20 +00:00
|
|
|
| `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
|-- ft1000d
|
2000-07-28 22:11:20 +00:00
|
|
|
| `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
|-- ft747
|
2000-07-28 22:11:20 +00:00
|
|
|
| |-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
| |-- include
|
2000-07-28 22:11:20 +00:00
|
|
|
| | `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
| |-- lib
|
2000-07-28 22:11:20 +00:00
|
|
|
| | `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
| `-- test
|
2000-07-28 22:11:20 +00:00
|
|
|
| `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
|-- ft840
|
2000-07-28 22:11:20 +00:00
|
|
|
| `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
|-- ft847
|
2000-07-28 22:11:20 +00:00
|
|
|
| |-- CVS
|
|
|
|
| |-- include
|
|
|
|
| | `-- CVS
|
|
|
|
| |-- lib
|
|
|
|
| | `-- CVS
|
|
|
|
| `-- test
|
|
|
|
| `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
|-- ft920
|
2000-07-28 22:11:20 +00:00
|
|
|
| `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
|-- ts570d
|
2000-07-28 22:11:20 +00:00
|
|
|
| `-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
|-- ts870s
|
2000-07-28 22:11:20 +00:00
|
|
|
| `-- CVS
|
|
|
|
`-- ts950
|
|
|
|
`-- CVS
|
2000-07-18 21:26:14 +00:00
|
|
|
|
2000-07-18 21:09:51 +00:00
|
|
|
1.Every new shared lib should be created autonomously
|
|
|
|
within its own directory. eg ft747/ for libft747.so
|
|
|
|
|
|
|
|
2. Every lib should have the following structure
|
2000-07-28 22:11:20 +00:00
|
|
|
[frank@kirk ft747]$ tree
|
|
|
|
|
|
|
|
.
|
|
|
|
|-- CVS
|
|
|
|
| |-- Entries
|
|
|
|
| |-- Entries.Log
|
|
|
|
| |-- Repository
|
|
|
|
| `-- Root
|
2000-07-18 21:09:51 +00:00
|
|
|
|-- Makefile
|
|
|
|
|-- README.ft747
|
|
|
|
|-- TODO.ft747
|
|
|
|
|-- ft747.c
|
|
|
|
|-- ft747.h
|
|
|
|
|-- include
|
2000-07-28 22:11:20 +00:00
|
|
|
| `-- CVS
|
|
|
|
| |-- Entries
|
|
|
|
| |-- Repository
|
|
|
|
| `-- Root
|
2000-07-18 21:09:51 +00:00
|
|
|
|-- lib
|
2000-07-28 22:11:20 +00:00
|
|
|
| `-- CVS
|
|
|
|
| |-- Entries
|
|
|
|
| |-- Repository
|
|
|
|
| `-- Root
|
2000-07-18 21:09:51 +00:00
|
|
|
`-- test
|
2000-07-28 22:11:20 +00:00
|
|
|
|-- CVS
|
|
|
|
| |-- Entries
|
|
|
|
| |-- Repository
|
|
|
|
| `-- Root
|
2000-07-18 21:09:51 +00:00
|
|
|
|-- Makefile
|
|
|
|
|-- testlibft747.c
|
2000-07-28 22:11:20 +00:00
|
|
|
`-- testlibft747.h
|
2000-07-18 21:09:51 +00:00
|
|
|
|
2000-07-28 22:11:20 +00:00
|
|
|
3. Use the ft847 tree for examples of coding style. If there
|
2000-07-18 21:09:51 +00:00
|
|
|
are any glaring problems,let me know..
|
|
|
|
|
|
|
|
4. The "test" directory should contain source code of the
|
|
|
|
form testlibXXXX.[ch]
|
|
|
|
|
|
|
|
5. The "test" directory should build a test suite that
|
|
|
|
excercises the API you are implementing.
|
|
|
|
|
|
|
|
6. libXXXX.so should be built to allow TX (PTT) to be disabled
|
2000-08-20 21:52:27 +00:00
|
|
|
if required. See ft847.[ch] for how this is done.
|
2000-07-18 21:09:51 +00:00
|
|
|
|
2000-07-18 21:16:49 +00:00
|
|
|
7. The Makefile for the test suite should have a target like
|
|
|
|
this to allow testing the API.
|
|
|
|
|
|
|
|
# run test program in local directory
|
|
|
|
|
|
|
|
.PHONY: runtest
|
|
|
|
runtest:
|
|
|
|
(LD_LIBRARY_PATH="../lib" ./testlibft747 )
|
|
|
|
|
|
|
|
|
|
|
|
8. You may wish to make an example out from your test suite
|
|
|
|
program available as follows.
|
|
|
|
|
|
|
|
make runtest > RESULT.example
|
2000-07-18 21:19:57 +00:00
|
|
|
|
|
|
|
9. Your header file (eg ft747.h, ft847.h etc) documents
|
2000-09-24 02:19:42 +00:00
|
|
|
your backend API, so please describe it so others can understand.
|
2000-07-18 21:19:57 +00:00
|
|
|
If this cannot be done, I may consider an "API.xxx" that
|
2000-07-28 22:11:20 +00:00
|
|
|
decsribes the API (eg: API.ft847 )
|
2000-07-18 21:19:57 +00:00
|
|
|
|
2000-08-20 21:52:27 +00:00
|
|
|
10. C code examples.
|
|
|
|
An example piece of code may uses the ft847 API could
|
|
|
|
look like this..
|
|
|
|
|
|
|
|
A C code snippet to connect to a FT847 and set
|
2000-09-24 02:19:42 +00:00
|
|
|
the frequency of the main VFO to 439,700,000 Hz ,
|
2000-08-20 21:52:27 +00:00
|
|
|
using FM as the required mode, would look something
|
2000-09-24 02:19:42 +00:00
|
|
|
like this. The error checking is removed for simplicity.
|
|
|
|
|
|
|
|
See testrig.c for an example.
|
2000-08-20 21:52:27 +00:00
|
|
|
|
|
|
|
<snip>
|
|
|
|
|
2000-09-24 02:19:42 +00:00
|
|
|
#define SERIAL_PORT "/dev/ttyS1"
|
|
|
|
...
|
|
|
|
|
|
|
|
my_rig = rig_init(RIG_MODEL_FT847);
|
|
|
|
strncpy(my_rig->state.rig_path,SERIAL_PORT,FILPATHLEN);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Example of setting rig Main VFO to 439.700 Mhz FM -- FS
|
|
|
|
* and some error checking on the return code.
|
|
|
|
*/
|
|
|
|
|
|
|
|
retcode = rig_set_vfo(my_rig, RIG_VFO_MAIN);
|
|
|
|
|
|
|
|
if (retcode != RIG_OK ) {
|
|
|
|
printf("rig_set_vfo: error = %i \n", retcode);
|
|
|
|
}
|
|
|
|
|
|
|
|
rig_set_freq(my_rig, 439700000); /* cq de vk3fcs */
|
|
|
|
|
|
|
|
if (retcode != RIG_OK ) {
|
|
|
|
printf("rig_set_freq: error = %i \n", retcode);
|
|
|
|
}
|
|
|
|
|
|
|
|
rig_set_mode(my_rig, RIG_MODE_FM);
|
|
|
|
|
|
|
|
if (retcode != RIG_OK ) {
|
|
|
|
printf("rig_get_mode: error = %i \n", retcode);
|
|
|
|
}
|
2000-08-20 21:52:27 +00:00
|
|
|
|
|
|
|
<snip>
|
|
|
|
|
|
|
|
|
|
|
|
11. Where are the GUI's.
|
|
|
|
|
|
|
|
"Build it and they will come ..."
|
|
|
|
|
|
|
|
Seriously, I am hoping the API's will provide a solid
|
|
|
|
framework for some cool GUI development. I would like
|
|
|
|
to see some GTK apps that use the hamlib API's
|
|
|
|
so they can be used by end users as a nice part of the
|
|
|
|
Ham shack.
|
|
|
|
|
|
|
|
|
|
|
|
|
2000-09-24 02:19:42 +00:00
|
|
|
Frank Singleton vk3fcs/km5ws
|
|
|
|
|
|
|
|
|
2000-07-18 21:19:57 +00:00
|
|
|
|
2000-07-28 22:11:20 +00:00
|
|
|
|