2011-09-01 17:09:53 +00:00
|
|
|
Half-arsed divelog software in C.
|
|
|
|
|
2011-11-27 16:53:14 +00:00
|
|
|
I'm tired of Java programs that don't work etc.
|
2011-09-01 17:09:53 +00:00
|
|
|
|
|
|
|
License: GPLv2
|
2011-09-03 15:53:05 +00:00
|
|
|
|
2011-09-22 22:20:26 +00:00
|
|
|
You need libxml2-devel, gtk2-devel, glib-2.0 and GConf2-devel to build
|
|
|
|
this (and libusb-1.0 if you have libdivecomputer built with it, but then
|
|
|
|
you obviously already have it installed)
|
2011-09-03 15:53:05 +00:00
|
|
|
|
2011-09-12 21:05:44 +00:00
|
|
|
You also need to have libdivecomputer installed, which goes something like this:
|
|
|
|
|
|
|
|
git clone git://libdivecomputer.git.sourceforge.net/gitroot/libdivecomputer/libdivecomputer
|
|
|
|
cd libdivecomputer
|
|
|
|
autoreconf --install
|
|
|
|
./configure
|
|
|
|
make
|
|
|
|
sudo make install
|
|
|
|
|
2011-09-22 22:20:26 +00:00
|
|
|
NOTE! You may need to tell the main Makefile where you installed
|
|
|
|
libdivecomputer if you didn't do it in the default /usr/local location.
|
|
|
|
I don't trust pkg-config for libdivecomputer, since pkg-config usually
|
|
|
|
doesn't work unless the project has been installed by the distro.
|
|
|
|
|
|
|
|
Just edit the makefile directly. autoconf and friends are the devil's
|
|
|
|
tools.
|
|
|
|
|
2011-09-03 15:53:05 +00:00
|
|
|
Usage:
|
|
|
|
|
|
|
|
make
|
2011-09-15 16:43:14 +00:00
|
|
|
./subsurface dives/*.xml
|
2011-09-03 15:53:05 +00:00
|
|
|
|
|
|
|
to see my dives (with no notes or commentary).
|
|
|
|
|
2011-09-26 17:06:00 +00:00
|
|
|
Or, if you have a dive computer supported by libdivecomputer, you can
|
|
|
|
just do
|
2011-09-12 21:05:44 +00:00
|
|
|
|
|
|
|
make
|
2011-09-15 16:43:14 +00:00
|
|
|
./subsurface
|
2011-09-12 21:05:44 +00:00
|
|
|
|
2012-05-02 19:56:01 +00:00
|
|
|
and select "Import" from the Log menu, tell it what dive computer you
|
2011-09-26 17:06:00 +00:00
|
|
|
have (and where it is connected if you need to), and hit "OK".
|
2011-09-12 21:05:44 +00:00
|
|
|
|
2011-09-27 21:09:21 +00:00
|
|
|
NOTE! There are often multiple models of dive computers that import
|
|
|
|
exactly the same way. If you have a Suunto Gekko, for example, the
|
|
|
|
import function works fine - even if you don't find the Gekko listed
|
|
|
|
explicitly. It has the same import engine as the older Suunto Vyper
|
|
|
|
(not "Vyper Air").
|
|
|
|
|
|
|
|
So check the (incomplete?) list of supported dive computers below, and
|
|
|
|
see which ones show up together. If you have the "Aeris Elite T3", for
|
|
|
|
example, you'd notice that it's in the same group with the "Oceanic Atom
|
|
|
|
2", and use that choice to import.
|
|
|
|
|
|
|
|
Suunto:
|
|
|
|
|
|
|
|
* Solution
|
|
|
|
|
|
|
|
* Eon, Solution Alpha and Solution Nitrox/Vario
|
|
|
|
|
|
|
|
* Vyper, Cobra, Vytec, Vytec DS, D3, Spyder, Gekko, Mosquito, Stinger and Zoop
|
|
|
|
|
|
|
|
* Vyper2, Cobra2, Cobra3, Vyper Air and HelO2
|
|
|
|
|
|
|
|
* D9, D6 and D4
|
|
|
|
|
|
|
|
Uwatec:
|
|
|
|
|
|
|
|
* Aladin
|
|
|
|
|
|
|
|
* Memomouse
|
|
|
|
|
|
|
|
* Smart and Galileo (infrared)
|
|
|
|
|
|
|
|
Reefnet:
|
|
|
|
|
|
|
|
* Sensus
|
|
|
|
|
|
|
|
* Sensus Pro
|
|
|
|
|
|
|
|
* Sensus Ultra
|
|
|
|
|
|
|
|
Oceanic, Aeris, Sherwood, Hollis, Genesis and Tusa (Pelagic):
|
|
|
|
|
|
|
|
* VT Pro, Versa Pro, Pro Plus 2, Wisdom, Atmos 2, Atmos AI, Atmos
|
|
|
|
Elite, ...
|
|
|
|
|
|
|
|
* Veo 250, Veo 180Nx, XR2, React Pro, DG02, Insight, ...
|
|
|
|
|
|
|
|
* Atom 2.0, VT3, Datamask, Geo, Geo 2.0, Veo 2.0, Veo 3.0, Pro Plus 2.1,
|
|
|
|
Compumask, Elite T3, Epic, Manta, IQ-900 (Zen), IQ-950 (Zen Air),
|
|
|
|
IQ-750 (Element II), ...
|
|
|
|
|
|
|
|
Mares:
|
|
|
|
|
|
|
|
* Nemo, Nemo Excel, Nemo Apneist, ...
|
|
|
|
|
|
|
|
* Puck, Puck Air, Nemo Air, Nemo Wide, ...
|
|
|
|
|
|
|
|
* Icon HD
|
|
|
|
|
|
|
|
Heinrichs Weikamp:
|
|
|
|
|
|
|
|
* OSTC, OSTC Mk.2 and OSTC 2N
|
|
|
|
|
|
|
|
Cressi, Zeagle and Mares (Seiko):
|
|
|
|
|
|
|
|
* Edy, Nemo Sport
|
|
|
|
|
|
|
|
* N2iTiON3
|
|
|
|
|
|
|
|
Atomic Aquatics:
|
|
|
|
|
|
|
|
* Cobalt
|
|
|
|
|
2011-09-03 15:53:05 +00:00
|
|
|
|
2011-09-20 19:40:34 +00:00
|
|
|
Implementation details:
|
|
|
|
|
2011-09-22 22:20:26 +00:00
|
|
|
main.c - program frame
|
|
|
|
dive.c - creates and maintaines the internal dive list structure
|
|
|
|
libdivecomputer.c
|
|
|
|
uemis.c
|
|
|
|
parse-xml.c
|
|
|
|
save-xml.c - interface with dive computers and the XML files
|
|
|
|
profile.c - creates the data for the profile and draws it using cairo
|
2011-09-20 19:40:34 +00:00
|
|
|
|
|
|
|
A first UI has been implemented in gtk and an attempt has been made to
|
2011-09-22 22:20:26 +00:00
|
|
|
separate program logic from UI implementation.
|
2011-09-20 19:40:34 +00:00
|
|
|
|
2011-09-22 22:20:26 +00:00
|
|
|
gtk-gui.c - overall layout, main window of the UI
|
|
|
|
divelist.c - list of dives subsurface maintains
|
|
|
|
equipment.c - equipment / tank information for each dive
|
|
|
|
info.c - detailed dive info
|
|
|
|
print.c - printing
|
2011-09-20 19:40:34 +00:00
|
|
|
|
2011-09-03 15:53:05 +00:00
|
|
|
WARNING! I wasn't kidding when I said that I've done this by reading
|
|
|
|
gtk2 tutorials as I've gone along. If somebody is more comfortable with
|
|
|
|
gtk, feel free to send me (signed-off) patches.
|
|
|
|
|
|
|
|
Just as an example of the extreme hackiness of the code, I don't even
|
|
|
|
bother connecting a signal for the "somebody edited the dive info"
|
|
|
|
cases. I just save/restore the dive info every single time you switch
|
|
|
|
dives. Christ! That's truly lame.
|
|
|
|
|
|
|
|
NOTE! Some of the dives are pretty pitiful. All the last dives are from
|
|
|
|
my divemaster course, so they are from following open water students
|
|
|
|
along (many of them the confined*water dives). There a lot of the
|
|
|
|
action is at the surface, so some of the "dives" are 4ft deep and 2min
|
|
|
|
long.
|
2011-09-06 19:32:51 +00:00
|
|
|
|
|
|
|
Contributing:
|
|
|
|
|
|
|
|
Please either send me signed-off patches or a pull request with
|
|
|
|
signed-off commits. If you don't sign off on them, I will not accept
|
|
|
|
them. This means adding a line that says "Signed-off-by: Name <email>"
|
|
|
|
at the end of each commit, indicating that you wrote the code and have
|
|
|
|
the right to pass it on as an open source patch.
|
|
|
|
|
|
|
|
See: http://gerrit.googlecode.com/svn/documentation/2.0/user-signedoffby.html
|
|
|
|
|
2011-09-06 21:58:05 +00:00
|
|
|
Also, please write good git commit messages. A good commit message
|
|
|
|
looks like this:
|
|
|
|
|
2011-11-27 16:53:14 +00:00
|
|
|
Header line: explaining the commit in one line
|
2011-09-06 21:58:05 +00:00
|
|
|
|
|
|
|
Body of commit message is a few lines of text, explaining things
|
|
|
|
in more detail, possibly giving some background about the issue
|
|
|
|
being fixed, etc etc.
|
|
|
|
|
2011-11-27 16:53:14 +00:00
|
|
|
The body of the commit message can be several paragraphs, and
|
2011-09-06 21:58:05 +00:00
|
|
|
please do proper word-wrap and keep columns shorter than about
|
|
|
|
74 characters or so. That way "git log" will show things
|
|
|
|
nicely even when it's indented.
|
|
|
|
|
|
|
|
Reported-by: whoever-reported-it
|
|
|
|
Signed-off-by: Your Name <youremail@yourhost.com>
|
|
|
|
|
|
|
|
where that header line really should be meaningful, and really should be
|
|
|
|
just one line. That header line is what is shown by tools like gitk and
|
|
|
|
shortlog, and should summarize the change in one readable line of text,
|
|
|
|
independently of the longer explanation.
|