96 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Factor
		
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Factor
		
	
	
! Copyright (C) 2007 Adam Wendt.
 | 
						|
! See http://factorcode.org/license.txt for BSD license.
 | 
						|
USING: alien alien.c-types byte-arrays io io.binary io.files kernel mad
 | 
						|
    namespaces prettyprint sbufs sequences tools.interpreter vars
 | 
						|
    io.encodings.binary ;
 | 
						|
IN: mad.api
 | 
						|
 | 
						|
VARS: buffer-start buffer-length output-callback-var ;
 | 
						|
 | 
						|
: create-mad-callback-generic ( sequence parameters -- alien )
 | 
						|
  swap >r >r "mad_flow" r> "cdecl" r> alien-callback ; inline
 | 
						|
 | 
						|
: create-input-callback ( sequence -- alien )
 | 
						|
  { "void*" "mad_stream*" } create-mad-callback-generic ; inline
 | 
						|
 | 
						|
: create-header-callback ( sequence -- alien )
 | 
						|
  { "void*" "mad_header*" } create-mad-callback-generic ; inline
 | 
						|
 | 
						|
: create-filter-callback ( sequence -- alien )
 | 
						|
  { "void*" "mad_stream*" "mad_frame*" } create-mad-callback-generic ; inline
 | 
						|
 | 
						|
: create-output-callback ( sequence -- alien )
 | 
						|
  { "void*" "mad_header*" "mad_pcm*" } create-mad-callback-generic ; inline
 | 
						|
 | 
						|
: create-error-callback ( sequence -- alien )
 | 
						|
  { "void*" "mad_stream*" "mad_frame*" } create-mad-callback-generic ; inline
 | 
						|
 | 
						|
: create-message-callback ( sequence -- alien )
 | 
						|
  { "void*" "void*" "uint*" } create-mad-callback-generic ; inline
 | 
						|
 | 
						|
: input ( buffer mad_stream -- mad_flow )
 | 
						|
  "input" print flush
 | 
						|
  nip                       ! mad_stream
 | 
						|
  buffer-start get          ! mad_stream start
 | 
						|
  buffer-length get         ! mad_stream start length
 | 
						|
  dup 0 =                   ! mad-stream start length bool
 | 
						|
  [ 3drop MAD_FLOW_STOP ]   ! mad_flow
 | 
						|
  [ mad_stream_buffer       ! 
 | 
						|
  0 buffer-length set       ! 
 | 
						|
  MAD_FLOW_CONTINUE ] if ;  ! mad_flow
 | 
						|
 | 
						|
: input-callback ( -- callback )
 | 
						|
  [ input ] create-input-callback ;
 | 
						|
 | 
						|
: header-callback ( -- callback )
 | 
						|
  [ "header" print flush drop drop MAD_FLOW_CONTINUE ] create-header-callback ;
 | 
						|
 | 
						|
: filter-callback ( -- callback )
 | 
						|
  [ "filter" print flush 3drop MAD_FLOW_CONTINUE ] create-filter-callback ;
 | 
						|
 | 
						|
: write-sample ( sample -- )
 | 
						|
  4 >le write ;
 | 
						|
 | 
						|
: output ( data header pcm -- mad_flow )
 | 
						|
  "output" . flush
 | 
						|
  -rot 2drop output-callback-var> call
 | 
						|
  [ MAD_FLOW_CONTINUE ] [ MAD_FLOW_STOP ] if ;
 | 
						|
 | 
						|
: output-stdout ( pcm -- ? )
 | 
						|
  [ mad_pcm-channels ] keep
 | 
						|
  [ mad_pcm-length ] keep swap
 | 
						|
  [
 | 
						|
    [ mad_pcm-sample-right ] 2keep
 | 
						|
    [ mad_pcm-sample-left ] 2keep
 | 
						|
    drop -rot write-sample pick
 | 
						|
    2 = [ write-sample ] [ drop ] if
 | 
						|
  ] each drop t ;
 | 
						|
 | 
						|
: output-callback ( -- callback )
 | 
						|
  [ output ] create-output-callback ;
 | 
						|
 | 
						|
: error-callback ( -- callback )
 | 
						|
  [ "error" print flush drop drop drop MAD_FLOW_CONTINUE ] create-error-callback ;
 | 
						|
 | 
						|
: message-callback ( -- callback )
 | 
						|
  [ "message" print flush drop drop drop MAD_FLOW_CONTINUE ] create-message-callback ;
 | 
						|
 | 
						|
: mad-init ( decoder -- )
 | 
						|
  0 <alien> input-callback 0 <alien> 0 <alien> output-callback error-callback message-callback mad_decoder_init ;
 | 
						|
 | 
						|
: make-decoder ( -- decoder )
 | 
						|
  "mad_decoder" malloc-object ;
 | 
						|
 | 
						|
: mad-run ( -- int )
 | 
						|
  make-decoder [ mad-init ] keep MAD_DECODER_MODE_SYNC mad_decoder_run ;
 | 
						|
 | 
						|
: init-vars ( alien length -- )
 | 
						|
  buffer-length set buffer-start set ;
 | 
						|
 | 
						|
: decode-mp3 ( filename -- results )
 | 
						|
  [ malloc-file-contents ] keep file-length init-vars mad-run ;
 | 
						|
 | 
						|
: mad-test ( -- results )
 | 
						|
  [ output-stdout ] >output-callback-var
 | 
						|
  "/home/adam/download/mp3/Misc/wutbf.mp3" decode-mp3 ;
 |