[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 7/7] replace int ssml_mode with SPDDataMode
From: |
Andrei Kholodnyi |
Subject: |
[PATCH 7/7] replace int ssml_mode with SPDDataMode |
Date: |
Sat, 23 Oct 2010 20:57:10 +0200 |
replace internal int ssml_mode with public SPDDataMode enum
moved SPDDataMode declaration from libspeechd.h to speechd_types.h
to make it available for internal modules
---
include/speechd_types.h | 5 +++++
src/api/c/libspeechd.h | 5 -----
src/clients/say/options.c | 2 +-
src/clients/say/options.h | 3 ++-
src/clients/say/say.c | 6 ++++--
src/server/configuration.c | 2 +-
src/server/index_marking.c | 18 +++++++++---------
src/server/index_marking.h | 4 ++--
src/server/set.c | 6 +++---
src/server/set.h | 6 +++---
src/server/speechd.h | 2 +-
11 files changed, 31 insertions(+), 28 deletions(-)
diff --git a/include/speechd_types.h b/include/speechd_types.h
index d44554a..5efd9b9 100644
--- a/include/speechd_types.h
+++ b/include/speechd_types.h
@@ -58,6 +58,11 @@ typedef struct {
char *variant; /* a not-well defined string describing dialect etc. */
} SPDVoice;
+typedef enum{
+ SPD_DATA_TEXT = 0,
+ SPD_DATA_SSML = 1
+} SPDDataMode;
+
typedef enum {
SPD_BEGIN = 1,
SPD_END = 2,
diff --git a/src/api/c/libspeechd.h b/src/api/c/libspeechd.h
index e31ce2f..fe4e217 100644
--- a/src/api/c/libspeechd.h
+++ b/src/api/c/libspeechd.h
@@ -45,11 +45,6 @@ extern "C" {
/* --------------------- Public data types ------------------------ */
typedef enum{
- SPD_DATA_TEXT = 0,
- SPD_DATA_SSML = 1
-}SPDDataMode;
-
-typedef enum{
SPD_IMPORTANT = 1,
SPD_MESSAGE = 2,
SPD_TEXT = 3,
diff --git a/src/clients/say/options.c b/src/clients/say/options.c
index aecfbe5..4159dc6 100644
--- a/src/clients/say/options.c
+++ b/src/clients/say/options.c
@@ -181,7 +181,7 @@ options_parse(int argc, char *argv[])
OPT_SET_STR(priority);
break;
case 'x':
- ssml_mode = 1;
+ ssml_mode = SPD_DATA_SSML;
break;
case 'N':
OPT_SET_STR(application_name);
diff --git a/src/clients/say/options.h b/src/clients/say/options.h
index 80f6f47..2d33ed5 100644
--- a/src/clients/say/options.h
+++ b/src/clients/say/options.h
@@ -22,6 +22,7 @@
*/
#include <getopt.h>
+#include "speechd_types.h"
signed int rate;
signed int pitch;
@@ -34,7 +35,7 @@ char *voice_type;
char *punctuation_mode;
char *priority;
int pipe_mode;
-int ssml_mode;
+SPDDataMode ssml_mode;
int spelling;
int wait_till_end;
int stop_previous;
diff --git a/src/clients/say/say.c b/src/clients/say/say.c
index f2813b6..ee32d30 100644
--- a/src/clients/say/say.c
+++ b/src/clients/say/say.c
@@ -33,7 +33,9 @@
#include <semaphore.h>
#include <errno.h>
#include <getopt.h>
+
#include "libspeechd.h"
+#include "speechd_types.h"
#include "options.h"
@@ -64,7 +66,7 @@ int main(int argc, char **argv) {
voice_type = NULL;
punctuation_mode = NULL;
spelling = -2;
- ssml_mode = 0;
+ ssml_mode = SPD_DATA_TEXT;
wait_till_end = 0;
stop_previous = 0;
cancel_previous = 0;
@@ -182,7 +184,7 @@ int main(int argc, char **argv) {
if (spd_set_synthesis_voice(conn, synthesis_voice))
printf("Failed to set synthesis voice!\n");
- if (ssml_mode)
+ if (ssml_mode == SPD_DATA_SSML)
if(spd_execute_command(conn, "SET SELF SSML_MODE ON"))
printf("Failed to set SSML mode.\n");
diff --git a/src/server/configuration.c b/src/server/configuration.c
index 017dfd3..5abafcf 100644
--- a/src/server/configuration.c
+++ b/src/server/configuration.c
@@ -452,7 +452,7 @@ load_default_global_set_options()
GlobalFDSet.cap_let_recogn = SPD_CAP_NONE;
GlobalFDSet.min_delay_progress = 2000;
GlobalFDSet.pause_context = 0;
- GlobalFDSet.ssml_mode = 0;
+ GlobalFDSet.ssml_mode = SPD_DATA_TEXT;
GlobalFDSet.notification = 0;
#ifdef __SUNPRO_C
diff --git a/src/server/index_marking.c b/src/server/index_marking.c
index 584b7bb..94e17b0 100644
--- a/src/server/index_marking.c
+++ b/src/server/index_marking.c
@@ -30,7 +30,7 @@
#include "index_marking.h"
void
-insert_index_marks(TSpeechDMessage *msg, int ssml_mode)
+insert_index_marks(TSpeechDMessage *msg, SPDDataMode ssml_mode)
{
GString *marked_text;
char* pos;
@@ -48,7 +48,7 @@ insert_index_marks(TSpeechDMessage *msg, int ssml_mode)
MSG2(5, "index_marking", "MSG before index marking: |%s|, ssml_mode=%d",
msg->buf, ssml_mode);
- if (!ssml_mode) g_string_printf(marked_text, "<speak>");
+ if (ssml_mode == SPD_DATA_TEXT) g_string_printf(marked_text, "<speak>");
pos = msg->buf;
while(pos){
@@ -57,21 +57,21 @@ insert_index_marks(TSpeechDMessage *msg, int ssml_mode)
u_char = g_utf8_get_char(character);
if (u_char == '<'){
- if (ssml_mode){
+ if (ssml_mode == SPD_DATA_SSML){
inside_tag = 1;
g_string_append_printf(marked_text, "%s", character);
}
else g_string_append_printf(marked_text, "<");
}
else if (u_char == '>'){
- if (ssml_mode){
+ if (ssml_mode == SPD_DATA_SSML){
inside_tag = 0;
g_string_append_printf(marked_text, "%s", character);
}
else g_string_append_printf(marked_text, ">");
}
else if (u_char == '&'){
- if (ssml_mode){
+ if (ssml_mode == SPD_DATA_SSML){
g_string_append_printf(marked_text, "%s", character);
}
else{
@@ -105,7 +105,7 @@ insert_index_marks(TSpeechDMessage *msg, int ssml_mode)
pos = g_utf8_find_next_char(pos, NULL);
}
- if (!ssml_mode) g_string_append_printf(marked_text, "</speak>");
+ if (ssml_mode == SPD_DATA_TEXT) g_string_append_printf(marked_text,
"</speak>");
g_free(msg->buf);
msg->buf = marked_text->str;
@@ -140,7 +140,7 @@ find_index_mark(TSpeechDMessage *msg, int mark)
/* Deletes all index marks from the given text */
char*
-strip_index_marks(char *buf, int ssml_mode)
+strip_index_marks(char *buf, SPDDataMode ssml_mode)
{
GString *str;
char *strret;
@@ -150,7 +150,7 @@ strip_index_marks(char *buf, int ssml_mode)
char *p;
char *p_old;
- if (ssml_mode)
+ if (ssml_mode = SPD_DATA_SSML)
str = g_string_new("<speak>");
else
str = g_string_new("");
@@ -175,7 +175,7 @@ strip_index_marks(char *buf, int ssml_mode)
if (*p == '>') p++;
}
- if (!ssml_mode){
+ if (ssml_mode == SPD_DATA_TEXT){
p = strstr(str->str, "</speak>");
if (p != NULL) *p = 0;
}
diff --git a/src/server/index_marking.h b/src/server/index_marking.h
index 8033209..d670a1e 100644
--- a/src/server/index_marking.h
+++ b/src/server/index_marking.h
@@ -33,7 +33,7 @@
#define SD_MARK_TAIL "\"/>"
/* Insert index marks into a message. */
-void insert_index_marks(TSpeechDMessage *msg, int ssml_mode);
+void insert_index_marks(TSpeechDMessage *msg, SPDDataMode ssml_mode);
/* Find the index mark specified as _mark_ and return the
rest of the text after that index mark. */
@@ -41,6 +41,6 @@ char* find_index_mark(TSpeechDMessage *msg, int mark);
/* Delete all index marks from _buf_ and return a newly
allocated string. */
-char* strip_index_marks(char *buf, int ssml_mode);
+char* strip_index_marks(char *buf, SPDDataMode ssml_mode);
#endif /* INDEX_MARKING_H */
diff --git a/src/server/set.c b/src/server/set.c
index b114597..3bf0672 100644
--- a/src/server/set.c
+++ b/src/server/set.c
@@ -357,17 +357,17 @@ set_pause_context_uid(int uid, int pause_context)
return 0;
}
-SET_SELF_ALL(int, ssml_mode)
+SET_SELF_ALL(SPDDataMode, ssml_mode)
int
-set_ssml_mode_uid(int uid, int ssml_mode)
+set_ssml_mode_uid(int uid, SPDDataMode ssml_mode)
{
TFDSetElement *settings;
settings = get_client_settings_by_uid(uid);
if (settings == NULL) return 1;
- set_param_int(&settings->ssml_mode, ssml_mode);
+ settings->ssml_mode = ssml_mode;
return 0;
}
diff --git a/src/server/set.h b/src/server/set.h
index e125eec..e93aa1a 100644
--- a/src/server/set.h
+++ b/src/server/set.h
@@ -47,7 +47,7 @@ int set_synthesis_voice_uid(int uid, char *synthesis_voice);
int set_punctuation_mode_uid(int uid, SPDPunctuation punctuation);
int set_capital_letter_recognition_uid(int uid, SPDCapitalLetters recogn);
int set_output_module_uid(int uid, char* output_module);
-int set_ssml_mode_uid(int uid, int ssml_mode);
+int set_ssml_mode_uid(int uid, SPDDataMode ssml_mode);
int set_pause_context_uid(int uid, int pause_context);
int set_debug_uid(int uid, int debug);
int set_debug_destination_uid(int uid, char *debug_destination);
@@ -67,7 +67,7 @@ int set_voice_self(int fd, char *voice);
int set_synthesis_voice_self(int fd, char *synthesis_voice);
int set_punctuation_mode_self(int fd, SPDPunctuation punctuation);
int set_capital_letter_recognition_self(int fd, SPDCapitalLetters recogn);
-int set_ssml_mode_self(int fd, int ssml_mode);
+int set_ssml_mode_self(int fd, SPDDataMode ssml_mode);
int set_notification_self(int fd, char *type, int val);
int set_pause_context_self(int fd, int pause_context);
int set_debug_self(int fd, int debug);
@@ -86,7 +86,7 @@ int set_voice_all(char *voice);
int set_synthesis_voice_all(char *synthesis_voice);
int set_punctuation_mode_all(SPDPunctuation punctuation);
int set_capital_letter_recognition_all(SPDCapitalLetters recogn);
-int set_ssml_mode_all(int ssml_mode);
+int set_ssml_mode_all(SPDDataMode ssml_mode);
int set_pause_context_all(int pause_context);
int set_debug_all(int debug);
int set_debug_destination_all(char *debug_destination);
diff --git a/src/server/speechd.h b/src/server/speechd.h
index 1142f55..c1fbc83 100644
--- a/src/server/speechd.h
+++ b/src/server/speechd.h
@@ -79,7 +79,7 @@ typedef struct{
int paused; /* Internal flag, 1 for paused client or 0 for
normal. */
int paused_while_speaking;
EMessageType type; /* Type of the message (1=text, 2=icon,
3=char, 4=key) */
- int ssml_mode; /* SSML mode on (1)/off (0) */
+ SPDDataMode ssml_mode; /* SSML mode on (1)/off (0) */
int priority; /* Priority between 1 and 3 (1 - highest, 3 -
lowest) */
signed int rate; /* Speed of voice from <-100;+100>, 0 is the
default */
signed int pitch; /* Pitch of voice from <-100;+100>, 0 is the
default */
--
1.6.0.4
[PATCH 1/7] replace EPunctMode with SPDPunctuation, William Hubbs, 2010/10/25