Rename icon files to fit XDG specifications. Add file icons. Add mime types
[fw/altos] / telegps / Makefile.am
index cd2de1f964b841a5540c1016948efa5fcd9157bb..a7defb8a01798816bc553609b5e3cf88a2927365 100644 (file)
@@ -5,7 +5,7 @@ man_MANS=telegps.1
 
 altoslibdir=$(libdir)/altos
 
-CLASSPATH_ENV=mkdir -p $(JAVAROOT); CLASSPATH=".:classes:../altoslib/*:../altosuilib/*:../libaltos:$(JCOMMON)/jcommon.jar:$(JFREECHART)/jfreechart.jar"
+CLASSPATH_ENV=mkdir -p $(JAVAROOT); CLASSPATH=".:classes:../altoslib/*:../altosuilib/*:../libaltos:$(JCOMMON)/jcommon.jar:$(JFREECHART)/jfreechart.jar:$(FREETTS)/freetts.jar"
 
 bin_SCRIPTS=telegps
 
@@ -14,7 +14,14 @@ telegpsdir=$(datadir)/java
 telegps_JAVA= \
        TeleGPS.java \
        TeleGPSStatus.java \
-       TeleGPSStatusUpdate.java
+       TeleGPSStatusUpdate.java \
+       TeleGPSInfo.java \
+       TeleGPSState.java \
+       TeleGPSConfig.java \
+       TeleGPSConfigUI.java \
+       TeleGPSPreferences.java \
+       TeleGPSGraphUI.java \
+       TeleGPSDisplayThread.java
 
 JFREECHART_CLASS= \
     jfreechart.jar
@@ -22,6 +29,15 @@ JFREECHART_CLASS= \
 JCOMMON_CLASS=\
     jcommon.jar
 
+FREETTS_CLASS= \
+       cmudict04.jar \
+       cmulex.jar \
+       cmu_time_awb.jar \
+       cmutimelex.jar \
+       cmu_us_kal.jar \
+       en_us.jar \
+       freetts.jar
+
 JAR=telegps.jar
 
 FATJAR=telegps-fat.jar
@@ -42,25 +58,49 @@ ALTOSUILIB_CLASS=\
 ICONDIR=$(top_srcdir)/icon
 
 JAVA_ICONS=\
-       $(ICONDIR)/telegps-16.png \
-       $(ICONDIR)/telegps-32.png \
-       $(ICONDIR)/telegps-48.png \
-       $(ICONDIR)/telegps-64.png \
-       $(ICONDIR)/telegps-128.png \
-       $(ICONDIR)/telegps-256.png
+       $(ICONDIR)/altusmetrum-telegps-16.png \
+       $(ICONDIR)/altusmetrum-telegps-32.png \
+       $(ICONDIR)/altusmetrum-telegps-48.png \
+       $(ICONDIR)/altusmetrum-telegps-64.png \
+       $(ICONDIR)/altusmetrum-telegps-128.png\
+       $(ICONDIR)/altusmetrum-telegps-256.png
 
 # icon base names for jar
-ICONJAR= -C $(ICONDIR) telegps-16.png \
-       -C $(ICONDIR) telegps-32.png \
-       -C $(ICONDIR) telegps-48.png \
-       -C $(ICONDIR) telegps-64.png \
-       -C $(ICONDIR) telegps-128.png \
-       -C $(ICONDIR) telegps-256.png
-
-WINDOWS_ICON=$(ICONDIR)/telegps.ico
+ICONJAR= \
+       -C $(ICONDIR) altusmetrum-telegps-16.png \
+       -C $(ICONDIR) altusmetrum-telegps-32.png \
+       -C $(ICONDIR) altusmetrum-telegps-48.png \
+       -C $(ICONDIR) altusmetrum-telegps-64.png \
+       -C $(ICONDIR) altusmetrum-telegps-128.png\
+       -C $(ICONDIR) altusmetrum-telegps-256.png
+
+WINDOWS_ICONS  =\
+       ../icon/altusmetrum-telegps.ico \
+       ../icon/altusmetrum-telegps.exe
+       ../icon/application-vnd.altusmetrum.eeprom.ico \
+       ../icon/application-vnd.altusmetrum.eeprom.exe \
+       ../icon/application-vnd.altusmetrum.telemetry.ico \
+       ../icon/application-vnd.altusmetrum.telemetry.exe
+
+MACOSX_ICONS   =\
+       ../icon/altusmetrum-telegps.icns \
+       ../icon/application-vnd.altusmetrum.eeprom.icns \
+       ../icon/application-vnd.altusmetrum.telemetry.icns
+
+# Firmware
+FIRMWARE_TD_0_2=$(top_srcdir)/src/teledongle-v0.2/teledongle-v0.2-$(VERSION).ihx
+FIRMWARE_TD=$(FIRMWARE_TD_0_2)
+
+FIRMWARE_TBT_1_0=$(top_srcdir)/src/telebt-v1.0/telebt-v1.0-$(VERSION).ihx
+FIRMWARE_TBT=$(FIRMWARE_TBT_1_0)
+
+FIRMWARE_TG_1_0=$(top_srcdir)/src/telegps-v1.0/telegps-v1.0-$(VERSION).ihx
+FIRMWARE_TG=$(FIRMWARE_TG_1_0)
+
+FIRMWARE=$(FIRMWARE_TG) $(FIRMWARE_TD) $(FIRMWARE_TBT)
 
 desktopdir = $(datadir)/applications
-desktop_file = telegps.desktop
+desktop_file = altusmetrum-telegps.desktop
 desktop_SCRIPTS = $(desktop_file)
 
 all-local: telegps-test telegps-jdb $(JAR)
@@ -77,7 +117,7 @@ clean-local:
 EXTRA_DIST = $(desktop_file).in
 
 $(desktop_file): $(desktop_file).in
-       sed -e 's#%bindir%#@bindir@#' -e 's#%icondir%#$(datadir)/icons/hicolor/scalable/apps#' ${srcdir}/telegps.desktop.in > $@
+       sed -e 's#%bindir%#@bindir@#' -e 's#%icondir%#$(datadir)/icons/hicolor/scalable/apps#' ${srcdir}/$(desktop_file).in > $@
        chmod +x $@
 
 LINUX_DIST=TeleGPS-Linux-$(VERSION).tar.bz2
@@ -85,31 +125,21 @@ LINUX_SH=TeleGPS-Linux-$(VERSION).sh
 MACOSX_DIST=TeleGPS-Mac-$(VERSION).dmg
 WINDOWS_DIST=TeleGPS-Windows-$(VERSION_DASH).exe
 
-MICROPEAK_DOC=$(top_srcdir)/doc/telegps.pdf
+TELEGPS_DOC=$(top_srcdir)/doc/telegps.pdf
 
-DOC=$(MICROPEAK_DOC)
+DOC=$(TELEGPS_DOC)
 
 FAT_FILES=$(FATJAR) $(ALTOSLIB_CLASS) $(ALTOSUILIB_CLASS) $(FREETTS_CLASS) $(JFREECHART_CLASS) $(JCOMMON_CLASS)
 
-LINUX_FILES=$(FAT_FILES) libaltos.so $(FIRMWARE) $(DOC) telegps.desktop.in ../icon/telegps.svg
-LINUX_EXTRA=telegps-fat telegps.desktop.in
+LINUX_FILES=$(FAT_FILES) libaltos.so $(FIRMWARE) $(DOC) $(desktop_file).in ../icon/altusmetrum-telegps.svg
+LINUX_EXTRA=telegps-fat $(desktop_file).in
 
-MACOSX_DRIVER_URL=http://www.ftdichip.com/Drivers/VCP/MacOSX/FTDIUSBSerialDriver_v2_2_18.dmg
-MACOSX_DRIVER=FTDIUSBSerialDriver_v2_2_18.dmg
 MACOSX_INFO_PLIST=Info.plist
 MACOSX_README=ReadMe-Mac.rtf
-MACOSX_FILES=$(FAT_FILES) libaltos.dylib $(MACOSX_INFO_PLIST) $(MACOSX_DRIVER) $(MACOSX_README) $(DOC)
-
-$(MACOSX_DRIVER):
-       wget $(MACOSX_DRIVER_URL)
-
-WINDOWS_DRIVER_URL=http://www.ftdichip.com/Drivers/CDM/CDM20824_Setup.exe
-WINDOWS_DRIVER=CDM20824_Setup.exe
+MACOSX_FILES=$(FAT_FILES) libaltos.dylib $(MACOSX_INFO_PLIST) $(MACOSX_README) $(DOC) $(MACOSX_ICONS)
+MACOSX_EXTRA=$(FIRMWARE)
 
-$(WINDOWS_DRIVER):
-       wget $(WINDOWS_DRIVER_URL)
-
-WINDOWS_FILES=$(FAT_FILES) altos.dll altos64.dll $(DOC) $(WINDOWS_ICON) $(WINDOWS_DRIVER)
+WINDOWS_FILES=$(FAT_FILES) altos.dll altos64.dll $(top_srcdir)/altusmetrum.inf $(top_srcdir)/altusmetrum.cat $(DOC) $(WINDOWS_ICONS)
 
 if FATINSTALL
 
@@ -175,7 +205,7 @@ $(FATJAR): classtelegps.stamp Manifest-fat.txt $(ALTOSLIB_CLASS) $(ALTOSUILIB_CL
                -C classes org \
                -C ../libaltos libaltosJNI
 
-classaltosui.stamp: $(ALTOSLIB_CLASS) $(ALTOSUILIB_CLASS)
+classtelegps.stamp: $(ALTOSLIB_CLASS) $(ALTOSUILIB_CLASS)
 
 libaltos.so: build-libaltos
        -rm -f "$@"
@@ -215,6 +245,10 @@ $(ALTOSUILIB_CLASS):
        -rm -f "$@"
        $(LN_S) ../altosuilib/"$@" .
 
+$(FREETTS_CLASS):
+       -rm -f "$@"
+       $(LN_S) "$(FREETTS)"/"$@" .
+
 $(JFREECHART_CLASS):
        -rm -f "$@"
        $(LN_S) "$(JFREECHART)"/"$@" .
@@ -236,27 +270,30 @@ $(LINUX_SH): $(LINUX_DIST) $(srcdir)/../altosui/linux-install.sh
        sed 's/AltOS/TeleGPS/g' $(srcdir)/../altosui/linux-install.sh | cat - $(LINUX_DIST) > $@
        chmod +x $@
 
-$(MACOSX_DIST): $(MACOSX_FILES)
+$(MACOSX_DIST): $(MACOSX_FILES) $(MACOSX_EXTRA) Makefile
        -rm -f $@
        -rm -rf macosx
        mkdir macosx
        cp -a TeleGPS.app macosx/
        cp -a $(MACOSX_README) macosx/ReadMe.rtf
-       cp -a $(DOC) macosx
+       mkdir -p macosx/Doc
+       cp -a $(DOC) macosx/Doc
        cp -p Info.plist macosx/TeleGPS.app/Contents
-       cp -p $(MACOSX_DRIVER) macosx
-       mkdir -p macosx/TeleGPS.app/Contents/Resources/Java
+       mkdir -p macosx/AltOS-$(VERSION) macosx/TeleGPS.app/Contents/Resources/Java
+       cp -p $(MACOSX_ICONS) macosx/TeleGPS.app/Contents/Resources
        cp -p $(FATJAR) macosx/TeleGPS.app/Contents/Resources/Java/telegps.jar
        cp -p libaltos.dylib macosx/TeleGPS.app/Contents/Resources/Java
        cp -p $(ALTOSLIB_CLASS) macosx/TeleGPS.app/Contents/Resources/Java
        cp -p $(ALTOSUILIB_CLASS) macosx/TeleGPS.app/Contents/Resources/Java
+       cp -p $(FREETTS_CLASS) macosx/TeleGPS.app/Contents/Resources/Java
        cp -p $(JFREECHART_CLASS) macosx/TeleGPS.app/Contents/Resources/Java
        cp -p $(JCOMMON_CLASS) macosx/TeleGPS.app/Contents/Resources/Java
+       cp -p $(MACOSX_EXTRA) macosx/AltOS-$(VERSION)
        genisoimage -D -V TeleGPS-$(VERSION) -no-pad -r -apple -o $@ macosx
 
 $(WINDOWS_DIST): $(WINDOWS_FILES) telegps-windows.nsi
        -rm -f $@
-       makensis -Otelegps-windows.log "-XOutFile $@" "-DVERSION=$(VERSION)" telegps-windows.nsi
+       makensis -Otelegps-windows.log "-XOutFile $@" "-DVERSION=$(VERSION)" telegps-windows.nsi || (cat telegps-windows.log && exit 1)
 
 Manifest.txt: Makefile
        echo 'Main-Class: org.altusmetrum.telegps.TeleGPS' > $@