mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-25 14:06:27 +00:00 
			
		
		
		
	Merged revisions 79334 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r79334 | file | 2007-08-13 18:57:20 -0300 (Mon, 13 Aug 2007) | 2 lines Instead of accepting a single DTMF character accept a full string. ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@79335 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		| @@ -662,7 +662,6 @@ static int speech_background(struct ast_channel *chan, void *data) | |||||||
| 			/* Free the frame we received */ | 			/* Free the frame we received */ | ||||||
| 			switch (f->frametype) { | 			switch (f->frametype) { | ||||||
| 			case AST_FRAME_DTMF: | 			case AST_FRAME_DTMF: | ||||||
| 				ast_speech_dtmf(speech, f->subclass); |  | ||||||
| 				if (dtmf_terminator != '\0' && f->subclass == dtmf_terminator) { | 				if (dtmf_terminator != '\0' && f->subclass == dtmf_terminator) { | ||||||
| 					done = 1; | 					done = 1; | ||||||
| 				} else { | 				} else { | ||||||
| @@ -702,6 +701,7 @@ static int speech_background(struct ast_channel *chan, void *data) | |||||||
| 		/* We sort of make a results entry */ | 		/* We sort of make a results entry */ | ||||||
| 		speech->results = ast_calloc(1, sizeof(*speech->results)); | 		speech->results = ast_calloc(1, sizeof(*speech->results)); | ||||||
| 		if (speech->results != NULL) { | 		if (speech->results != NULL) { | ||||||
|  | 			ast_speech_dtmf(speech, dtmf); | ||||||
| 			speech->results->score = 1000; | 			speech->results->score = 1000; | ||||||
| 			speech->results->text = ast_strdup(dtmf); | 			speech->results->text = ast_strdup(dtmf); | ||||||
| 			speech->results->grammar = ast_strdup("dtmf"); | 			speech->results->grammar = ast_strdup("dtmf"); | ||||||
|   | |||||||
| @@ -88,7 +88,7 @@ struct ast_speech_engine { | |||||||
| 	/*! Write audio to the speech engine */ | 	/*! Write audio to the speech engine */ | ||||||
| 	int (*write)(struct ast_speech *speech, void *data, int len); | 	int (*write)(struct ast_speech *speech, void *data, int len); | ||||||
| 	/*! Signal DTMF was received */ | 	/*! Signal DTMF was received */ | ||||||
| 	int (*dtmf)(struct ast_speech *speech, char dtmf); | 	int (*dtmf)(struct ast_speech *speech, const char *dtmf); | ||||||
| 	/*! Prepare engine to accept audio */ | 	/*! Prepare engine to accept audio */ | ||||||
| 	int (*start)(struct ast_speech *speech); | 	int (*start)(struct ast_speech *speech); | ||||||
| 	/*! Change an engine specific setting */ | 	/*! Change an engine specific setting */ | ||||||
| @@ -137,7 +137,7 @@ int ast_speech_destroy(struct ast_speech *speech); | |||||||
| /*! \brief Write audio to the speech engine */ | /*! \brief Write audio to the speech engine */ | ||||||
| int ast_speech_write(struct ast_speech *speech, void *data, int len); | int ast_speech_write(struct ast_speech *speech, void *data, int len); | ||||||
| /*! \brief Signal to the engine that DTMF was received */ | /*! \brief Signal to the engine that DTMF was received */ | ||||||
| int ast_speech_dtmf(struct ast_speech *speech, char dtmf); | int ast_speech_dtmf(struct ast_speech *speech, const char *dtmf); | ||||||
| /*! \brief Change an engine specific attribute */ | /*! \brief Change an engine specific attribute */ | ||||||
| int ast_speech_change(struct ast_speech *speech, char *name, const char *value); | int ast_speech_change(struct ast_speech *speech, char *name, const char *value); | ||||||
| /*! \brief Change the type of results we want */ | /*! \brief Change the type of results we want */ | ||||||
|   | |||||||
| @@ -154,7 +154,7 @@ int ast_speech_write(struct ast_speech *speech, void *data, int len) | |||||||
| } | } | ||||||
|  |  | ||||||
| /*! \brief Signal to the engine that DTMF was received */ | /*! \brief Signal to the engine that DTMF was received */ | ||||||
| int ast_speech_dtmf(struct ast_speech *speech, char dtmf) | int ast_speech_dtmf(struct ast_speech *speech, const char *dtmf) | ||||||
| { | { | ||||||
| 	int res = 0; | 	int res = 0; | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user