view src/mediastreamer/mstruespeechencoder.c @ 12626:6a2e376b0a34

[gaim-migrate @ 14962] let the world know committer: Tailor Script <tailor@pidgin.im>
author Christopher O'Brien <siege@pidgin.im>
date Thu, 22 Dec 2005 17:38:38 +0000
parents e67993da8a22
children
line wrap: on
line source

/*
  Copyright 2003 Robert W. Brewer <rbrewer at op.net>
  
  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Lesser General Public
  License as published by the Free Software Foundation; either
  version 2.1 of the License, or (at your option) any later version.

  This library is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  Lesser General Public License for more details.

  You should have received a copy of the GNU Lesser General Public
  License along with this library; if not, write to the Free Software
  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*/


#include "mstruespeechencoder.h"
#include "mscodec.h"

#define TRUESPEECH_CBSIZE 32

extern MSCodecInfo TrueSpeechinfo;

static MSTrueSpeechEncoderClass *ms_truespeechencoder_class = 0;

/* FOR INTERNAL USE*/
void ms_truespeechencoder_init(MSTrueSpeechEncoder *r);
void ms_truespeechencoder_class_init(MSTrueSpeechEncoderClass *klass);
void ms_truespeechencoder_destroy(MSTrueSpeechEncoder *obj);
void ms_truespeechencoder_process(MSTrueSpeechEncoder *r);

MSFilter * ms_truespeechencoder_new(void)
{
  MSTrueSpeechEncoder *r = 0;

  if (!ms_truespeechencoder_class)
  {
    ms_truespeechencoder_class = g_new(MSTrueSpeechEncoderClass, 1);
    ms_truespeechencoder_class_init(ms_truespeechencoder_class);
  }
	
  r = g_new(MSTrueSpeechEncoder, 1);
  MS_FILTER(r)->klass = MS_FILTER_CLASS(ms_truespeechencoder_class);
  ms_truespeechencoder_init(r);
  return MS_FILTER(r);
}
	

/* FOR INTERNAL USE*/
void ms_truespeechencoder_init(MSTrueSpeechEncoder *r)
{
  ms_filter_init(MS_FILTER(r));
  MS_FILTER(r)->infifos  = r->f_inputs;
  MS_FILTER(r)->outfifos = r->f_outputs;

  WAVEFORMATEX* wf = ms_truespeechencoder_wf_create();
        
  r->codec = win32codec_create(wf, 1);
  free(wf);
                                     
  MS_FILTER(r)->r_mingran = r->codec->min_insize;

  MS_FILTER_CLASS(ms_truespeechencoder_class)->r_maxgran =
    r->codec->min_insize;
  MS_FILTER_CLASS(ms_truespeechencoder_class)->w_maxgran =
    r->codec->min_outsize;
        
  memset(r->f_inputs,  0, sizeof(MSFifo*) * MS_TRUESPEECH_CODEC_MAX_IN_OUT);
  memset(r->f_outputs, 0, sizeof(MSFifo*) * MS_TRUESPEECH_CODEC_MAX_IN_OUT);
}

void ms_truespeechencoder_class_init(MSTrueSpeechEncoderClass *klass)
{
  ms_filter_class_init(MS_FILTER_CLASS(klass));
  ms_filter_class_set_name(MS_FILTER_CLASS(klass), "TrueSpeechEncoder");
  MS_FILTER_CLASS(klass)->max_finputs  = MS_TRUESPEECH_CODEC_MAX_IN_OUT;
  MS_FILTER_CLASS(klass)->max_foutputs = MS_TRUESPEECH_CODEC_MAX_IN_OUT;
  MS_FILTER_CLASS(klass)->r_maxgran = 0; /* filled in by first instance */
  MS_FILTER_CLASS(klass)->w_maxgran = 0; /* filled in by first instance */
  MS_FILTER_CLASS(klass)->destroy = (MSFilterDestroyFunc)ms_truespeechencoder_destroy;
  MS_FILTER_CLASS(klass)->process = (MSFilterProcessFunc)ms_truespeechencoder_process;
  MS_FILTER_CLASS(klass)->info = MS_FILTER_INFO(&TrueSpeechinfo);
  klass->driver = win32codec_create_driver(TRUESPEECH_DLL,
                                           TRUESPEECH_FORMAT_TAG, 1);
}
	
void ms_truespeechencoder_process(MSTrueSpeechEncoder *r)
{
  MSFifo *fi,*fo;
  int err1;
  void *s,*d;
	
  /* process output fifos, but there is only one for this class of filter*/

  fi = r->f_inputs[0];
  fo = r->f_outputs[0];
  if (fi)
  {
    err1 = ms_fifo_get_read_ptr(fi, r->codec->min_insize, &s);
    if (err1 > 0)
    {
      err1 = ms_fifo_get_write_ptr(fo, r->codec->min_outsize, &d);
      if (d)
      {
        signed long n;
        
        n = win32codec_convert(r->codec,
                           s, r->codec->min_insize,
                           d, r->codec->min_outsize);
      }
    }
		
  }
}



void ms_truespeechencoder_uninit(MSTrueSpeechEncoder *obj)
{
  win32codec_destroy(obj->codec);
}

void ms_truespeechencoder_destroy(MSTrueSpeechEncoder *obj)
{
  ms_truespeechencoder_uninit(obj);
  g_free(obj);
}


WAVEFORMATEX* ms_truespeechencoder_wf_create()
{
  WAVEFORMATEX* ts_wf = 0;
  long* iptr = 0;
  
  ts_wf = malloc(sizeof(WAVEFORMATEX) + TRUESPEECH_CBSIZE);
  if (!ts_wf)
  {
    return 0;
  }
  
  memset(ts_wf, 0, sizeof(*ts_wf) + TRUESPEECH_CBSIZE);
  
  ts_wf->wFormatTag      = TRUESPEECH_FORMAT_TAG;
  ts_wf->nChannels       = 1;
  ts_wf->nSamplesPerSec  = 8000;
  ts_wf->wBitsPerSample  = 1;
  ts_wf->nBlockAlign     = 32;
  ts_wf->nAvgBytesPerSec = 1067;
  ts_wf->cbSize          = TRUESPEECH_CBSIZE;

  /* write extra data needed by TrueSpeech codec found
     from examining a TrueSpeech .wav file header
  */
  iptr = (long*)(ts_wf + 1);
  *iptr = 0x00f00001;

  return ts_wf;
}