ref: f6a42c50c040196f3f830d3e51d405d5ae2b8982
dir: /src/st.h/
#ifndef ST_H #define ST_H /* * July 5, 1991 * Copyright 1991 Lance Norskog And Sundry Contributors * This source code is freely redistributable and may be used for * any purpose. This copyright notice must be maintained. * Lance Norskog And Sundry Contributors are not responsible for * the consequences of using this software. */ #ifdef VAXC #define IMPORT globalref #define EXPORT globaldef /* * use the VAX C optimized functions */ #define calloc VAXC$CALLOC_OPT #define cfree VAXC$CFREE_OPT #define free VAXC$FREE_OPT #define malloc VAXC$MALLOC_OPT #define realloc VAXC$REALLOC_OPT #else #define IMPORT extern #define EXPORT #endif /* * Sound Tools sources header file. */ #include <stdio.h> #ifdef __alpha__ #include <sys/types.h> /* To get defines for 32-bit integers */ #define LONG int32_t #define ULONG u_int32_t #else #define LONG long #define ULONG unsigned long #endif #ifdef AMIGA #include "amiga.h" #endif /* AMIGA */ /* * Handler structure for each format. */ typedef struct format { char **names; /* file type names */ int flags; /* details about file type */ void (*startread)(); LONG (*read)(); void (*stopread)(); void (*startwrite)(); void (*write)(); void (*stopwrite)(); } format_t; IMPORT format_t formats[]; /* Signal parameters */ struct signalinfo { LONG rate; /* sampling rate */ int size; /* word length of data */ int style; /* format of sample numbers */ int channels; /* number of sound channels */ }; /* Loop parameters */ struct loopinfo { int start; /* first sample */ int length; /* length */ int count; /* number of repeats, 0=forever */ int type; /* 0=no, 1=forward, 2=forward/back */ }; /* Instrument parameters */ /* vague attempt at generic information for sampler-specific info */ struct instrinfo { char MIDInote; /* for unity pitch playback */ char MIDIlow, MIDIhi;/* MIDI pitch-bend range */ char loopmode; /* semantics of loop data */ char nloops; /* number of active loops */ unsigned char smpte[4]; /* SMPTE offset (hour:min:sec:frame) */ /* this is a film audio thing */ }; #define MIDI_UNITY 60 /* MIDI note number to play sample at unity */ /* Loop modes, upper 4 bits mask the loop blass, lower 4 bits describe */ /* the loop behaviour, ie. single shot, bidirectional etc. */ #define LOOP_NONE 0 #define LOOP_8 32 /* 8 loops: don't know ?? */ #define LOOP_SUSTAIN_DECAY 64 /* AIFF style: one sustain & one decay loop */ /* * Format information for input and output files. */ #define PRIVSIZE 330 #define NLOOPS 8 struct soundstream { struct signalinfo info; /* signal specifications */ struct instrinfo instr; /* instrument specification */ struct loopinfo loops[NLOOPS]; /* Looping specification */ char swap; /* do byte- or word-swap */ char seekable; /* can seek on this file */ char *filename; /* file name */ char *filetype; /* type of file */ char *comment; /* comment string */ FILE *fp; /* File stream pointer */ format_t *h; /* format struct for this file */ double priv[PRIVSIZE/8]; /* format's private data area */ }; IMPORT struct soundstream informat, outformat; typedef struct soundstream *ft_t; /* flags field */ #define FILE_STEREO 1 /* does file format support stereo? */ #define FILE_LOOPS 2 /* does file format support loops? */ #define FILE_INSTR 4 /* does file format support instrument specificications? */ /* Size field */ #define BYTE 1 #define WORD 2 #define DWORD 4 #define FLOAT 5 #define DOUBLE 6 #define IEEE 7 /* IEEE 80-bit floats. Is it necessary? */ /* Style field */ #define UNSIGNED 1 /* unsigned linear: Sound Blaster */ #define SIGN2 2 /* signed linear 2's comp: Mac */ #define ULAW 3 /* U-law signed logs: US telephony, SPARC */ #define ALAW 4 /* A-law signed logs: non-US telephony */ #define ADPCM 5 /* Compressed PCM */ #define GSM 6 /* GSM 6.10 33-byte frame lossy compression */ IMPORT char *sizes[], *styles[]; /* * Handler structure for each effect. */ typedef struct { char *name; /* effect name */ int flags; /* this and that */ void (*getopts)(); /* process arguments */ void (*start)(); /* start off effect */ void (*flow)(); /* do a buffer */ void (*drain)(); /* drain out at end */ void (*stop)(); /* finish up effect */ } effect_t; IMPORT effect_t effects[]; #define EFF_CHAN 1 /* Effect can mix channels up/down */ #define EFF_RATE 2 /* Effect can alter data rate */ #define EFF_MCHAN 4 /* Effect can handle multi-channel */ #define EFF_REPORT 8 /* Effect does nothing */ struct effect { char *name; /* effect name */ struct signalinfo ininfo; /* input signal specifications */ struct loopinfo loops[8]; /* input loops specifications */ struct instrinfo instr; /* input instrument specifications */ struct signalinfo outinfo; /* output signal specifications */ effect_t *h; /* effects driver */ LONG *obuf; /* output buffer */ LONG odone, olen; /* consumed, total length */ double priv[PRIVSIZE]; /* private area for effect */ }; typedef struct effect *eff_t; #if defined(__STDC__) #define P1(a) a #define P2(a,b) a, b #define P3(a,b,c) a, b, c #define P4(a,b,c,d) a, b, c, d #define P5(a,b,c,d,e) a, b, c, d, e #define P6(a,b,c,d,e,f) a, b, c, d, e, f #define P7(a,b,c,d,e,f,g) a, b, c, d, e, f, g #define P8(a,b,c,d,e,f,g,h) a, b, c, d, e, f, g, h #define P9(a,b,c,d,e,f,g,h,i) a, b, c, d, e, f, g, h, i #define P10(a,b,c,d,e,f,g,h,i,j) a, b, c, d, e, f, g, h, i, j #else #define P1(a) #define P2(a,b) #define P3(a,b,c) #define P4(a,b,c,d) #define P5(a,b,c,d,e) #define P6(a,b,c,d,e,f) #define P7(a,b,c,d,e,f,g) #define P8(a,b,c,d,e,f,g,h) #define P9(a,b,c,d,e,f,g,h,i) #define P10(a,b,c,d,e,f,g,h,i,j) #endif /* Utilities to read and write shorts and longs little-endian and big-endian */ unsigned short rlshort(P1(ft_t ft)); /* short little-end */ unsigned short rbshort(P1(ft_t ft)); /* short big-end */ unsigned short wlshort(P2(ft_t ft, unsigned short us)); /* short little-end */ unsigned short wbshort(P2(ft_t ft, unsigned short us)); /* short big-end */ ULONG rllong(P1(ft_t ft)); /* long little-end */ ULONG rblong(P1(ft_t ft)); /* long big-end */ ULONG wllong(P2(ft_t ft, ULONG ul)); /* long little-end */ ULONG wblong(P2(ft_t ft, ULONG ul)); /* long big-end */ /* Read and write words and longs in "machine format". Swap if indicated. */ unsigned short rshort(P1(ft_t ft)); unsigned short wshort(P2(ft_t ft, unsigned short us)); ULONG rlong(P1(ft_t ft)); ULONG wlong(P2(ft_t ft, ULONG ul)); float rfloat(P1(ft_t ft)); void wfloat(P2(ft_t ft, double f)); double rdouble(P1(ft_t ft)); void wdouble(P2(ft_t ft, double d)); /* Utilities to byte-swap values */ unsigned short swapw(P1(unsigned short us)); /* Swap short */ ULONG swapl(P1(ULONG ul)); /* Swap long */ float swapf(P1(float f)); /* Swap float */ double swapd(P1(double d)); /* Swap double */ IMPORT void report(P2(char *, ...)), warn(P2(char *, ...)), fail(P2(char *, ...)); /* util.c */ IMPORT void geteffect(P1(eff_t)); IMPORT void gettype(P1(ft_t)); IMPORT void checkformat(P1(ft_t)); IMPORT void copyformat(P2(ft_t, ft_t)); IMPORT void cmpformats(P2(ft_t, ft_t)); typedef unsigned int u_i; typedef ULONG u_l; typedef unsigned short u_s; IMPORT float volume; /* expansion coefficient */ IMPORT int dovolume; IMPORT float amplitude; /* Largest sample so far */ IMPORT int writing; /* are we writing to a file? */ /* export flags */ IMPORT int verbose; /* be noisy on stderr */ IMPORT int summary; /* just print summary of information */ IMPORT char *myname; IMPORT int soxpreview; /* Preview mode: be fast and ugly */ #define MAXRATE 50L * 1024 /* maximum sample rate */ #define RIGHT(datum, bits) ((datum) >> bits) #define LEFT(datum, bits) ((datum) << bits) #ifndef M_PI #define M_PI 3.14159265358979323846 #endif #ifdef VMS #define READBINARY "r", "mbf=16", "ctx=stm" #define WRITEBINARY "w", "ctx=stm" #else #define READBINARY "rb" #define WRITEBINARY "wb" #endif #define REMOVE unlink char *version(); /* return version number */ #endif