[packages/svox] - new, partially based on Debian packaging (with all patches) - added link patch to fix libpicotts l

qboosh qboosh at pld-linux.org
Sat Mar 2 20:20:26 CET 2013


commit f4a1d095740b66e857273daeff9430ff2c62f578
Author: Jakub Bogusz <qboosh at pld-linux.org>
Date:   Sat Mar 2 20:20:11 2013 +0100

    - new, partially based on Debian packaging (with all patches)
    - added link patch to fix libpicotts linking

 ...utoconf-building-of-library-using-libtool.patch | 123 +++++++
 0002-gitignore-for-autotools-files.patch           |  51 +++
 ...onvert-text-to-.wav-using-svox-text-to-sp.patch | 399 +++++++++++++++++++++
 0004-add-header-files.patch                        |  59 +++
 0005-Install-lang-files.patch                      |  32 ++
 0006-Set-picolangdir.patch                         |  40 +++
 0008-64bits.patch                                  |  26 ++
 svox-link.patch                                    |  10 +
 svox.spec                                          | 230 ++++++++++++
 9 files changed, 970 insertions(+)
---
diff --git a/svox.spec b/svox.spec
new file mode 100644
index 0000000..4a173e9
--- /dev/null
+++ b/svox.spec
@@ -0,0 +1,230 @@
+Summary:	SVOX Pico software speech synthesizer engine
+Summary(pl.UTF-8):	Silnik programowego syntezatora mowy SVOX Pico
+Name:		svox
+%define	subver	git20110131
+Version:	1.0
+Release:	0.%{subver}.1
+License:	Apache v2.0
+Group:		Libraries
+Source0:	http://ftp.de.debian.org/debian/pool/non-free/s/svox/%{name}_%{version}+%{subver}.orig.tar.gz
+# Source0-md5:	e9dd590721705c50ee5d7f262bd3c697
+Patch0:		0001-autoconf-building-of-library-using-libtool.patch
+Patch1:		0002-gitignore-for-autotools-files.patch
+Patch2:		0003-pico2wave-Convert-text-to-.wav-using-svox-text-to-sp.patch
+Patch3:		0004-add-header-files.patch
+Patch4:		0005-Install-lang-files.patch
+Patch5:		0006-Set-picolangdir.patch
+Patch6:		0008-64bits.patch
+Patch7:		%{name}-link.patch
+URL:		http://www.android.com/
+BuildRequires:	autoconf >= 2.59
+BuildRequires:	automake >= 1:1.9
+BuildRequires:	libtool >= 2:2
+BuildRoot:	%{tmpdir}/%{name}-%{version}-root-%(id -u -n)
+
+%description
+The SVOX Pico engine is a software speech synthesizer for German,
+English (GB and US), Spanish, French and Italian.
+
+SVOX produces a clear and distinct speech output made possible by the
+use of Hidden Markov Model (HMM) algorithms.
+
+%description -l pl.UTF-8
+Silnik SVOX Pico to programowy syntezator mowy dla języka
+niemieckiego, angielskiego (brytyjskiego i amerykańskiego),
+hiszpańskiego, francuskiego i włoskiego.
+
+SVOX wytwarza czystą i wyraźną mowę dzięki użyciu algorytmów opartych
+na ukrytych modelach Markowa (HMM - Hidden Markov Model).
+
+%package devel
+Summary:	Header files for SVOX Pico TTS library
+Summary(pl.UTF-8):	Pliki nagłówkowe biblioteki SVOX Pico TTS
+Group:		Development/Libraries
+Requires:	%{name} = %{version}-%{release}
+
+%description devel
+Header files for SVOX Pico TTS library.
+
+%description devel -l pl.UTF-8
+Pliki nagłówkowe biblioteki SVOX Pico TTS.
+
+%package static
+Summary:	Static SVOX Pico TTS library
+Summary(pl.UTF-8):	Statyczna biblioteka SVOX Pico TTS
+Group:		Development/Libraries
+Requires:	%{name}-devel = %{version}-%{release}
+
+%description static
+Static SVOX Pico TTS library.
+
+%description static -l pl.UTF-8
+Statyczna biblioteka SVOX Pico TTS.
+
+%package lang-de
+Summary:	SVOX Pico TTS language files (lingware) for German
+Summary(pl.UTF-8):	Pliki językowe (lingware) syntezatora SVOX Pico dla języka niemieckiego
+Group:		Applications/Text
+Requires:	%{name} = %{version}-%{release}
+
+%description lang-de
+SVOX Pico TTS language files (lingware) for German.
+
+%description lang-de -l pl.UTF-8
+Pliki językowe (lingware) syntezatora SVOX Pico dla języka
+niemieckiego.
+
+%package lang-en_GB
+Summary:	SVOX Pico TTS language files (lingware) for UK English
+Summary(pl.UTF-8):	Pliki językowe (lingware) syntezatora SVOX Pico dla angielskiego brytyjskiego
+Group:		Applications/Text
+Requires:	%{name} = %{version}-%{release}
+
+%description lang-en_GB
+SVOX Pico TTS language files (lingware) for UK English.
+
+%description lang-en_GB -l pl.UTF-8
+Pliki językowe (lingware) syntezatora SVOX Pico dla języka
+angielskiego brytyjskiego.
+
+%package lang-en_US
+Summary:	SVOX Pico TTS language files (lingware) for US English
+Summary(pl.UTF-8):	Pliki językowe (lingware) syntezatora SVOX Pico dla angielskiego amerykańskiego
+Group:		Applications/Text
+Requires:	%{name} = %{version}-%{release}
+
+%description lang-en_US
+SVOX Pico TTS language files (lingware) for US English.
+
+%description lang-en_US -l pl.UTF-8
+Pliki językowe (lingware) syntezatora SVOX Pico dla języka
+angielskiego amerykańskiego.
+
+%package lang-es
+Summary:	SVOX Pico TTS language files (lingware) for Spanish
+Summary(pl.UTF-8):	Pliki językowe (lingware) syntezatora SVOX Pico dla języka hiszpańskiego
+Group:		Applications/Text
+Requires:	%{name} = %{version}-%{release}
+
+%description lang-es
+SVOX Pico TTS language files (lingware) for Spanish
+
+%description lang-es -l pl.UTF-8
+Pliki językowe (lingware) syntezatora SVOX Pico dla języka
+hiszpańskiego.
+
+%package lang-fr
+Summary:	SVOX Pico TTS language files (lingware) for French
+Summary(pl.UTF-8):	Pliki językowe (lingware) syntezatora SVOX Pico dla języka francuskiego
+Group:		Applications/Text
+Requires:	%{name} = %{version}-%{release}
+
+%description lang-fr
+SVOX Pico TTS language files (lingware) for French.
+
+%description lang-fr -l pl.UTF-8
+Pliki językowe (lingware) syntezatora SVOX Pico dla języka
+francuskiego.
+
+%package lang-it
+Summary:	SVOX Pico TTS language files (lingware) for Italian
+Summary(pl.UTF-8):	Pliki językowe (lingware) syntezatora SVOX Pico dla języka włoskiego
+Group:		Applications/Text
+Requires:	%{name} = %{version}-%{release}
+
+%description lang-it
+SVOX Pico TTS language files (lingware) for Italian.
+
+%description lang-it -l pl.UTF-8
+Pliki językowe (lingware) syntezatora SVOX Pico dla języka
+włoskiego.
+
+%package docs
+Summary:	SVOX Pico TTS engine documentation
+Summary(pl.UTF-8):	Dokumentacja silnika syntezy mowy SVOX Pico
+Group:		Documentation
+
+%description docs
+SVOX Pico TTS engine documentation.
+
+%description docs -l pl.UTF-8
+Dokumentacja silnika syntezy mowy SVOX Pico.
+
+%prep
+%setup -q -n %{name}-%{version}+%{subver}
+%patch0 -p1
+%patch1 -p1
+%patch2 -p1
+%patch3 -p1
+%patch4 -p1
+%patch5 -p1
+%patch6 -p1
+%patch7 -p1
+
+%build
+cd pico
+%{__libtoolize}
+%{__aclocal}
+%{__autoconf}
+%{__automake}
+%configure
+
+%{__make}
+
+%install
+rm -rf $RPM_BUILD_ROOT
+
+%{__make} -C pico install \
+	DESTDIR=$RPM_BUILD_ROOT
+
+%clean
+rm -rf $RPM_BUILD_ROOT
+
+%post	-p /sbin/ldconfig
+%postun	-p /sbin/ldconfig
+
+%files
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_bindir}/pico2wave
+%attr(755,root,root) %{_libdir}/libttspico.so.*.*.*
+%attr(755,root,root) %ghost %{_libdir}/libttspico.so.0
+%dir %{_datadir}/pico
+%dir %{_datadir}/pico/lang
+
+%files devel
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_libdir}/libttspico.so
+%{_libdir}/libttspico.la
+%{_includedir}/pico*.h
+
+%files static
+%defattr(644,root,root,755)
+%{_libdir}/libttspico.a
+
+%files lang-de
+%defattr(644,root,root,755)
+%{_datadir}/pico/lang/de-DE_*.bin
+
+%files lang-en_GB
+%defattr(644,root,root,755)
+%{_datadir}/pico/lang/en-GB_*.bin
+
+%files lang-en_US
+%defattr(644,root,root,755)
+%{_datadir}/pico/lang/en-US_*.bin
+
+%files lang-es
+%defattr(644,root,root,755)
+%{_datadir}/pico/lang/es-ES_*.bin
+
+%files lang-fr
+%defattr(644,root,root,755)
+%{_datadir}/pico/lang/fr-FR_*.bin
+
+%files lang-it
+%defattr(644,root,root,755)
+%{_datadir}/pico/lang/it-IT_*.bin
+
+%files docs
+%defattr(644,root,root,755)
+%doc pico_resources/docs/SVOX_Pico_{Lingware,Manual,architecture_and_design}.pdf
diff --git a/0001-autoconf-building-of-library-using-libtool.patch b/0001-autoconf-building-of-library-using-libtool.patch
new file mode 100644
index 0000000..23201b6
--- /dev/null
+++ b/0001-autoconf-building-of-library-using-libtool.patch
@@ -0,0 +1,123 @@
+From 9fe1aa475b2667446b081623abc5c6f6083a76e6 Mon Sep 17 00:00:00 2001
+From: Mathieu Parent <math.parent at gmail.com>
+Date: Sat, 24 Oct 2009 17:03:37 +0200
+Subject: [PATCH 1/7] autoconf building of library (using libtool)
+
+---
+ pico/Makefile.am  |   36 ++++++++++++++++++++++++++++++++++++
+ pico/autogen.sh   |   36 ++++++++++++++++++++++++++++++++++++
+ pico/configure.in |   16 ++++++++++++++++
+ 3 files changed, 88 insertions(+), 0 deletions(-)
+ create mode 100644 pico/Makefile.am
+ create mode 100755 pico/autogen.sh
+ create mode 100644 pico/configure.in
+
+diff --git a/pico/Makefile.am b/pico/Makefile.am
+new file mode 100644
+index 0000000..6d8a10c
+--- /dev/null
++++ b/pico/Makefile.am
+@@ -0,0 +1,36 @@
++## Makefile.am -- Process this file with automake to produce Makefile.in
++
++ACLOCAL_AMFLAGS = -I m4
++
++lib_LTLIBRARIES = libttspico.la
++libttspico_la_SOURCES = \
++	lib/picoacph.c \
++	lib/picoapi.c \
++	lib/picobase.c \
++	lib/picocep.c \
++	lib/picoctrl.c \
++	lib/picodata.c \
++	lib/picodbg.c \
++	lib/picoextapi.c \
++	lib/picofftsg.c \
++	lib/picokdbg.c \
++	lib/picokdt.c \
++	lib/picokfst.c \
++	lib/picoklex.c \
++	lib/picoknow.c \
++	lib/picokpdf.c \
++	lib/picokpr.c \
++	lib/picoktab.c \
++	lib/picoos.c \
++	lib/picopal.c \
++	lib/picopam.c \
++	lib/picopr.c \
++	lib/picorsrc.c \
++	lib/picosa.c \
++	lib/picosig.c \
++	lib/picosig2.c \
++	lib/picospho.c \
++	lib/picotok.c \
++	lib/picotrns.c \
++	lib/picowa.c
++
+diff --git a/pico/autogen.sh b/pico/autogen.sh
+new file mode 100755
+index 0000000..a2f757c
+--- /dev/null
++++ b/pico/autogen.sh
+@@ -0,0 +1,36 @@
++#!/bin/sh
++
++#created by aclocal
++rm -rf autom4te.cache
++rm -f aclocal.m4
++
++#created by libtoolize
++rm -rf m4
++rm -f ltmain.sh
++
++#created by autoconf
++rm -f configure
++
++#created by automake
++rm -f install-sh missing depcomp Makefile.in config.guess config.sub
++
++#created by ./configure
++rm -rf .deps
++rm -f Makefile config.log config.status libtool
++
++if [ "$1" = "clean" ]; then
++    exit
++fi
++
++IPATHS="-I lib"
++
++aclocal $IPATHS
++libtoolize
++autoconf $IPATHS
++automake --add-missing
++
++rm -rf autom4te.cache
++
++echo "Now run ./configure and then make."
++exit 0
++
+diff --git a/pico/configure.in b/pico/configure.in
+new file mode 100644
+index 0000000..0afb56d
+--- /dev/null
++++ b/pico/configure.in
+@@ -0,0 +1,16 @@
++dnl Process this file with autoconf to produce a configure script.
++
++AC_PREREQ(2.59)
++
++AC_INIT([svox], [1.0], [math.parent at gmail.com])
++
++AM_INIT_AUTOMAKE([1.9 foreign])
++
++AC_PROG_CC
++LT_INIT
++AC_PROG_LIBTOOL
++
++AC_CONFIG_FILES([Makefile])
++AC_OUTPUT
++
++AC_CONFIG_MACRO_DIR([m4])
+-- 
+1.7.1
+
diff --git a/0002-gitignore-for-autotools-files.patch b/0002-gitignore-for-autotools-files.patch
new file mode 100644
index 0000000..df57df7
--- /dev/null
+++ b/0002-gitignore-for-autotools-files.patch
@@ -0,0 +1,51 @@
+From b56b0a4bdf3e11271caab744f532cb055c517b51 Mon Sep 17 00:00:00 2001
+From: Mathieu Parent <math.parent at gmail.com>
+Date: Sat, 24 Oct 2009 17:12:42 +0200
+Subject: [PATCH 2/7] gitignore for autotools files
+
+---
+ pico/.gitignore |   32 ++++++++++++++++++++++++++++++++
+ 1 files changed, 32 insertions(+), 0 deletions(-)
+ create mode 100644 pico/.gitignore
+
+diff --git a/pico/.gitignore b/pico/.gitignore
+new file mode 100644
+index 0000000..4235569
+--- /dev/null
++++ b/pico/.gitignore
+@@ -0,0 +1,32 @@
++#created by aclocal
++autom4te.cache
++aclocal.m4
++
++#created by libtoolize
++m4
++ltmain.sh
++
++#created by autoconf
++configure
++
++#created by automake
++install-sh
++missing
++depcomp
++Makefile.in
++config.guess
++config.sub
++
++#created by ./configure
++.deps
++Makefile
++config.log
++config.status
++libtool
++
++#created by make
++*.o
++*.lo
++.libs
++libttspico.la
++
+-- 
+1.7.1
+
diff --git a/0003-pico2wave-Convert-text-to-.wav-using-svox-text-to-sp.patch b/0003-pico2wave-Convert-text-to-.wav-using-svox-text-to-sp.patch
new file mode 100644
index 0000000..8ef4757
--- /dev/null
+++ b/0003-pico2wave-Convert-text-to-.wav-using-svox-text-to-sp.patch
@@ -0,0 +1,399 @@
+From 8bec80dccc9f4fe147a500486813f4e89a0d56d8 Mon Sep 17 00:00:00 2001
+From: Mathieu Parent <math.parent at gmail.com>
+Date: Sun, 25 Oct 2009 15:19:01 +0100
+Subject: [PATCH 3/7] pico2wave: Convert text to .wav using svox text-to-speech system.
+
+---
+ pico/.gitignore      |    1 +
+ pico/Makefile.am     |    7 +
+ pico/bin/pico2wave.c |  341 ++++++++++++++++++++++++++++++++++++++++++++++++++
+ pico/configure.in    |    3 +
+ 4 files changed, 352 insertions(+), 0 deletions(-)
+ create mode 100644 pico/bin/pico2wave.c
+
+diff --git a/pico/.gitignore b/pico/.gitignore
+index 4235569..a110298 100644
+--- a/pico/.gitignore
++++ b/pico/.gitignore
+@@ -29,4 +29,5 @@ libtool
+ *.lo
+ .libs
+ libttspico.la
++pico2wave
+ 
+diff --git a/pico/Makefile.am b/pico/Makefile.am
+index 6d8a10c..0d9472d 100644
+--- a/pico/Makefile.am
++++ b/pico/Makefile.am
+@@ -34,3 +34,10 @@ libttspico_la_SOURCES = \
+ 	lib/picotrns.c \
+ 	lib/picowa.c
+ 
++bin_PROGRAMS = pico2wave
++pico2wave_SOURCES = \
++	bin/pico2wave.c
++pico2wave_LDADD = \
++	libttspico.la -lm -lpopt
++pico2wave_CFLAGS = -Wall -I lib
++
+diff --git a/pico/bin/pico2wave.c b/pico/bin/pico2wave.c
+new file mode 100644
+index 0000000..0c035a7
+--- /dev/null
++++ b/pico/bin/pico2wave.c
+@@ -0,0 +1,341 @@
++/* pico2wave.c
++
++ * Copyright (C) 2009 Mathieu Parent <math.parent at gmail.com>
++ *
++ * Licensed under the Apache License, Version 2.0 (the "License");
++ * you may not use this file except in compliance with the License.
++ * You may obtain a copy of the License at
++ *
++ *     http://www.apache.org/licenses/LICENSE-2.0
++ *
++ * Unless required by applicable law or agreed to in writing, software
++ * distributed under the License is distributed on an "AS IS" BASIS,
++ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++ * See the License for the specific language governing permissions and
++ * limitations under the License.
++ *
++ *   Convert text to .wav using svox text-to-speech system.
++ *
++ */
++
++
++#include <popt.h>
++#include <stdio.h>
++#include <stdlib.h>
++#include <string.h>
++
++#include <picoapi.h>
++#include <picoapid.h>
++#include <picoos.h>
++
++
++/* adaptation layer defines */
++#define PICO_MEM_SIZE       2500000
++#define DummyLen 100000000
++
++/* string constants */
++#define MAX_OUTBUF_SIZE     128
++const char * PICO_LINGWARE_PATH             = "./lang/";
++const char * PICO_VOICE_NAME                = "PicoVoice";
++
++/* supported voices
++   Pico does not seperately specify the voice and locale.   */
++const char * picoSupportedLangIso3[]        = { "eng",              "eng",              "deu",              "spa",              "fra",              "ita" };
++const char * picoSupportedCountryIso3[]     = { "USA",              "GBR",              "DEU",              "ESP",              "FRA",              "ITA" };
++const char * picoSupportedLang[]            = { "en-US",            "en-GB",            "de-DE",            "es-ES",            "fr-FR",            "it-IT" };
++const char * picoInternalLang[]             = { "en-US",            "en-GB",            "de-DE",            "es-ES",            "fr-FR",            "it-IT" };
++const char * picoInternalTaLingware[]       = { "en-US_ta.bin",     "en-GB_ta.bin",     "de-DE_ta.bin",     "es-ES_ta.bin",     "fr-FR_ta.bin",     "it-IT_ta.bin" };
++const char * picoInternalSgLingware[]       = { "en-US_lh0_sg.bin", "en-GB_kh0_sg.bin", "de-DE_gl0_sg.bin", "es-ES_zl0_sg.bin", "fr-FR_nk0_sg.bin", "it-IT_cm0_sg.bin" };
++const char * picoInternalUtppLingware[]     = { "en-US_utpp.bin",   "en-GB_utpp.bin",   "de-DE_utpp.bin",   "es-ES_utpp.bin",   "fr-FR_utpp.bin",   "it-IT_utpp.bin" };
++const int picoNumSupportedVocs              = 6;
++
++/* adapation layer global variables */
++void *          picoMemArea         = NULL;
++pico_System     picoSystem          = NULL;
++pico_Resource   picoTaResource      = NULL;
++pico_Resource   picoSgResource      = NULL;
++pico_Resource   picoUtppResource    = NULL;
++pico_Engine     picoEngine          = NULL;
++pico_Char *     picoTaFileName      = NULL;
++pico_Char *     picoSgFileName      = NULL;
++pico_Char *     picoUtppFileName    = NULL;
++pico_Char *     picoTaResourceName  = NULL;
++pico_Char *     picoSgResourceName  = NULL;
++pico_Char *     picoUtppResourceName = NULL;
++int     picoSynthAbort = 0;
++
++
++int main(int argc, const char *argv[]) {
++    char * wavefile = NULL;
++    char * lang = "en-US";
++    int langIndex = -1, langIndexTmp = -1;
++    char * text;
++    int8_t * buffer;
++    size_t bufferSize = 256;
++    
++    /* Parsing options */
++	poptContext optCon; /* context for parsing command-line options */
++	int opt; /* used for argument parsing */
++
++	struct poptOption optionsTable[] = {
++		{ "wave", 'w', POPT_ARG_STRING, &wavefile, 0,
++		  "Write output to this WAV file (extension SHOULD be .wav)", "filename.wav" },
++		{ "lang", 'l', POPT_ARG_STRING | POPT_ARGFLAG_SHOW_DEFAULT, &lang, 0,
++		  "Language", "lang" },
++		POPT_AUTOHELP
++		POPT_TABLEEND
++	};
++	optCon = poptGetContext(NULL, argc, argv, optionsTable, POPT_CONTEXT_POSIXMEHARDER);
++    poptSetOtherOptionHelp(optCon, "<words>");
++
++    /* Reporting about invalid extra options */
++	while ((opt = poptGetNextOpt(optCon)) != -1) {
++		switch (opt) {
++		default:
++			fprintf(stderr, "Invalid option %s: %s\n", 
++				poptBadOption(optCon, 0), poptStrerror(opt));
++			poptPrintHelp(optCon, stderr, 0);
++			exit(1);
++		}
++	}
++
++    /* Mandatory option: --wave */
++	if(!wavefile) {
++		fprintf(stderr, "Mandatory option: %s\n\n", 
++			"--wave=filename.wav");
++		poptPrintHelp(optCon, stderr, 0);
++		exit(1);
++	}
++	/* option: --lang */
++	for(langIndexTmp =0; langIndexTmp<picoNumSupportedVocs; langIndexTmp++) {
++	    if(!strcmp(picoSupportedLang[langIndexTmp], lang)) {
++	        langIndex = langIndexTmp;
++	        break;
++	    }
++	}
++	if(langIndex == -1) {
++		fprintf(stderr, "Unknown language: %s\nValid languages:\n", 
++			lang);
++	    for(langIndexTmp =0; langIndexTmp<picoNumSupportedVocs; langIndexTmp++) {
++	        fprintf(stderr, "%s\n", picoSupportedLang[langIndexTmp]);
++	    }
++	    lang = "en-US";
++		fprintf(stderr, "\n");
++		poptPrintHelp(optCon, stderr, 0);
++		exit(1);
++	}
++
++	/* Remaining argument is <words> */
++	const char **extra_argv;
++	extra_argv = poptGetArgs(optCon);
++    if(extra_argv) {
++		text = (char *) &(*extra_argv)[0];
++    } else {
++        //TODO: stdin not supported yet.
++		fprintf(stderr, "Missing argument: %s\n\n", 
++			"<words>");
++		poptPrintHelp(optCon, stderr, 0);
++		exit(1);
++    }
++
++    poptFreeContext(optCon);
++    
++    buffer = malloc( bufferSize );
++    
++    int ret, getstatus;
++    pico_Char * inp = NULL;
++    pico_Char * local_text = NULL;
++    short       outbuf[MAX_OUTBUF_SIZE/2];
++    pico_Int16  bytes_sent, bytes_recv, text_remaining, out_data_type;
++    pico_Retstring outMessage;
++    
++    picoSynthAbort = 0;
++
++    picoMemArea = malloc( PICO_MEM_SIZE );
++    if((ret = pico_initialize( picoMemArea, PICO_MEM_SIZE, &picoSystem ))) {
++        pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++        fprintf(stderr, "Cannot initialize pico (%i): %s\n", ret, outMessage);
++        goto terminate;
++    }
++    
++    /* Load the text analysis Lingware resource file.   */
++    picoTaFileName      = (pico_Char *) malloc( PICO_MAX_DATAPATH_NAME_SIZE + PICO_MAX_FILE_NAME_SIZE );
++    strcpy((char *) picoTaFileName,   PICO_LINGWARE_PATH);
++    strcat((char *) picoTaFileName,   (const char *) picoInternalTaLingware[langIndex]);
++    if((ret = pico_loadResource( picoSystem, picoTaFileName, &picoTaResource ))) {
++        pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++        fprintf(stderr, "Cannot load text analysis resource file (%i): %s\n", ret, outMessage);
++        goto unloadTaResource;
++    }
++    
++    /* Load the signal generation Lingware resource file.   */
++    picoSgFileName      = (pico_Char *) malloc( PICO_MAX_DATAPATH_NAME_SIZE + PICO_MAX_FILE_NAME_SIZE );
++    strcpy((char *) picoSgFileName,   PICO_LINGWARE_PATH);
++    strcat((char *) picoSgFileName,   (const char *) picoInternalSgLingware[langIndex]);
++    if((ret = pico_loadResource( picoSystem, picoSgFileName, &picoSgResource ))) {
++        pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++        fprintf(stderr, "Cannot load signal generation Lingware resource file (%i): %s\n", ret, outMessage);
++        goto unloadSgResource;
++    }
++ 
++    /* Load the utpp Lingware resource file if exists - NOTE: this file is optional
++       and is currently not used. Loading is only attempted for future compatibility.
++       If this file is not present the loading will still succeed.                      //
++    picoUtppFileName      = (pico_Char *) malloc( PICO_MAX_DATAPATH_NAME_SIZE + PICO_MAX_FILE_NAME_SIZE );
++    strcpy((char *) picoUtppFileName,   PICO_LINGWARE_PATH);
++    strcat((char *) picoUtppFileName,   (const char *) picoInternalUtppLingware[langIndex]);
++    ret = pico_loadResource( picoSystem, picoUtppFileName, &picoUtppResource );
++    pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++    printf("pico_loadResource: %i: %s\n", ret, outMessage);
++    */
++    
++    /* Get the text analysis resource name.     */
++    picoTaResourceName  = (pico_Char *) malloc( PICO_MAX_RESOURCE_NAME_SIZE );
++    if((ret = pico_getResourceName( picoSystem, picoTaResource, (char *) picoTaResourceName ))) {
++        pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++        fprintf(stderr, "Cannot get the text analysis resource name (%i): %s\n", ret, outMessage);
++        goto unloadUtppResource;
++    }
++
++    /* Get the signal generation resource name. */
++    picoSgResourceName  = (pico_Char *) malloc( PICO_MAX_RESOURCE_NAME_SIZE );
++    if((ret = pico_getResourceName( picoSystem, picoSgResource, (char *) picoSgResourceName ))) {
++        pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++        fprintf(stderr, "Cannot get the signal generation resource name (%i): %s\n", ret, outMessage);
++        goto unloadUtppResource;
++    }
++
++
++    /* Create a voice definition.   */
++    if((ret = pico_createVoiceDefinition( picoSystem, (const pico_Char *) PICO_VOICE_NAME ))) {
++        pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++        fprintf(stderr, "Cannot create voice definition (%i): %s\n", ret, outMessage);
++        goto unloadUtppResource;
++    }
++
++    /* Add the text analysis resource to the voice. */
++    if((ret = pico_addResourceToVoiceDefinition( picoSystem, (const pico_Char *) PICO_VOICE_NAME, picoTaResourceName ))) {
++        pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++        fprintf(stderr, "Cannot add the text analysis resource to the voice (%i): %s\n", ret, outMessage);
++        goto unloadUtppResource;
++    }
++    
++    /* Add the signal generation resource to the voice. */
++    if((ret = pico_addResourceToVoiceDefinition( picoSystem, (const pico_Char *) PICO_VOICE_NAME, picoSgResourceName ))) {
++        pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++        fprintf(stderr, "Cannot add the signal generation resource to the voice (%i): %s\n", ret, outMessage);
++        goto unloadUtppResource;
++    }
++
++    /* Create a new Pico engine. */
++    if((ret = pico_newEngine( picoSystem, (const pico_Char *) PICO_VOICE_NAME, &picoEngine ))) {
++        pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++        fprintf(stderr, "Cannot create a new pico engine (%i): %s\n", ret, outMessage);
++        goto disposeEngine;
++    }
++    
++    local_text = (pico_Char *) text ;
++    text_remaining = strlen((const char *) local_text) + 1;
++
++    inp = (pico_Char *) local_text;
++    
++    size_t bufused = 0;
++    
++    picoos_Common common = (picoos_Common) pico_sysGetCommon(picoSystem);
++
++    picoos_SDFile sdOutFile = NULL;
++
++    picoos_bool done = TRUE;
++    if(TRUE != (done = picoos_sdfOpenOut(common, &sdOutFile,
++        (picoos_char *) wavefile, SAMPLE_FREQ_16KHZ, PICOOS_ENC_LIN)))
++    {
++        fprintf(stderr, "Cannot open output wave file\n");
++        ret = 1;
++        goto disposeEngine;
++    }
++    
++    /* synthesis loop   */
++    while (text_remaining) {
++        /* Feed the text into the engine.   */
++        if((ret = pico_putTextUtf8( picoEngine, inp, text_remaining, &bytes_sent ))) {
++            pico_getSystemStatusMessage(picoSystem, ret, outMessage);
++            fprintf(stderr, "Cannot put Text (%i): %s\n", ret, outMessage);
++            goto disposeEngine;
++        }
++    
++        text_remaining -= bytes_sent;
++        inp += bytes_sent;
++
++        do {
++            if (picoSynthAbort) {
++                goto disposeEngine;
++            }
++            /* Retrieve the samples and add them to the buffer. */
++            getstatus = pico_getData( picoEngine, (void *) outbuf,
++                      MAX_OUTBUF_SIZE, &bytes_recv, &out_data_type );
++            if((getstatus !=PICO_STEP_BUSY) && (getstatus !=PICO_STEP_IDLE)){
++                pico_getSystemStatusMessage(picoSystem, getstatus, outMessage);
++                fprintf(stderr, "Cannot get Data (%i): %s\n", getstatus, outMessage);
++                goto disposeEngine;
++            }
++            if (bytes_recv) {
++                if ((bufused + bytes_recv) <= bufferSize) {
++                    memcpy(buffer+bufused, (int8_t *) outbuf, bytes_recv);
++                    bufused += bytes_recv;
++                } else {
++                    done = picoos_sdfPutSamples(
++                                        sdOutFile,
++                                        bufused / 2,
++                                        (picoos_int16*) (buffer));
++                    bufused = 0;
++                    memcpy(buffer, (int8_t *) outbuf, bytes_recv);
++                    bufused += bytes_recv;
++                }
++            }
++        } while (PICO_STEP_BUSY == getstatus);
++        /* This chunk of synthesis is finished; pass the remaining samples. */
++        if (!picoSynthAbort) {
++                    done = picoos_sdfPutSamples(
++                                        sdOutFile,
++                                        bufused / 2,
++                                        (picoos_int16*) (buffer));
++        }
++        picoSynthAbort = 0;
++    }
++    
++    if(TRUE != (done = picoos_sdfCloseOut(common, &sdOutFile)))
++    {
++        fprintf(stderr, "Cannot close output wave file\n");
++        ret = 1;
++        goto disposeEngine;
++    }
++
++disposeEngine:
++    if (picoEngine) {
++        pico_disposeEngine( picoSystem, &picoEngine );
++        pico_releaseVoiceDefinition( picoSystem, (pico_Char *) PICO_VOICE_NAME );
++        picoEngine = NULL;
++    }
++unloadUtppResource:
++    if (picoUtppResource) {
++        pico_unloadResource( picoSystem, &picoUtppResource );
++        picoUtppResource = NULL;
++    }
++unloadSgResource:
++    if (picoSgResource) {
++        pico_unloadResource( picoSystem, &picoSgResource );
++        picoSgResource = NULL;
++    }
++unloadTaResource:
++    if (picoTaResource) {
++        pico_unloadResource( picoSystem, &picoTaResource );
++        picoTaResource = NULL;
++    }
++terminate:
++    if (picoSystem) {
++        pico_terminate(&picoSystem);
++        picoSystem = NULL;
++    }
++    exit(ret);
++}
++
+diff --git a/pico/configure.in b/pico/configure.in
+index 0afb56d..349eb1d 100644
+--- a/pico/configure.in
++++ b/pico/configure.in
+@@ -14,3 +14,6 @@ AC_CONFIG_FILES([Makefile])
+ AC_OUTPUT
+ 
+ AC_CONFIG_MACRO_DIR([m4])
++
++AC_CHECK_LIB(popt, poptGetContext)
++
+-- 
+1.7.1
+
diff --git a/0004-add-header-files.patch b/0004-add-header-files.patch
new file mode 100644
index 0000000..f057308
--- /dev/null
+++ b/0004-add-header-files.patch
@@ -0,0 +1,59 @@
+From 0866cb3f7cfe4b8bae1edc8d0dbf18c85e9ca74f Mon Sep 17 00:00:00 2001
+From: Mathieu Parent <math.parent at gmail.com>
+Date: Tue, 27 Oct 2009 18:29:45 +0100
+Subject: [PATCH 4/7] add header files
+
+---
+ pico/Makefile.am |   36 ++++++++++++++++++++++++++++++++++++
+ 1 files changed, 36 insertions(+), 0 deletions(-)
+
+diff --git a/pico/Makefile.am b/pico/Makefile.am
+index 0d9472d..9151042 100644
+--- a/pico/Makefile.am
++++ b/pico/Makefile.am
+@@ -34,6 +34,42 @@ libttspico_la_SOURCES = \
+ 	lib/picotrns.c \
+ 	lib/picowa.c
+ 
++libttspico_ladir = $(includedir)
++libttspico_la_HEADERS = \
++    lib/picoacph.h \
++    lib/picoapid.h \
++    lib/picoapi.h \
++    lib/picobase.h \
++    lib/picocep.h \
++    lib/picoctrl.h \
++    lib/picodata.h \
++    lib/picodbg.h \
++    lib/picodefs.h \
++    lib/picodsp.h \
++    lib/picoextapi.h \
++    lib/picofftsg.h \
++    lib/picokdbg.h \
++    lib/picokdt.h \
++    lib/picokfst.h \
++    lib/picoklex.h \
++    lib/picoknow.h \
++    lib/picokpdf.h \
++    lib/picokpr.h \
++    lib/picoktab.h \
++    lib/picoos.h \
++    lib/picopal.h \
++    lib/picopam.h \
++    lib/picopltf.h \
++    lib/picopr.h \
++    lib/picorsrc.h \
++    lib/picosa.h \
++    lib/picosig2.h \
++    lib/picosig.h \
++    lib/picospho.h \
++    lib/picotok.h \
++    lib/picotrns.h \
++    lib/picowa.h
++
+ bin_PROGRAMS = pico2wave
+ pico2wave_SOURCES = \
+ 	bin/pico2wave.c
+-- 
+1.7.1
+
diff --git a/0005-Install-lang-files.patch b/0005-Install-lang-files.patch
new file mode 100644
index 0000000..95344e3
--- /dev/null
+++ b/0005-Install-lang-files.patch
@@ -0,0 +1,32 @@
+From 486b9f924bdf38f5f213feed2631060b44024c11 Mon Sep 17 00:00:00 2001
+From: Mathieu Parent <math.parent at gmail.com>
+Date: Tue, 27 Oct 2009 23:06:46 +0100
+Subject: [PATCH 5/7] Install lang files
+
+---
+ pico/Makefile.am |    9 +++++++++
+ 1 files changed, 9 insertions(+), 0 deletions(-)
+
+diff --git a/pico/Makefile.am b/pico/Makefile.am
+index 9151042..8898050 100644
+--- a/pico/Makefile.am
++++ b/pico/Makefile.am
+@@ -70,6 +70,15 @@ libttspico_la_HEADERS = \
+     lib/picotrns.h \
+     lib/picowa.h
+ 
++picolangdir = $(datadir)/pico/lang
++picolang_DATA = \
++    lang/de-DE*.bin \
++    lang/en-GB*.bin \
++    lang/en-US*.bin \
++    lang/es-ES*.bin \
++    lang/fr-FR*.bin \
++    lang/it-IT*.bin
++
+ bin_PROGRAMS = pico2wave
+ pico2wave_SOURCES = \
+ 	bin/pico2wave.c
+-- 
+1.7.1
+
diff --git a/0006-Set-picolangdir.patch b/0006-Set-picolangdir.patch
new file mode 100644
index 0000000..1ec646d
--- /dev/null
+++ b/0006-Set-picolangdir.patch
@@ -0,0 +1,40 @@
+From 0102d423b79de7af982c8d4619d816f95a9b9278 Mon Sep 17 00:00:00 2001
+From: Mathieu Parent <math.parent at gmail.com>
+Date: Thu, 29 Oct 2009 23:55:19 +0100
+Subject: [PATCH 6/7] Set picolangdir
+
+---
+ pico/Makefile.am     |    2 +-
+ pico/bin/pico2wave.c |    4 ++++
+ 2 files changed, 5 insertions(+), 1 deletions(-)
+
+diff --git a/pico/Makefile.am b/pico/Makefile.am
+index 8898050..a19c42a 100644
+--- a/pico/Makefile.am
++++ b/pico/Makefile.am
+@@ -84,5 +84,5 @@ pico2wave_SOURCES = \
+ 	bin/pico2wave.c
+ pico2wave_LDADD = \
+ 	libttspico.la -lm -lpopt
+-pico2wave_CFLAGS = -Wall -I lib
++pico2wave_CFLAGS = -Wall -Dpicolangdir=\"$(picolangdir)\" -I lib
+ 
+diff --git a/pico/bin/pico2wave.c b/pico/bin/pico2wave.c
+index 0c035a7..ec7ab79 100644
+--- a/pico/bin/pico2wave.c
++++ b/pico/bin/pico2wave.c
+@@ -35,7 +35,11 @@
+ 
+ /* string constants */
+ #define MAX_OUTBUF_SIZE     128
++#ifdef picolangdir
++const char * PICO_LINGWARE_PATH             = picolangdir "/";
++#else
+ const char * PICO_LINGWARE_PATH             = "./lang/";
++#endif
+ const char * PICO_VOICE_NAME                = "PicoVoice";
+ 
+ /* supported voices
+-- 
+1.7.1
+
diff --git a/0008-64bits.patch b/0008-64bits.patch
new file mode 100644
index 0000000..883a42e
--- /dev/null
+++ b/0008-64bits.patch
@@ -0,0 +1,26 @@
+Description: fix execution on 64bit archs
+Bug: http://code.google.com/p/android/issues/detail?id=12224
+Author: Samuel Thibault <sthibault at debian.org>
+
+--- svox/pico/lib/picoapi.c.original	2010-10-25 19:06:57.000000000 +0200
++++ svox/pico/lib/picoapi.c	2010-10-25 19:07:18.000000000 +0200
+@@ -90,7 +90,7 @@
+         status = PICO_ERR_NULLPTR_ACCESS;
+     } else {
+         byte_ptr_t rest_mem;
+-        picoos_uint32 rest_mem_size;
++        picoos_objsize_t rest_mem_size;
+         pico_System sys;
+         picoos_MemoryManager sysMM;
+         picoos_ExceptionManager sysEM;
+--- svox/pico/lib/picosig2.c.original	2010-10-26 00:17:18.000000000 +0200
++++ svox/pico/lib/picosig2.c	2010-10-26 00:17:19.000000000 +0200
+@@ -568,7 +568,7 @@
+     for (nI = 1; nI < m1; nI++) {
+         XXr[nI] = c1[nI] << shift;
+     }
+-    i = sizeof(picoos_int32) * (PICODSP_FFTSIZE + 1 - m1);
++    i = sizeof(picoos_int32) * (PICODSP_FFTSIZE - m1);
+     picoos_mem_set(XXr + m1, 0, i);
+     dfct_nmf(m4, XXr); /* DFCT directly in fixed point */
+ 
diff --git a/svox-link.patch b/svox-link.patch
new file mode 100644
index 0000000..f2958d5
--- /dev/null
+++ b/svox-link.patch
@@ -0,0 +1,10 @@
+--- svox-1.0+git20110131/pico/Makefile.am.orig	2013-03-02 18:42:05.685584071 +0100
++++ svox-1.0+git20110131/pico/Makefile.am	2013-03-02 18:52:46.005557199 +0100
+@@ -3,6 +3,7 @@
+ ACLOCAL_AMFLAGS = -I m4
+ 
+ lib_LTLIBRARIES = libttspico.la
++libttspico_la_LIBADD = -lm
+ libttspico_la_SOURCES = \
+ 	lib/picoacph.c \
+ 	lib/picoapi.c \
================================================================

---- gitweb:

http://git.pld-linux.org/gitweb.cgi/packages/svox.git/commitdiff/f4a1d095740b66e857273daeff9430ff2c62f578



More information about the pld-cvs-commit mailing list