2002-05-28 21:28:15 +00:00
|
|
|
Hamlib - (C) Frank Singleton 2000 (vk3fcs@ix.netcom.com)
|
2002-10-29 22:14:58 +00:00
|
|
|
and Stephane Fillod 2000-2002
|
2000-07-18 21:09:51 +00:00
|
|
|
|
2000-08-20 21:52:27 +00:00
|
|
|
Take a look at http://sourceforge.net/projects/hamlib/
|
2002-05-28 21:28:15 +00:00
|
|
|
Here you will find a mail list, and the latest CVS releases.
|
2000-08-20 21:52:27 +00:00
|
|
|
|
2000-09-24 02:19:42 +00:00
|
|
|
See README for frontend/backend outline.
|
|
|
|
|
2000-07-18 21:09:51 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
The shared libs provide functions for both radio control,
|
|
|
|
and data retrieval from the radio.
|
2000-07-18 21:16:49 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
The structure of the libraries is as follows.
|
2000-07-18 21:16:49 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
(1) There is one frontend library "libhamlib" that
|
|
|
|
provides the generic API for user applications.
|
2000-07-18 21:16:49 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
(2) There are "n" backend libraries that "wrap"
|
|
|
|
rig specific communications inside frontend API.
|
2000-07-18 21:16:49 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
(3) Frontend lib loads (on demand) the appropriate
|
|
|
|
backend lib as required.
|
2000-07-18 21:19:57 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
Frontend Library
|
|
|
|
----------------
|
2000-07-18 21:19:57 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
libhamlib.so - frontend lib that provides generic API
|
|
|
|
for all RIG types. This is what Application
|
|
|
|
programmers will "see".
|
2000-08-20 21:52:27 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
Backend Examples are:
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
1.libhamlib-yaesu.so will provide connectivity to Yaesu
|
|
|
|
FT 747GX Transceiver, FT 847 "Earth Station", etc. via a standard API.
|
2000-09-24 02:19:42 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
2. libhamlib-xxxx.so will provide connectivity to the Wiz-bang
|
|
|
|
moon-melter 101A (yikes..)
|
2000-08-20 21:52:27 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
Hamlib also enables developers to develop professional looking
|
|
|
|
GUI's towards a standard control library API, and they would not have
|
|
|
|
to worry about the underlying connection towards physical hardware.
|
|
|
|
|
|
|
|
Initially serial (RS232) connectivity will be handled, but
|
|
|
|
I expect that IP (and other) connectivity will follow afterwards.
|
2000-08-20 21:52:27 +00:00
|
|
|
|
2000-09-24 02:19:42 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
General Guidelines.
|
|
|
|
-------------------
|
2000-09-24 02:19:42 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
0. The top level directory looks like this.
|
|
|
|
|
|
|
|
[fillods@charybde hamlib]$ tree -d
|
|
|
|
|-- alinco
|
|
|
|
|-- aor
|
|
|
|
|-- c++
|
|
|
|
|-- debian
|
|
|
|
|-- doc
|
|
|
|
| |-- html
|
|
|
|
| |-- man
|
|
|
|
| `-- sgml
|
|
|
|
|-- dummy
|
|
|
|
|-- easycomm
|
|
|
|
|-- icom
|
|
|
|
| |-- lib
|
|
|
|
| `-- test
|
|
|
|
|-- include
|
|
|
|
| `-- hamlib
|
|
|
|
|-- jrc
|
|
|
|
|-- kachina
|
|
|
|
|-- kenwood
|
|
|
|
|-- kylix
|
|
|
|
| `-- tests
|
|
|
|
|-- lib
|
|
|
|
|-- libltdl
|
|
|
|
|-- pcr
|
|
|
|
|-- perl
|
|
|
|
| `-- Hamlib
|
|
|
|
|-- rpcrig
|
|
|
|
|-- rpcrot
|
|
|
|
|-- src
|
|
|
|
|-- tcl
|
|
|
|
|-- tentec
|
|
|
|
|-- tests
|
|
|
|
| `-- html
|
|
|
|
|-- uniden
|
|
|
|
|-- winradio
|
|
|
|
| `-- linradio
|
|
|
|
`-- yaesu
|
|
|
|
|
|
|
|
|
2002-09-10 06:43:05 +00:00
|
|
|
1. Building
|
2002-10-29 22:14:58 +00:00
|
|
|
|
|
|
|
If you just want to recompile the library, please refer
|
|
|
|
to the INSTALL file.
|
|
|
|
|
|
|
|
1.1 Obtaining sources: anonymous (pserver) cvs checkout
|
|
|
|
|
|
|
|
cvs -d:pserver:anonymous@cvs.hamlib.sf.net:/cvsroot/hamlib login
|
|
|
|
cvs -z3 -d:pserver:anonymous@cvs.hamlib.sf.net:/cvsroot/hamlib co hamlib
|
|
|
|
|
|
|
|
When prompted for a password for anonymous, simply press the Enter key.
|
|
|
|
The check out has only to be done the first time. In the case you don't
|
|
|
|
have cvs access through your firewall, but http gets through, daily
|
|
|
|
cvs snapshots are available. The previous commands can be replaced
|
|
|
|
by the following:
|
|
|
|
|
|
|
|
wget http://cvs.sf.net/cvstarballs/hamlib-cvsroot.tar.gz
|
|
|
|
tar zxvf hamlib-cvsroot.tar.gz
|
|
|
|
mv hamlib hroot
|
|
|
|
export CVSROOT=`pwd`/hroot
|
2002-11-13 20:36:17 +00:00
|
|
|
cvs co -P hamlib
|
2002-10-29 22:14:58 +00:00
|
|
|
|
|
|
|
After the initial retrieval, whenever you want to update your local
|
|
|
|
version, issue the following command in the root directory of hamlib.
|
|
|
|
|
|
|
|
cvs -z3 -d:pserver:anonymous@cvs.hamlib.sf.net:/cvsroot/hamlib update -d
|
|
|
|
|
|
|
|
Tip:
|
|
|
|
I use the following alias:
|
|
|
|
alias hcvs='cvs -z3 -d:pserver:anonymous@cvs.hamlib.sf.net:/cvsroot/hamlib'
|
|
|
|
This way, I just have to do "hcvs update -d" whenever I want to keep to
|
|
|
|
date. Setting CVSROOT to ":pserver:anonymous@cvs.hamlib.sf.net:/cvsroot/hamlib"
|
|
|
|
works the same.
|
|
|
|
|
|
|
|
|
|
|
|
1.2. Requirements
|
2002-05-28 21:28:15 +00:00
|
|
|
|
|
|
|
Hamlib is entirely developped using GNU tools, under various Linux systems.
|
|
|
|
Note that it is not restricted to Linux systems. We welcome anyone who
|
|
|
|
has access to a POSIXish system to port Hamlib to. Contact us for help.
|
|
|
|
|
|
|
|
That is, if you want to take part in the development of Hamlib,
|
2002-10-29 22:14:58 +00:00
|
|
|
you'll need the following tools. Make sure you have at least the required
|
|
|
|
version or you won't even be able to build from the cvs checkout.
|
|
|
|
|
|
|
|
* Gnu C or any C99 compliant compiler # gcc --version
|
2002-11-13 20:36:17 +00:00
|
|
|
* Gnu make (or any modern one, BSD okay) # make --version
|
2002-11-28 22:34:22 +00:00
|
|
|
* autoconf 2.54 # autoconf --version
|
2002-10-29 22:14:58 +00:00
|
|
|
* automake 1.5 # automake --version
|
|
|
|
* libtool 1.4.2 # libtool --version
|
|
|
|
* cvs and ssh for connection to cvs.hamlib.sourceforge.net
|
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
Optional:
|
2002-10-29 22:14:58 +00:00
|
|
|
* GNU C++ # g++ --version
|
|
|
|
* swig (for bindings) 1.3.14 # swig -version
|
|
|
|
* perl devel # h2xs
|
|
|
|
* tcl devel
|
|
|
|
* libgd devel
|
|
|
|
* RPC devel (libc-dev) # rpcgen --version
|
2002-05-28 21:28:15 +00:00
|
|
|
|
|
|
|
Documentation:
|
|
|
|
* doxygen
|
|
|
|
* DocBook
|
|
|
|
|
2002-10-29 22:14:58 +00:00
|
|
|
Note:
|
|
|
|
Some systems can have several versions of the autotools installed.
|
|
|
|
In that case, autoconf may be called "autoconf2.50", autoheader "autoheader2.50",
|
|
|
|
and automake "automake-1.5", aclocal "aclocal-1.5" or upper version.
|
2002-05-28 21:28:15 +00:00
|
|
|
|
|
|
|
IMPORTANT: If autoconf or automake are installed on your system,
|
|
|
|
make sure they are matching *at least* the version shown above.
|
2002-11-13 20:36:17 +00:00
|
|
|
Some people experience troubles with automake 1.5, if you're one of those,
|
|
|
|
it's recommanded to upgrade to automake 1.7, which is a lot more stable.
|
2002-10-29 22:14:58 +00:00
|
|
|
|
|
|
|
|
|
|
|
1.3. configure and build stage
|
|
|
|
|
|
|
|
It has to be known the CVS repository holds no autogenerated files.
|
|
|
|
Hence after a fresh checkout, you'll have to generate those files.
|
|
|
|
To proceed, first edit the autogen.sh, and set appropriately
|
|
|
|
the AUTOCONF,AUTOHEADER,AUTOHEADER,ACLOCAL variables with the required
|
|
|
|
versions seen in the previous section.
|
|
|
|
|
|
|
|
chmod +x autogen.sh
|
2002-11-13 20:36:17 +00:00
|
|
|
./autogen.sh --disable-static --prefix=/some/where
|
2002-10-29 22:14:58 +00:00
|
|
|
make
|
|
|
|
make install
|
|
|
|
|
|
|
|
Once you've run autogen.sh, make sure you've got some recent
|
|
|
|
config.guess and config.sub (needed to guess your system type).
|
|
|
|
Anything of at least year 2002 should be fine, unless you run
|
|
|
|
some exotic hardware/software system:
|
|
|
|
|
|
|
|
./config.guess --version
|
|
|
|
./config.sub --version
|
|
|
|
|
|
|
|
The prefix argument is optionnal. The --disable-static speeds up
|
|
|
|
compilation if you don't plan to use static libraries.
|
|
|
|
|
|
|
|
NOTE: autogen.sh has only to be run the first time after a fresh checkout.
|
|
|
|
|
|
|
|
The difference between building as a tester and a developer
|
|
|
|
is in the '--enable-maintainer-mode' option passed to configure.
|
|
|
|
This option will add new Makefile targets and dependencies.
|
|
|
|
|
|
|
|
|
|
|
|
For Tcl build, add this if needed:
|
|
|
|
--with-tcl=/usr/lib/tcl8.2
|
|
|
|
|
|
|
|
Note: C-shell users may have to run it and make through a bourne shell instead,
|
|
|
|
or pass "SHELL=bash" as a parameter to make.
|
|
|
|
|
|
|
|
|
|
|
|
1.4. Feedback
|
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
The Hamlib team is very interrested to hear from you, how Hamlib
|
|
|
|
builds and works on your system, especially on non-Linux system or
|
|
|
|
non-PC systems. We try to make Hamlib as portable as possible.
|
|
|
|
Please report in case of problems at hamlib-developer@lists.sourceforge.net
|
|
|
|
Patches are welcome too!
|
|
|
|
|
|
|
|
So far, Hamlib has been tested under the following systems:
|
|
|
|
(if your system is not present, please report to mailing list)
|
|
|
|
|
2002-12-01 03:35:14 +00:00
|
|
|
* Debian potato/sarge/sid i386
|
2002-05-28 21:28:15 +00:00
|
|
|
* Debian sid mipsel
|
|
|
|
* RedHat i386
|
|
|
|
* Slackware i386
|
2002-11-13 20:36:17 +00:00
|
|
|
* FreeBSD
|
2002-05-28 21:28:15 +00:00
|
|
|
* win32: builds under Cygwin, module loading still broken
|
2002-10-29 22:14:58 +00:00
|
|
|
* Some work started under Darwin (issues with libtool)
|
2002-09-10 06:43:05 +00:00
|
|
|
|
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
2. How to add a new backend
|
|
|
|
The rule is one backend per protocol family.
|
|
|
|
Try to share code between rigs of the same family, if applicable.
|
|
|
|
|
|
|
|
|
|
|
|
2.1. mkdir mybackend
|
|
|
|
Create a new subdir, of the name of the protocol backend.
|
|
|
|
NB: the directory MUST be the same as the backend name.
|
|
|
|
|
|
|
|
2.2. Add <mybackend> to the SUBDIRS variable in the topdir Makefile.am,
|
|
|
|
2.3. Add the backend name to the BACKEND_LIST variable in configure.ac
|
|
|
|
2.4. Add "mybackend/Makefile" in the AC_CONFIG_FILES macro at the bottom
|
|
|
|
of configure.ac
|
|
|
|
|
|
|
|
2.5. Create mybackend/Makefile.am, mybackend.c mybackend.h
|
|
|
|
Use 'dummy' backend as a template.
|
2002-09-10 06:43:05 +00:00
|
|
|
Here are commands for the bourne shell.
|
2002-05-28 21:28:15 +00:00
|
|
|
|
|
|
|
$ automake mybackend/Makefile
|
|
|
|
$ CONFIG_HEADERS= CONFIG_LINKS= \
|
|
|
|
CONFIG_FILES=mybackend/Makefile ./config.status
|
|
|
|
|
|
|
|
make in topdir to rebuild all
|
|
|
|
|
|
|
|
2.6. Commit your work:
|
|
|
|
$ cvs add mybackend
|
|
|
|
$ cd mybackend
|
|
|
|
$ cvs add Makefile.am mybackend.c mybackend.h
|
|
|
|
$ cvs commit -m "Initial release" Makefile.am mybackend.c mybackend.h
|
|
|
|
|
|
|
|
|
|
|
|
3. How to add a new model to and existing backend
|
|
|
|
3.1. make sure there's already a (unique) ID for the model to be added
|
|
|
|
in include/hamlib/riglist.h
|
|
|
|
3.2. locate the existing backend
|
|
|
|
3.3. Clone the most similar model in the backend
|
|
|
|
3.4. Add the new C file to the _SOURCES variable
|
|
|
|
of the backend's Makefile.am
|
|
|
|
3.5. Add "extern const struct rig_caps <mymodel>_caps;" to mybackend.h
|
|
|
|
3.6. In initrigs_<mybackend> of mybackend.c,
|
|
|
|
add "rig_register(&<mymodel>_caps);"
|
2000-09-24 02:19:42 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
3.7. Run make if you have dependencies, or the following to regenerate
|
|
|
|
the makefile.
|
|
|
|
$ automake mybackend/Makefile
|
|
|
|
$ CONFIG_HEADERS= CONFIG_LINKS= \
|
|
|
|
CONFIG_FILES=mybackend/Makefile ./config.status
|
2000-09-24 02:19:42 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
make in topdir to rebuild all
|
2000-09-24 02:19:42 +00:00
|
|
|
|
2002-10-29 22:14:58 +00:00
|
|
|
3.8. Commit your work (once tests are satisfactory):
|
2002-05-28 21:28:15 +00:00
|
|
|
$ cd mybackend
|
|
|
|
$ cvs add mymodel.c
|
|
|
|
$ cvs commit -m "added <mymodel> to <mybackend>" \
|
|
|
|
Makefile.am mybackend.c mybackend.h mymodel.c
|
2000-09-24 02:19:42 +00:00
|
|
|
|
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
4. Read README.betatester to test the new backend/model.
|
|
|
|
Report to mailing list.
|
2000-09-24 02:19:42 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
5. Basic functions: set_freq and set_mode. set_vfo would be great.
|
2000-08-20 21:52:27 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
6. C code examples.
|
|
|
|
|
|
|
|
A C code snippet to connect to a FT847 and set
|
|
|
|
the frequency of the main VFO to 439,700,000 Hz ,
|
|
|
|
using FM as the required mode, would look something
|
|
|
|
like this. The error checking is removed for simplicity.
|
|
|
|
|
|
|
|
See tests/testrig.c
|
2000-08-20 21:52:27 +00:00
|
|
|
|
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
7. Where are the GUI's?
|
2000-08-20 21:52:27 +00:00
|
|
|
|
|
|
|
"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.
|
2002-05-28 21:28:15 +00:00
|
|
|
Starting point: kontakt, grig
|
2000-08-20 21:52:27 +00:00
|
|
|
|
2002-11-13 20:36:17 +00:00
|
|
|
8. Coding guidelines
|
2002-11-28 22:34:22 +00:00
|
|
|
Contributed code to the Hamlib frontend must be released under the LGPL.
|
2002-12-01 03:35:14 +00:00
|
|
|
Contributed code to Hamlib backends must follow backend current license.
|
2002-11-28 22:34:22 +00:00
|
|
|
Needless to say, the LGPL is the license of choice.
|
|
|
|
End user applications like rigctl, rotctl and RPC daemons should be released
|
|
|
|
under the GPL, so any contributed code must follow the rule.
|
|
|
|
|
2000-08-20 21:52:27 +00:00
|
|
|
|
2002-05-28 21:28:15 +00:00
|
|
|
Stephane Fillod f8cfe
|
2000-09-24 02:19:42 +00:00
|
|
|
Frank Singleton vk3fcs/km5ws
|
|
|
|
|