mirror of https://github.com/PCSX2/pcsx2.git
3rdparty: Remove Portaudio
This commit is contained in:
parent
f3d51a242d
commit
7f0f153ebd
|
@ -1,48 +0,0 @@
|
||||||
add_library(portaudio
|
|
||||||
src/common/pa_allocation.c
|
|
||||||
src/common/pa_converters.c
|
|
||||||
src/common/pa_cpuload.c
|
|
||||||
src/common/pa_debugprint.c
|
|
||||||
src/common/pa_dither.c
|
|
||||||
src/common/pa_front.c
|
|
||||||
src/common/pa_process.c
|
|
||||||
src/common/pa_ringbuffer.c
|
|
||||||
src/common/pa_stream.c
|
|
||||||
src/common/pa_trace.c
|
|
||||||
src/hostapi/dsound/pa_win_ds.c
|
|
||||||
src/hostapi/dsound/pa_win_ds_dynlink.c
|
|
||||||
src/hostapi/wdmks/pa_win_wdmks.c
|
|
||||||
src/hostapi/wmme/pa_win_wmme.c
|
|
||||||
src/hostapi/wasapi/pa_win_wasapi.c
|
|
||||||
src/os/win/pa_win_coinitialize.c
|
|
||||||
src/os/win/pa_win_hostapis.c
|
|
||||||
src/os/win/pa_win_util.c
|
|
||||||
src/os/win/pa_win_waveformat.c
|
|
||||||
src/os/win/pa_win_wdmks_utils.c
|
|
||||||
src/os/win/pa_x86_plain_converters.c
|
|
||||||
include/pa_asio.h
|
|
||||||
include/pa_jack.h
|
|
||||||
include/pa_linux_alsa.h
|
|
||||||
include/pa_mac_core.h
|
|
||||||
include/pa_win_ds.h
|
|
||||||
include/pa_win_wasapi.h
|
|
||||||
include/pa_win_waveformat.h
|
|
||||||
include/pa_win_wdmks.h
|
|
||||||
include/pa_win_wmme.h
|
|
||||||
include/portaudio.h
|
|
||||||
src/os/win/pa_win_coinitialize.h
|
|
||||||
)
|
|
||||||
target_compile_definitions(portaudio PRIVATE
|
|
||||||
_CRT_SECURE_NO_WARNINGS
|
|
||||||
_CRT_SECURE_NO_DEPRECATE
|
|
||||||
PAWIN_USE_WDMKS_DEVICE_INFO
|
|
||||||
PA_USE_DS=0
|
|
||||||
PA_USE_WASAPI=1
|
|
||||||
PA_USE_WDMKS=1
|
|
||||||
PA_USE_WMME=0
|
|
||||||
PA_USE_ASIO=0
|
|
||||||
$<$<CONFIG:Debug>:PA_ENABLE_DEBUG_OUTPUT>
|
|
||||||
)
|
|
||||||
target_link_libraries(portaudio PRIVATE ksuser.lib)
|
|
||||||
target_include_directories(portaudio PUBLIC include PRIVATE src/common src/os/win)
|
|
||||||
add_library(PkgConfig::PORTAUDIO ALIAS portaudio)
|
|
|
@ -1,239 +0,0 @@
|
||||||
# Doxyfile 1.4.6
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Project related configuration options
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
PROJECT_NAME = PortAudio
|
|
||||||
PROJECT_NUMBER = 2.0
|
|
||||||
OUTPUT_DIRECTORY = ./doc/
|
|
||||||
CREATE_SUBDIRS = NO
|
|
||||||
OUTPUT_LANGUAGE = English
|
|
||||||
USE_WINDOWS_ENCODING = NO
|
|
||||||
BRIEF_MEMBER_DESC = YES
|
|
||||||
REPEAT_BRIEF = YES
|
|
||||||
ABBREVIATE_BRIEF = "The $name class" \
|
|
||||||
"The $name widget" \
|
|
||||||
"The $name file" \
|
|
||||||
is \
|
|
||||||
provides \
|
|
||||||
specifies \
|
|
||||||
contains \
|
|
||||||
represents \
|
|
||||||
a \
|
|
||||||
an \
|
|
||||||
the
|
|
||||||
ALWAYS_DETAILED_SEC = NO
|
|
||||||
INLINE_INHERITED_MEMB = NO
|
|
||||||
FULL_PATH_NAMES = NO
|
|
||||||
STRIP_FROM_PATH =
|
|
||||||
STRIP_FROM_INC_PATH =
|
|
||||||
SHORT_NAMES = NO
|
|
||||||
JAVADOC_AUTOBRIEF = NO
|
|
||||||
MULTILINE_CPP_IS_BRIEF = NO
|
|
||||||
DETAILS_AT_TOP = NO
|
|
||||||
INHERIT_DOCS = YES
|
|
||||||
SEPARATE_MEMBER_PAGES = NO
|
|
||||||
TAB_SIZE = 8
|
|
||||||
ALIASES =
|
|
||||||
OPTIMIZE_OUTPUT_FOR_C = YES
|
|
||||||
OPTIMIZE_OUTPUT_JAVA = NO
|
|
||||||
BUILTIN_STL_SUPPORT = NO
|
|
||||||
DISTRIBUTE_GROUP_DOC = NO
|
|
||||||
SUBGROUPING = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Build related configuration options
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
EXTRACT_ALL = NO
|
|
||||||
EXTRACT_PRIVATE = NO
|
|
||||||
EXTRACT_STATIC = NO
|
|
||||||
EXTRACT_LOCAL_CLASSES = YES
|
|
||||||
EXTRACT_LOCAL_METHODS = NO
|
|
||||||
HIDE_UNDOC_MEMBERS = NO
|
|
||||||
HIDE_UNDOC_CLASSES = NO
|
|
||||||
HIDE_FRIEND_COMPOUNDS = NO
|
|
||||||
HIDE_IN_BODY_DOCS = NO
|
|
||||||
INTERNAL_DOCS = NO
|
|
||||||
CASE_SENSE_NAMES = YES
|
|
||||||
HIDE_SCOPE_NAMES = NO
|
|
||||||
SHOW_INCLUDE_FILES = YES
|
|
||||||
INLINE_INFO = YES
|
|
||||||
SORT_MEMBER_DOCS = YES
|
|
||||||
SORT_BRIEF_DOCS = NO
|
|
||||||
SORT_BY_SCOPE_NAME = NO
|
|
||||||
GENERATE_TODOLIST = NO
|
|
||||||
GENERATE_TESTLIST = NO
|
|
||||||
GENERATE_BUGLIST = NO
|
|
||||||
GENERATE_DEPRECATEDLIST= YES
|
|
||||||
ENABLED_SECTIONS =
|
|
||||||
MAX_INITIALIZER_LINES = 30
|
|
||||||
SHOW_USED_FILES = YES
|
|
||||||
SHOW_DIRECTORIES = YES
|
|
||||||
FILE_VERSION_FILTER =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to warning and progress messages
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
QUIET = NO
|
|
||||||
WARNINGS = YES
|
|
||||||
WARN_IF_UNDOCUMENTED = YES
|
|
||||||
WARN_IF_DOC_ERROR = YES
|
|
||||||
WARN_NO_PARAMDOC = NO
|
|
||||||
WARN_FORMAT = "$file:$line: $text"
|
|
||||||
WARN_LOGFILE =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the input files
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
INPUT = doc/src \
|
|
||||||
include \
|
|
||||||
examples
|
|
||||||
FILE_PATTERNS = *.h \
|
|
||||||
*.c \
|
|
||||||
*.cpp \
|
|
||||||
*.java \
|
|
||||||
*.dox
|
|
||||||
RECURSIVE = YES
|
|
||||||
EXCLUDE = src/hostapi/wasapi/mingw-include
|
|
||||||
EXCLUDE_SYMLINKS = NO
|
|
||||||
EXCLUDE_PATTERNS =
|
|
||||||
EXAMPLE_PATH =
|
|
||||||
EXAMPLE_PATTERNS =
|
|
||||||
EXAMPLE_RECURSIVE = NO
|
|
||||||
IMAGE_PATH = doc/src/images
|
|
||||||
INPUT_FILTER =
|
|
||||||
FILTER_PATTERNS =
|
|
||||||
FILTER_SOURCE_FILES = NO
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to source browsing
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
SOURCE_BROWSER = YES
|
|
||||||
INLINE_SOURCES = NO
|
|
||||||
STRIP_CODE_COMMENTS = YES
|
|
||||||
REFERENCED_BY_RELATION = YES
|
|
||||||
REFERENCES_RELATION = YES
|
|
||||||
USE_HTAGS = NO
|
|
||||||
VERBATIM_HEADERS = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the alphabetical class index
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
ALPHABETICAL_INDEX = NO
|
|
||||||
COLS_IN_ALPHA_INDEX = 5
|
|
||||||
IGNORE_PREFIX =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the HTML output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_HTML = YES
|
|
||||||
HTML_OUTPUT = html
|
|
||||||
HTML_FILE_EXTENSION = .html
|
|
||||||
HTML_HEADER =
|
|
||||||
HTML_FOOTER =
|
|
||||||
HTML_STYLESHEET =
|
|
||||||
HTML_ALIGN_MEMBERS = YES
|
|
||||||
GENERATE_HTMLHELP = NO
|
|
||||||
CHM_FILE =
|
|
||||||
HHC_LOCATION =
|
|
||||||
GENERATE_CHI = NO
|
|
||||||
BINARY_TOC = NO
|
|
||||||
TOC_EXPAND = NO
|
|
||||||
DISABLE_INDEX = NO
|
|
||||||
ENUM_VALUES_PER_LINE = 4
|
|
||||||
GENERATE_TREEVIEW = NO
|
|
||||||
TREEVIEW_WIDTH = 250
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the LaTeX output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_LATEX = NO
|
|
||||||
LATEX_OUTPUT = latex
|
|
||||||
LATEX_CMD_NAME = latex
|
|
||||||
MAKEINDEX_CMD_NAME = makeindex
|
|
||||||
COMPACT_LATEX = NO
|
|
||||||
PAPER_TYPE = a4wide
|
|
||||||
EXTRA_PACKAGES =
|
|
||||||
LATEX_HEADER =
|
|
||||||
PDF_HYPERLINKS = NO
|
|
||||||
USE_PDFLATEX = NO
|
|
||||||
LATEX_BATCHMODE = NO
|
|
||||||
LATEX_HIDE_INDICES = NO
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the RTF output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_RTF = NO
|
|
||||||
RTF_OUTPUT = rtf
|
|
||||||
COMPACT_RTF = NO
|
|
||||||
RTF_HYPERLINKS = NO
|
|
||||||
RTF_STYLESHEET_FILE =
|
|
||||||
RTF_EXTENSIONS_FILE =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the man page output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_MAN = NO
|
|
||||||
MAN_OUTPUT = man
|
|
||||||
MAN_EXTENSION = .3
|
|
||||||
MAN_LINKS = NO
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the XML output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_XML = NO
|
|
||||||
XML_OUTPUT = xml
|
|
||||||
XML_SCHEMA =
|
|
||||||
XML_DTD =
|
|
||||||
XML_PROGRAMLISTING = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options for the AutoGen Definitions output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_AUTOGEN_DEF = NO
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the Perl module output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_PERLMOD = NO
|
|
||||||
PERLMOD_LATEX = NO
|
|
||||||
PERLMOD_PRETTY = YES
|
|
||||||
PERLMOD_MAKEVAR_PREFIX =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration options related to the preprocessor
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
ENABLE_PREPROCESSING = YES
|
|
||||||
MACRO_EXPANSION = NO
|
|
||||||
EXPAND_ONLY_PREDEF = NO
|
|
||||||
SEARCH_INCLUDES = YES
|
|
||||||
INCLUDE_PATH =
|
|
||||||
INCLUDE_FILE_PATTERNS =
|
|
||||||
PREDEFINED =
|
|
||||||
EXPAND_AS_DEFINED =
|
|
||||||
SKIP_FUNCTION_MACROS = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration::additions related to external references
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
TAGFILES =
|
|
||||||
GENERATE_TAGFILE =
|
|
||||||
ALLEXTERNALS = NO
|
|
||||||
EXTERNAL_GROUPS = YES
|
|
||||||
PERL_PATH = /usr/bin/perl
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration options related to the dot tool
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
CLASS_DIAGRAMS = NO
|
|
||||||
HIDE_UNDOC_RELATIONS = NO
|
|
||||||
HAVE_DOT = NO
|
|
||||||
CLASS_GRAPH = YES
|
|
||||||
COLLABORATION_GRAPH = YES
|
|
||||||
GROUP_GRAPHS = YES
|
|
||||||
UML_LOOK = NO
|
|
||||||
TEMPLATE_RELATIONS = YES
|
|
||||||
INCLUDE_GRAPH = YES
|
|
||||||
INCLUDED_BY_GRAPH = YES
|
|
||||||
CALL_GRAPH = NO
|
|
||||||
GRAPHICAL_HIERARCHY = YES
|
|
||||||
DIRECTORY_GRAPH = YES
|
|
||||||
DOT_IMAGE_FORMAT = png
|
|
||||||
DOT_PATH =
|
|
||||||
DOTFILE_DIRS =
|
|
||||||
MAX_DOT_GRAPH_WIDTH = 1024
|
|
||||||
MAX_DOT_GRAPH_HEIGHT = 1024
|
|
||||||
MAX_DOT_GRAPH_DEPTH = 1000
|
|
||||||
DOT_TRANSPARENT = NO
|
|
||||||
DOT_MULTI_TARGETS = NO
|
|
||||||
GENERATE_LEGEND = YES
|
|
||||||
DOT_CLEANUP = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration::additions related to the search engine
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
SEARCHENGINE = NO
|
|
|
@ -1,242 +0,0 @@
|
||||||
# Doxyfile 1.4.6
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Project related configuration options
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
PROJECT_NAME = PortAudio
|
|
||||||
PROJECT_NUMBER = 2.0
|
|
||||||
OUTPUT_DIRECTORY = ./doc/
|
|
||||||
CREATE_SUBDIRS = NO
|
|
||||||
OUTPUT_LANGUAGE = English
|
|
||||||
USE_WINDOWS_ENCODING = NO
|
|
||||||
BRIEF_MEMBER_DESC = YES
|
|
||||||
REPEAT_BRIEF = YES
|
|
||||||
ABBREVIATE_BRIEF = "The $name class" \
|
|
||||||
"The $name widget" \
|
|
||||||
"The $name file" \
|
|
||||||
is \
|
|
||||||
provides \
|
|
||||||
specifies \
|
|
||||||
contains \
|
|
||||||
represents \
|
|
||||||
a \
|
|
||||||
an \
|
|
||||||
the
|
|
||||||
ALWAYS_DETAILED_SEC = NO
|
|
||||||
INLINE_INHERITED_MEMB = NO
|
|
||||||
FULL_PATH_NAMES = NO
|
|
||||||
STRIP_FROM_PATH =
|
|
||||||
STRIP_FROM_INC_PATH =
|
|
||||||
SHORT_NAMES = NO
|
|
||||||
JAVADOC_AUTOBRIEF = NO
|
|
||||||
MULTILINE_CPP_IS_BRIEF = NO
|
|
||||||
DETAILS_AT_TOP = NO
|
|
||||||
INHERIT_DOCS = YES
|
|
||||||
SEPARATE_MEMBER_PAGES = NO
|
|
||||||
TAB_SIZE = 8
|
|
||||||
ALIASES =
|
|
||||||
OPTIMIZE_OUTPUT_FOR_C = YES
|
|
||||||
OPTIMIZE_OUTPUT_JAVA = NO
|
|
||||||
BUILTIN_STL_SUPPORT = NO
|
|
||||||
DISTRIBUTE_GROUP_DOC = NO
|
|
||||||
SUBGROUPING = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Build related configuration options
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
EXTRACT_ALL = YES
|
|
||||||
EXTRACT_PRIVATE = NO
|
|
||||||
EXTRACT_STATIC = NO
|
|
||||||
EXTRACT_LOCAL_CLASSES = YES
|
|
||||||
EXTRACT_LOCAL_METHODS = NO
|
|
||||||
HIDE_UNDOC_MEMBERS = NO
|
|
||||||
HIDE_UNDOC_CLASSES = NO
|
|
||||||
HIDE_FRIEND_COMPOUNDS = NO
|
|
||||||
HIDE_IN_BODY_DOCS = NO
|
|
||||||
INTERNAL_DOCS = YES
|
|
||||||
CASE_SENSE_NAMES = YES
|
|
||||||
HIDE_SCOPE_NAMES = NO
|
|
||||||
SHOW_INCLUDE_FILES = YES
|
|
||||||
INLINE_INFO = YES
|
|
||||||
SORT_MEMBER_DOCS = YES
|
|
||||||
SORT_BRIEF_DOCS = NO
|
|
||||||
SORT_BY_SCOPE_NAME = NO
|
|
||||||
GENERATE_TODOLIST = YES
|
|
||||||
GENERATE_TESTLIST = YES
|
|
||||||
GENERATE_BUGLIST = YES
|
|
||||||
GENERATE_DEPRECATEDLIST= YES
|
|
||||||
ENABLED_SECTIONS = INTERNAL
|
|
||||||
MAX_INITIALIZER_LINES = 30
|
|
||||||
SHOW_USED_FILES = YES
|
|
||||||
SHOW_DIRECTORIES = YES
|
|
||||||
FILE_VERSION_FILTER =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to warning and progress messages
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
QUIET = NO
|
|
||||||
WARNINGS = YES
|
|
||||||
WARN_IF_UNDOCUMENTED = YES
|
|
||||||
WARN_IF_DOC_ERROR = YES
|
|
||||||
WARN_NO_PARAMDOC = NO
|
|
||||||
WARN_FORMAT = "$file:$line: $text"
|
|
||||||
WARN_LOGFILE =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the input files
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
INPUT = doc/src \
|
|
||||||
include \
|
|
||||||
examples \
|
|
||||||
src \
|
|
||||||
test \
|
|
||||||
qa
|
|
||||||
FILE_PATTERNS = *.h \
|
|
||||||
*.c \
|
|
||||||
*.cpp \
|
|
||||||
*.java \
|
|
||||||
*.dox
|
|
||||||
RECURSIVE = YES
|
|
||||||
EXCLUDE = src/hostapi/wasapi/mingw-include
|
|
||||||
EXCLUDE_SYMLINKS = NO
|
|
||||||
EXCLUDE_PATTERNS =
|
|
||||||
EXAMPLE_PATH =
|
|
||||||
EXAMPLE_PATTERNS =
|
|
||||||
EXAMPLE_RECURSIVE = NO
|
|
||||||
IMAGE_PATH = doc/src/images
|
|
||||||
INPUT_FILTER =
|
|
||||||
FILTER_PATTERNS =
|
|
||||||
FILTER_SOURCE_FILES = NO
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to source browsing
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
SOURCE_BROWSER = NO
|
|
||||||
INLINE_SOURCES = NO
|
|
||||||
STRIP_CODE_COMMENTS = YES
|
|
||||||
REFERENCED_BY_RELATION = YES
|
|
||||||
REFERENCES_RELATION = YES
|
|
||||||
USE_HTAGS = NO
|
|
||||||
VERBATIM_HEADERS = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the alphabetical class index
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
ALPHABETICAL_INDEX = NO
|
|
||||||
COLS_IN_ALPHA_INDEX = 5
|
|
||||||
IGNORE_PREFIX =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the HTML output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_HTML = YES
|
|
||||||
HTML_OUTPUT = html
|
|
||||||
HTML_FILE_EXTENSION = .html
|
|
||||||
HTML_HEADER =
|
|
||||||
HTML_FOOTER =
|
|
||||||
HTML_STYLESHEET =
|
|
||||||
HTML_ALIGN_MEMBERS = YES
|
|
||||||
GENERATE_HTMLHELP = NO
|
|
||||||
CHM_FILE =
|
|
||||||
HHC_LOCATION =
|
|
||||||
GENERATE_CHI = NO
|
|
||||||
BINARY_TOC = NO
|
|
||||||
TOC_EXPAND = NO
|
|
||||||
DISABLE_INDEX = NO
|
|
||||||
ENUM_VALUES_PER_LINE = 4
|
|
||||||
GENERATE_TREEVIEW = NO
|
|
||||||
TREEVIEW_WIDTH = 250
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the LaTeX output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_LATEX = NO
|
|
||||||
LATEX_OUTPUT = latex
|
|
||||||
LATEX_CMD_NAME = latex
|
|
||||||
MAKEINDEX_CMD_NAME = makeindex
|
|
||||||
COMPACT_LATEX = NO
|
|
||||||
PAPER_TYPE = a4wide
|
|
||||||
EXTRA_PACKAGES =
|
|
||||||
LATEX_HEADER =
|
|
||||||
PDF_HYPERLINKS = NO
|
|
||||||
USE_PDFLATEX = NO
|
|
||||||
LATEX_BATCHMODE = NO
|
|
||||||
LATEX_HIDE_INDICES = NO
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the RTF output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_RTF = NO
|
|
||||||
RTF_OUTPUT = rtf
|
|
||||||
COMPACT_RTF = NO
|
|
||||||
RTF_HYPERLINKS = NO
|
|
||||||
RTF_STYLESHEET_FILE =
|
|
||||||
RTF_EXTENSIONS_FILE =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the man page output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_MAN = NO
|
|
||||||
MAN_OUTPUT = man
|
|
||||||
MAN_EXTENSION = .3
|
|
||||||
MAN_LINKS = NO
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the XML output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_XML = NO
|
|
||||||
XML_OUTPUT = xml
|
|
||||||
XML_SCHEMA =
|
|
||||||
XML_DTD =
|
|
||||||
XML_PROGRAMLISTING = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options for the AutoGen Definitions output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_AUTOGEN_DEF = NO
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the Perl module output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
GENERATE_PERLMOD = NO
|
|
||||||
PERLMOD_LATEX = NO
|
|
||||||
PERLMOD_PRETTY = YES
|
|
||||||
PERLMOD_MAKEVAR_PREFIX =
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration options related to the preprocessor
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
ENABLE_PREPROCESSING = YES
|
|
||||||
MACRO_EXPANSION = NO
|
|
||||||
EXPAND_ONLY_PREDEF = NO
|
|
||||||
SEARCH_INCLUDES = YES
|
|
||||||
INCLUDE_PATH =
|
|
||||||
INCLUDE_FILE_PATTERNS =
|
|
||||||
PREDEFINED =
|
|
||||||
EXPAND_AS_DEFINED =
|
|
||||||
SKIP_FUNCTION_MACROS = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration::additions related to external references
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
TAGFILES =
|
|
||||||
GENERATE_TAGFILE =
|
|
||||||
ALLEXTERNALS = NO
|
|
||||||
EXTERNAL_GROUPS = YES
|
|
||||||
PERL_PATH = /usr/bin/perl
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration options related to the dot tool
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
CLASS_DIAGRAMS = NO
|
|
||||||
HIDE_UNDOC_RELATIONS = NO
|
|
||||||
HAVE_DOT = NO
|
|
||||||
CLASS_GRAPH = YES
|
|
||||||
COLLABORATION_GRAPH = YES
|
|
||||||
GROUP_GRAPHS = YES
|
|
||||||
UML_LOOK = NO
|
|
||||||
TEMPLATE_RELATIONS = YES
|
|
||||||
INCLUDE_GRAPH = YES
|
|
||||||
INCLUDED_BY_GRAPH = YES
|
|
||||||
CALL_GRAPH = NO
|
|
||||||
GRAPHICAL_HIERARCHY = YES
|
|
||||||
DIRECTORY_GRAPH = YES
|
|
||||||
DOT_IMAGE_FORMAT = png
|
|
||||||
DOT_PATH =
|
|
||||||
DOTFILE_DIRS =
|
|
||||||
MAX_DOT_GRAPH_WIDTH = 1024
|
|
||||||
MAX_DOT_GRAPH_HEIGHT = 1024
|
|
||||||
MAX_DOT_GRAPH_DEPTH = 1000
|
|
||||||
DOT_TRANSPARENT = NO
|
|
||||||
DOT_MULTI_TARGETS = NO
|
|
||||||
GENERATE_LEGEND = YES
|
|
||||||
DOT_CLEANUP = YES
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration::additions related to the search engine
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
SEARCHENGINE = NO
|
|
|
@ -1,81 +0,0 @@
|
||||||
Portable header file to contain:
|
|
||||||
>>>>>
|
|
||||||
/*
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* PortAudio API Header File
|
|
||||||
* Latest version available at: http://www.portaudio.com
|
|
||||||
*
|
|
||||||
* Copyright (c) 1999-2006 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
<<<<<
|
|
||||||
|
|
||||||
|
|
||||||
Implementation files to contain:
|
|
||||||
>>>>>
|
|
||||||
/*
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* Latest version at: http://www.portaudio.com
|
|
||||||
* <platform> Implementation
|
|
||||||
* Copyright (c) 1999-2000 <author(s)>
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
<<<<<
|
|
|
@ -1,257 +0,0 @@
|
||||||
#
|
|
||||||
# PortAudio V19 Makefile.in
|
|
||||||
#
|
|
||||||
# Dominic Mazzoni
|
|
||||||
# Modifications by Mikael Magnusson
|
|
||||||
# Modifications by Stelios Bounanos
|
|
||||||
#
|
|
||||||
|
|
||||||
top_srcdir = @top_srcdir@
|
|
||||||
srcdir = @srcdir@
|
|
||||||
VPATH = @srcdir@
|
|
||||||
top_builddir = .
|
|
||||||
PREFIX = @prefix@
|
|
||||||
prefix = $(PREFIX)
|
|
||||||
exec_prefix = @exec_prefix@
|
|
||||||
bindir = @bindir@
|
|
||||||
libdir = @libdir@
|
|
||||||
includedir = @includedir@
|
|
||||||
CC = @CC@
|
|
||||||
CXX = @CXX@
|
|
||||||
CFLAGS = @CFLAGS@ @DEFS@
|
|
||||||
LIBS = @LIBS@
|
|
||||||
AR = @AR@
|
|
||||||
RANLIB = @RANLIB@
|
|
||||||
SHELL = @SHELL@
|
|
||||||
LIBTOOL = @LIBTOOL@
|
|
||||||
INSTALL = @INSTALL@
|
|
||||||
INSTALL_DATA = @INSTALL_DATA@
|
|
||||||
SHARED_FLAGS = @SHARED_FLAGS@
|
|
||||||
LDFLAGS = @LDFLAGS@
|
|
||||||
DLL_LIBS = @DLL_LIBS@
|
|
||||||
CXXFLAGS = @CXXFLAGS@
|
|
||||||
NASM = @NASM@
|
|
||||||
NASMOPT = @NASMOPT@
|
|
||||||
LN_S = @LN_S@
|
|
||||||
LT_CURRENT=@LT_CURRENT@
|
|
||||||
LT_REVISION=@LT_REVISION@
|
|
||||||
LT_AGE=@LT_AGE@
|
|
||||||
|
|
||||||
OTHER_OBJS = @OTHER_OBJS@
|
|
||||||
INCLUDES = @INCLUDES@
|
|
||||||
|
|
||||||
PALIB = libportaudio.la
|
|
||||||
PAINC = include/portaudio.h
|
|
||||||
|
|
||||||
PA_LDFLAGS = $(LDFLAGS) $(SHARED_FLAGS) -rpath $(libdir) -no-undefined \
|
|
||||||
-export-symbols-regex "(Pa|PaMacCore|PaJack|PaAlsa|PaAsio|PaOSS)_.*" \
|
|
||||||
-version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE)
|
|
||||||
|
|
||||||
COMMON_OBJS = \
|
|
||||||
src/common/pa_allocation.o \
|
|
||||||
src/common/pa_converters.o \
|
|
||||||
src/common/pa_cpuload.o \
|
|
||||||
src/common/pa_dither.o \
|
|
||||||
src/common/pa_debugprint.o \
|
|
||||||
src/common/pa_front.o \
|
|
||||||
src/common/pa_process.o \
|
|
||||||
src/common/pa_stream.o \
|
|
||||||
src/common/pa_trace.o \
|
|
||||||
src/hostapi/skeleton/pa_hostapi_skeleton.o
|
|
||||||
|
|
||||||
LOOPBACK_OBJS = \
|
|
||||||
qa/loopback/src/audio_analyzer.o \
|
|
||||||
qa/loopback/src/biquad_filter.o \
|
|
||||||
qa/loopback/src/paqa_tools.o \
|
|
||||||
qa/loopback/src/test_audio_analyzer.o \
|
|
||||||
qa/loopback/src/write_wav.o \
|
|
||||||
qa/loopback/src/paqa.o
|
|
||||||
|
|
||||||
EXAMPLES = \
|
|
||||||
bin/pa_devs \
|
|
||||||
bin/pa_fuzz \
|
|
||||||
bin/paex_pink \
|
|
||||||
bin/paex_read_write_wire \
|
|
||||||
bin/paex_record \
|
|
||||||
bin/paex_saw \
|
|
||||||
bin/paex_sine \
|
|
||||||
bin/paex_write_sine \
|
|
||||||
bin/paex_write_sine_nonint
|
|
||||||
|
|
||||||
SELFTESTS = \
|
|
||||||
bin/paqa_devs \
|
|
||||||
bin/paqa_errs \
|
|
||||||
bin/paqa_latency
|
|
||||||
|
|
||||||
TESTS = \
|
|
||||||
bin/patest1 \
|
|
||||||
bin/patest_buffer \
|
|
||||||
bin/patest_callbackstop \
|
|
||||||
bin/patest_clip \
|
|
||||||
bin/patest_dither \
|
|
||||||
bin/patest_hang \
|
|
||||||
bin/patest_in_overflow \
|
|
||||||
bin/patest_latency \
|
|
||||||
bin/patest_leftright \
|
|
||||||
bin/patest_longsine \
|
|
||||||
bin/patest_many \
|
|
||||||
bin/patest_maxsines \
|
|
||||||
bin/patest_mono \
|
|
||||||
bin/patest_multi_sine \
|
|
||||||
bin/patest_out_underflow \
|
|
||||||
bin/patest_prime \
|
|
||||||
bin/patest_ringmix \
|
|
||||||
bin/patest_sine8 \
|
|
||||||
bin/patest_sine_channelmaps \
|
|
||||||
bin/patest_sine_formats \
|
|
||||||
bin/patest_sine_time \
|
|
||||||
bin/patest_sine_srate \
|
|
||||||
bin/patest_start_stop \
|
|
||||||
bin/patest_stop \
|
|
||||||
bin/patest_stop_playout \
|
|
||||||
bin/patest_toomanysines \
|
|
||||||
bin/patest_two_rates \
|
|
||||||
bin/patest_underflow \
|
|
||||||
bin/patest_wire \
|
|
||||||
bin/pa_minlat
|
|
||||||
|
|
||||||
# Most of these don't compile yet. Put them in TESTS, above, if
|
|
||||||
# you want to try to compile them...
|
|
||||||
ALL_TESTS = \
|
|
||||||
$(TESTS) \
|
|
||||||
bin/patest_sync \
|
|
||||||
bin/debug_convert \
|
|
||||||
bin/debug_dither_calc \
|
|
||||||
bin/debug_dual \
|
|
||||||
bin/debug_multi_in \
|
|
||||||
bin/debug_multi_out \
|
|
||||||
bin/debug_record \
|
|
||||||
bin/debug_record_reuse \
|
|
||||||
bin/debug_sine_amp \
|
|
||||||
bin/debug_sine \
|
|
||||||
bin/debug_sine_formats \
|
|
||||||
bin/debug_srate \
|
|
||||||
bin/debug_test1
|
|
||||||
|
|
||||||
OBJS := $(COMMON_OBJS) $(OTHER_OBJS)
|
|
||||||
|
|
||||||
LTOBJS := $(OBJS:.o=.lo)
|
|
||||||
|
|
||||||
SRC_DIRS = \
|
|
||||||
src/common \
|
|
||||||
src/hostapi/alsa \
|
|
||||||
src/hostapi/asihpi \
|
|
||||||
src/hostapi/asio \
|
|
||||||
src/hostapi/coreaudio \
|
|
||||||
src/hostapi/dsound \
|
|
||||||
src/hostapi/jack \
|
|
||||||
src/hostapi/oss \
|
|
||||||
src/hostapi/wasapi \
|
|
||||||
src/hostapi/wdmks \
|
|
||||||
src/hostapi/wmme \
|
|
||||||
src/os/unix \
|
|
||||||
src/os/win
|
|
||||||
|
|
||||||
SUBDIRS =
|
|
||||||
@ENABLE_CXX_TRUE@SUBDIRS += bindings/cpp
|
|
||||||
|
|
||||||
all: lib/$(PALIB) all-recursive tests examples selftests
|
|
||||||
|
|
||||||
tests: bin-stamp $(TESTS)
|
|
||||||
|
|
||||||
examples: bin-stamp $(EXAMPLES)
|
|
||||||
|
|
||||||
selftests: bin-stamp $(SELFTESTS)
|
|
||||||
|
|
||||||
loopback: bin-stamp bin/paloopback
|
|
||||||
|
|
||||||
# With ASIO enabled we must link libportaudio and all test programs with CXX
|
|
||||||
lib/$(PALIB): lib-stamp $(LTOBJS) $(MAKEFILE) $(PAINC)
|
|
||||||
@WITH_ASIO_FALSE@ $(LIBTOOL) --mode=link $(CC) $(PA_LDFLAGS) -o lib/$(PALIB) $(LTOBJS) $(DLL_LIBS)
|
|
||||||
@WITH_ASIO_TRUE@ $(LIBTOOL) --mode=link --tag=CXX $(CXX) $(PA_LDFLAGS) -o lib/$(PALIB) $(LTOBJS) $(DLL_LIBS)
|
|
||||||
|
|
||||||
$(ALL_TESTS): bin/%: lib/$(PALIB) $(MAKEFILE) $(PAINC) test/%.c
|
|
||||||
@WITH_ASIO_FALSE@ $(LIBTOOL) --mode=link $(CC) -o $@ $(CFLAGS) $(top_srcdir)/test/$*.c lib/$(PALIB) $(LIBS)
|
|
||||||
@WITH_ASIO_TRUE@ $(LIBTOOL) --mode=link --tag=CXX $(CXX) -o $@ $(CXXFLAGS) $(top_srcdir)/test/$*.c lib/$(PALIB) $(LIBS)
|
|
||||||
|
|
||||||
$(EXAMPLES): bin/%: lib/$(PALIB) $(MAKEFILE) $(PAINC) examples/%.c
|
|
||||||
@WITH_ASIO_FALSE@ $(LIBTOOL) --mode=link $(CC) -o $@ $(CFLAGS) $(top_srcdir)/examples/$*.c lib/$(PALIB) $(LIBS)
|
|
||||||
@WITH_ASIO_TRUE@ $(LIBTOOL) --mode=link --tag=CXX $(CXX) -o $@ $(CXXFLAGS) $(top_srcdir)/examples/$*.c lib/$(PALIB) $(LIBS)
|
|
||||||
|
|
||||||
$(SELFTESTS): bin/%: lib/$(PALIB) $(MAKEFILE) $(PAINC) qa/%.c
|
|
||||||
@WITH_ASIO_FALSE@ $(LIBTOOL) --mode=link $(CC) -o $@ $(CFLAGS) $(top_srcdir)/qa/$*.c lib/$(PALIB) $(LIBS)
|
|
||||||
@WITH_ASIO_TRUE@ $(LIBTOOL) --mode=link --tag=CXX $(CXX) -o $@ $(CXXFLAGS) $(top_srcdir)/qa/$*.c lib/$(PALIB) $(LIBS)
|
|
||||||
|
|
||||||
bin/paloopback: lib/$(PALIB) $(MAKEFILE) $(PAINC) $(LOOPBACK_OBJS)
|
|
||||||
@WITH_ASIO_FALSE@ $(LIBTOOL) --mode=link $(CC) -o $@ $(CFLAGS) $(LOOPBACK_OBJS) lib/$(PALIB) $(LIBS)
|
|
||||||
@WITH_ASIO_TRUE@ $(LIBTOOL) --mode=link --tag=CXX $(CXX) -o $@ $(CXXFLAGS) $(LOOPBACK_OBJS) lib/$(PALIB) $(LIBS)
|
|
||||||
|
|
||||||
install: lib/$(PALIB) portaudio-2.0.pc
|
|
||||||
$(INSTALL) -d $(DESTDIR)$(libdir)
|
|
||||||
$(LIBTOOL) --mode=install $(INSTALL) lib/$(PALIB) $(DESTDIR)$(libdir)
|
|
||||||
$(INSTALL) -d $(DESTDIR)$(includedir)
|
|
||||||
for include in $(INCLUDES); do \
|
|
||||||
$(INSTALL_DATA) -m 644 $(top_srcdir)/include/$$include $(DESTDIR)$(includedir)/$$include; \
|
|
||||||
done
|
|
||||||
$(INSTALL) -d $(DESTDIR)$(libdir)/pkgconfig
|
|
||||||
$(INSTALL) -m 644 portaudio-2.0.pc $(DESTDIR)$(libdir)/pkgconfig/portaudio-2.0.pc
|
|
||||||
@echo ""
|
|
||||||
@echo "------------------------------------------------------------"
|
|
||||||
@echo "PortAudio was successfully installed."
|
|
||||||
@echo ""
|
|
||||||
@echo "On some systems (e.g. Linux) you should run 'ldconfig' now"
|
|
||||||
@echo "to make the shared object available. You may also need to"
|
|
||||||
@echo "modify your LD_LIBRARY_PATH environment variable to include"
|
|
||||||
@echo "the directory $(libdir)"
|
|
||||||
@echo "------------------------------------------------------------"
|
|
||||||
@echo ""
|
|
||||||
$(MAKE) install-recursive
|
|
||||||
|
|
||||||
uninstall:
|
|
||||||
$(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$(PALIB)
|
|
||||||
$(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(includedir)/portaudio.h
|
|
||||||
$(MAKE) uninstall-recursive
|
|
||||||
|
|
||||||
clean:
|
|
||||||
$(LIBTOOL) --mode=clean rm -f $(LTOBJS) $(LOOPBACK_OBJS) $(ALL_TESTS) lib/$(PALIB)
|
|
||||||
$(RM) bin-stamp lib-stamp
|
|
||||||
-$(RM) -r bin lib
|
|
||||||
|
|
||||||
distclean: clean
|
|
||||||
$(RM) config.log config.status Makefile libtool portaudio-2.0.pc
|
|
||||||
|
|
||||||
%.o: %.c $(MAKEFILE) $(PAINC)
|
|
||||||
$(CC) -c $(CFLAGS) $< -o $@
|
|
||||||
|
|
||||||
%.lo: %.c $(MAKEFILE) $(PAINC)
|
|
||||||
$(LIBTOOL) --mode=compile $(CC) -c $(CFLAGS) $< -o $@
|
|
||||||
|
|
||||||
%.lo: %.cpp $(MAKEFILE) $(PAINC)
|
|
||||||
$(LIBTOOL) --mode=compile --tag=CXX $(CXX) -c $(CXXFLAGS) $< -o $@
|
|
||||||
|
|
||||||
%.o: %.cpp $(MAKEFILE) $(PAINC)
|
|
||||||
$(CXX) -c $(CXXFLAGS) $< -o $@
|
|
||||||
|
|
||||||
%.o: %.asm
|
|
||||||
$(NASM) $(NASMOPT) -o $@ $<
|
|
||||||
|
|
||||||
bin-stamp:
|
|
||||||
-mkdir bin
|
|
||||||
touch $@
|
|
||||||
|
|
||||||
lib-stamp:
|
|
||||||
-mkdir lib
|
|
||||||
-mkdir -p $(SRC_DIRS)
|
|
||||||
touch $@
|
|
||||||
|
|
||||||
Makefile: Makefile.in config.status
|
|
||||||
$(SHELL) config.status
|
|
||||||
|
|
||||||
all-recursive:
|
|
||||||
if test -n "$(SUBDIRS)" ; then for dir in "$(SUBDIRS)"; do $(MAKE) -C $$dir all; done ; fi
|
|
||||||
|
|
||||||
install-recursive:
|
|
||||||
if test -n "$(SUBDIRS)" ; then for dir in "$(SUBDIRS)"; do $(MAKE) -C $$dir install; done ; fi
|
|
||||||
|
|
||||||
uninstall-recursive:
|
|
||||||
if test -n "$(SUBDIRS)" ; then for dir in "$(SUBDIRS)"; do $(MAKE) -C $$dir uninstall; done ; fi
|
|
|
@ -1,32 +0,0 @@
|
||||||
PortAudio uses "autoconf" tools to generate Makefiles for Linux and Mac platforms.
|
|
||||||
The source for these are configure.in and Makefile.in
|
|
||||||
If you modify either of these files then please run this command before
|
|
||||||
testing and checking in your changes. I run this command on Linux.
|
|
||||||
|
|
||||||
autoreconf -if
|
|
||||||
|
|
||||||
If you do not have autoreconf then do:
|
|
||||||
sudo apt-get install autoconf
|
|
||||||
|
|
||||||
If you get error like "possibly undefined macro: AC_LIBTOOL_WIN32_DLL"
|
|
||||||
then you try installing some more packages and then try again.
|
|
||||||
|
|
||||||
sudo apt-get install build-essential
|
|
||||||
sudo apt-get install pkg-config
|
|
||||||
sudo apt-get install libtool
|
|
||||||
autoreconf -if
|
|
||||||
|
|
||||||
Then test a build by doing:
|
|
||||||
|
|
||||||
./configure
|
|
||||||
make clean
|
|
||||||
make
|
|
||||||
|
|
||||||
then check in the related files that are modified.
|
|
||||||
These might include files like:
|
|
||||||
|
|
||||||
configure
|
|
||||||
config.guess
|
|
||||||
depcomp
|
|
||||||
install.sh
|
|
||||||
|
|
|
@ -1,98 +0,0 @@
|
||||||
README for PortAudio
|
|
||||||
|
|
||||||
/*
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* Latest Version at: http://www.portaudio.com
|
|
||||||
*
|
|
||||||
* Copyright (c) 1999-2008 Phil Burk and Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
PortAudio is a portable audio I/O library designed for cross-platform
|
|
||||||
support of audio. It uses either a callback mechanism to request audio
|
|
||||||
processing, or blocking read/write calls to buffer data between the
|
|
||||||
native audio subsystem and the client. Audio can be processed in various
|
|
||||||
formats, including 32 bit floating point, and will be converted to the
|
|
||||||
native format internally.
|
|
||||||
|
|
||||||
Documentation:
|
|
||||||
Documentation is available in "/doc/html/index.html"
|
|
||||||
Also see "src/common/portaudio.h" for API spec.
|
|
||||||
Also see http://www.portaudio.com/docs/
|
|
||||||
And see the "test/" directory for many examples of usage
|
|
||||||
(we suggest "test/patest_saw.c" for an example)
|
|
||||||
|
|
||||||
For information on compiling programs with PortAudio, please see the
|
|
||||||
tutorial at:
|
|
||||||
|
|
||||||
http://portaudio.com/trac/wiki/TutorialDir/TutorialStart
|
|
||||||
|
|
||||||
We have an active mailing list for user and developer discussions.
|
|
||||||
Please feel free to join. See http://www.portaudio.com for details.
|
|
||||||
|
|
||||||
|
|
||||||
Important Files and Folders:
|
|
||||||
include/portaudio.h = header file for PortAudio API. Specifies API.
|
|
||||||
src/common/ = platform independant code, host independant
|
|
||||||
code for all implementations.
|
|
||||||
src/os = os specific (but host api neutral) code
|
|
||||||
src/hostapi = implementations for different host apis
|
|
||||||
|
|
||||||
|
|
||||||
Host API Implementations:
|
|
||||||
src/hostapi/alsa = Advanced Linux Sound Architecture (ALSA)
|
|
||||||
src/hostapi/asihpi = AudioScience HPI
|
|
||||||
src/hostapi/asio = ASIO for Windows and Macintosh
|
|
||||||
src/hostapi/coreaudio = Macintosh Core Audio for OS X
|
|
||||||
src/hostapi/dsound = Windows Direct Sound
|
|
||||||
src/hostapi/jack = JACK Audio Connection Kit
|
|
||||||
src/hostapi/oss = Unix Open Sound System (OSS)
|
|
||||||
src/hostapi/wasapi = Windows Vista WASAPI
|
|
||||||
src/hostapi/wdmks = Windows WDM Kernel Streaming
|
|
||||||
src/hostapi/wmme = Windows MultiMedia Extensions (MME)
|
|
||||||
|
|
||||||
|
|
||||||
Test Programs:
|
|
||||||
test/pa_fuzz.c = guitar fuzz box
|
|
||||||
test/pa_devs.c = print a list of available devices
|
|
||||||
test/pa_minlat.c = determine minimum latency for your machine
|
|
||||||
test/paqa_devs.c = self test that opens all devices
|
|
||||||
test/paqa_errs.c = test error detection and reporting
|
|
||||||
test/patest_clip.c = hear a sine wave clipped and unclipped
|
|
||||||
test/patest_dither.c = hear effects of dithering (extremely subtle)
|
|
||||||
test/patest_pink.c = fun with pink noise
|
|
||||||
test/patest_record.c = record and playback some audio
|
|
||||||
test/patest_maxsines.c = how many sine waves can we play? Tests Pa_GetCPULoad().
|
|
||||||
test/patest_sine.c = output a sine wave in a simple PA app
|
|
||||||
test/patest_sync.c = test syncronization of audio and video
|
|
||||||
test/patest_wire.c = pass input to output, wire simulator
|
|
|
@ -1,197 +0,0 @@
|
||||||
import sys, os.path
|
|
||||||
|
|
||||||
def rsplit(toSplit, sub, max=-1):
|
|
||||||
""" str.rsplit seems to have been introduced in 2.4 :( """
|
|
||||||
l = []
|
|
||||||
i = 0
|
|
||||||
while i != max:
|
|
||||||
try: idx = toSplit.rindex(sub)
|
|
||||||
except ValueError: break
|
|
||||||
|
|
||||||
toSplit, splitOff = toSplit[:idx], toSplit[idx + len(sub):]
|
|
||||||
l.insert(0, splitOff)
|
|
||||||
i += 1
|
|
||||||
|
|
||||||
l.insert(0, toSplit)
|
|
||||||
return l
|
|
||||||
|
|
||||||
sconsDir = os.path.join("build", "scons")
|
|
||||||
SConscript(os.path.join(sconsDir, "SConscript_common"))
|
|
||||||
Import("Platform", "Posix", "ApiVer")
|
|
||||||
|
|
||||||
# SConscript_opts exports PortAudio options
|
|
||||||
optsDict = SConscript(os.path.join(sconsDir, "SConscript_opts"))
|
|
||||||
optionsCache = os.path.join(sconsDir, "options.cache") # Save options between runs in this cache
|
|
||||||
options = Options(optionsCache, args=ARGUMENTS)
|
|
||||||
for k in ("Installation Dirs", "Build Targets", "Host APIs", "Build Parameters", "Bindings"):
|
|
||||||
options.AddOptions(*optsDict[k])
|
|
||||||
# Propagate options into environment
|
|
||||||
env = Environment(options=options)
|
|
||||||
# Save options for next run
|
|
||||||
options.Save(optionsCache, env)
|
|
||||||
# Generate help text for options
|
|
||||||
env.Help(options.GenerateHelpText(env))
|
|
||||||
|
|
||||||
buildDir = os.path.join("#", sconsDir, env["PLATFORM"])
|
|
||||||
|
|
||||||
# Determine parameters to build tools
|
|
||||||
if Platform in Posix:
|
|
||||||
threadCFlags = ''
|
|
||||||
if Platform != 'darwin':
|
|
||||||
threadCFlags = "-pthread "
|
|
||||||
baseLinkFlags = threadCFlags
|
|
||||||
baseCxxFlags = baseCFlags = "-Wall -pedantic -pipe " + threadCFlags
|
|
||||||
debugCxxFlags = debugCFlags = "-g"
|
|
||||||
optCxxFlags = optCFlags = "-O2"
|
|
||||||
env.Append(CCFLAGS = baseCFlags)
|
|
||||||
env.Append(CXXFLAGS = baseCxxFlags)
|
|
||||||
env.Append(LINKFLAGS = baseLinkFlags)
|
|
||||||
if env["enableDebug"]:
|
|
||||||
env.AppendUnique(CCFLAGS=debugCFlags.split())
|
|
||||||
env.AppendUnique(CXXFLAGS=debugCxxFlags.split())
|
|
||||||
if env["enableOptimize"]:
|
|
||||||
env.AppendUnique(CCFLAGS=optCFlags.split())
|
|
||||||
env.AppendUnique(CXXFLAGS=optCxxFlags.split())
|
|
||||||
if not env["enableAsserts"]:
|
|
||||||
env.AppendUnique(CPPDEFINES=["-DNDEBUG"])
|
|
||||||
if env["customCFlags"]:
|
|
||||||
env.Append(CCFLAGS=Split(env["customCFlags"]))
|
|
||||||
if env["customCxxFlags"]:
|
|
||||||
env.Append(CXXFLAGS=Split(env["customCxxFlags"]))
|
|
||||||
if env["customLinkFlags"]:
|
|
||||||
env.Append(LINKFLAGS=Split(env["customLinkFlags"]))
|
|
||||||
|
|
||||||
env.Append(CPPPATH=[os.path.join("#", "include"), "common"])
|
|
||||||
|
|
||||||
# Store all signatures in one file, otherwise .sconsign files will get installed along with our own files
|
|
||||||
env.SConsignFile(os.path.join(sconsDir, ".sconsign"))
|
|
||||||
|
|
||||||
env.SConscriptChdir(False)
|
|
||||||
sources, sharedLib, staticLib, tests, portEnv, hostApis = env.SConscript(os.path.join("src", "SConscript"),
|
|
||||||
build_dir=buildDir, duplicate=False, exports=["env"])
|
|
||||||
|
|
||||||
if Platform in Posix:
|
|
||||||
prefix = env["prefix"]
|
|
||||||
includeDir = os.path.join(prefix, "include")
|
|
||||||
libDir = os.path.join(prefix, "lib")
|
|
||||||
env.Alias("install", includeDir)
|
|
||||||
env.Alias("install", libDir)
|
|
||||||
|
|
||||||
# pkg-config
|
|
||||||
|
|
||||||
def installPkgconfig(env, target, source):
|
|
||||||
tgt = str(target[0])
|
|
||||||
src = str(source[0])
|
|
||||||
f = open(src)
|
|
||||||
try: txt = f.read()
|
|
||||||
finally: f.close()
|
|
||||||
txt = txt.replace("@prefix@", prefix)
|
|
||||||
txt = txt.replace("@exec_prefix@", prefix)
|
|
||||||
txt = txt.replace("@libdir@", libDir)
|
|
||||||
txt = txt.replace("@includedir@", includeDir)
|
|
||||||
txt = txt.replace("@LIBS@", " ".join(["-l%s" % l for l in portEnv["LIBS"]]))
|
|
||||||
txt = txt.replace("@THREAD_CFLAGS@", threadCFlags)
|
|
||||||
|
|
||||||
f = open(tgt, "w")
|
|
||||||
try: f.write(txt)
|
|
||||||
finally: f.close()
|
|
||||||
|
|
||||||
pkgconfigTgt = "portaudio-%d.0.pc" % int(ApiVer.split(".", 1)[0])
|
|
||||||
env.Command(os.path.join(libDir, "pkgconfig", pkgconfigTgt),
|
|
||||||
os.path.join("#", pkgconfigTgt + ".in"), installPkgconfig)
|
|
||||||
|
|
||||||
# Default to None, since if the user disables all targets and no Default is set, all targets
|
|
||||||
# are built by default
|
|
||||||
env.Default(None)
|
|
||||||
if env["enableTests"]:
|
|
||||||
env.Default(tests)
|
|
||||||
if env["enableShared"]:
|
|
||||||
env.Default(sharedLib)
|
|
||||||
|
|
||||||
if Platform in Posix:
|
|
||||||
def symlink(env, target, source):
|
|
||||||
trgt = str(target[0])
|
|
||||||
src = str(source[0])
|
|
||||||
|
|
||||||
if os.path.islink(trgt) or os.path.exists(trgt):
|
|
||||||
os.remove(trgt)
|
|
||||||
os.symlink(os.path.basename(src), trgt)
|
|
||||||
|
|
||||||
major, minor, micro = [int(c) for c in ApiVer.split(".")]
|
|
||||||
|
|
||||||
soFile = "%s.%s" % (os.path.basename(str(sharedLib[0])), ApiVer)
|
|
||||||
env.InstallAs(target=os.path.join(libDir, soFile), source=sharedLib)
|
|
||||||
# Install symlinks
|
|
||||||
symTrgt = os.path.join(libDir, soFile)
|
|
||||||
env.Command(os.path.join(libDir, "libportaudio.so.%d.%d" % (major, minor)),
|
|
||||||
symTrgt, symlink)
|
|
||||||
symTrgt = rsplit(symTrgt, ".", 1)[0]
|
|
||||||
env.Command(os.path.join(libDir, "libportaudio.so.%d" % major), symTrgt, symlink)
|
|
||||||
symTrgt = rsplit(symTrgt, ".", 1)[0]
|
|
||||||
env.Command(os.path.join(libDir, "libportaudio.so"), symTrgt, symlink)
|
|
||||||
|
|
||||||
if env["enableStatic"]:
|
|
||||||
env.Default(staticLib)
|
|
||||||
env.Install(libDir, staticLib)
|
|
||||||
|
|
||||||
env.Install(includeDir, os.path.join("include", "portaudio.h"))
|
|
||||||
|
|
||||||
|
|
||||||
if env["enableCxx"]:
|
|
||||||
env.SConscriptChdir(True)
|
|
||||||
cxxEnv = env.Copy()
|
|
||||||
sharedLibs, staticLibs, headers = env.SConscript(os.path.join("bindings", "cpp", "SConscript"),
|
|
||||||
exports={"env": cxxEnv, "buildDir": buildDir}, build_dir=os.path.join(buildDir, "portaudiocpp"), duplicate=False)
|
|
||||||
if env["enableStatic"]:
|
|
||||||
env.Default(staticLibs)
|
|
||||||
env.Install(libDir, staticLibs)
|
|
||||||
if env["enableShared"]:
|
|
||||||
env.Default(sharedLibs)
|
|
||||||
env.Install(libDir, sharedLibs)
|
|
||||||
env.Install(os.path.join(includeDir, "portaudiocpp"), headers)
|
|
||||||
|
|
||||||
# Generate portaudio_config.h header with compile-time definitions of which PA
|
|
||||||
# back-ends are available, and which includes back-end extension headers
|
|
||||||
|
|
||||||
# Host-specific headers
|
|
||||||
hostApiHeaders = {"ALSA": "pa_linux_alsa.h",
|
|
||||||
"ASIO": "pa_asio.h",
|
|
||||||
"COREAUDIO": "pa_mac_core.h",
|
|
||||||
"JACK": "pa_jack.h",
|
|
||||||
"WMME": "pa_winwmme.h",
|
|
||||||
}
|
|
||||||
|
|
||||||
def buildConfigH(target, source, env):
|
|
||||||
"""builder for portaudio_config.h"""
|
|
||||||
global hostApiHeaders, hostApis
|
|
||||||
out = ""
|
|
||||||
for hostApi in hostApis:
|
|
||||||
out += "#define PA_HAVE_%s\n" % hostApi
|
|
||||||
|
|
||||||
hostApiSpecificHeader = hostApiHeaders.get(hostApi, None)
|
|
||||||
if hostApiSpecificHeader:
|
|
||||||
out += "#include \"%s\"\n" % hostApiSpecificHeader
|
|
||||||
|
|
||||||
out += "\n"
|
|
||||||
# Strip the last newline
|
|
||||||
if out and out[-1] == "\n":
|
|
||||||
out = out[:-1]
|
|
||||||
|
|
||||||
f = file(str(target[0]), 'w')
|
|
||||||
try: f.write(out)
|
|
||||||
finally: f.close()
|
|
||||||
return 0
|
|
||||||
|
|
||||||
# Define the builder for the config header
|
|
||||||
env.Append(BUILDERS={"portaudioConfig": env.Builder(
|
|
||||||
action=Action(buildConfigH), target_factory=env.fs.File)})
|
|
||||||
|
|
||||||
confH = env.portaudioConfig(File("portaudio_config.h", "include"),
|
|
||||||
File("portaudio.h", "include"))
|
|
||||||
env.Default(confH)
|
|
||||||
env.Install(os.path.join(includeDir, "portaudio"), confH)
|
|
||||||
|
|
||||||
for api in hostApis:
|
|
||||||
if api in hostApiHeaders:
|
|
||||||
env.Install(os.path.join(includeDir, "portaudio"),
|
|
||||||
File(hostApiHeaders[api], "include"))
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,18 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
|
||||||
<PropertyGroup Label="UserMacros">
|
|
||||||
<ProjectRootDir>$(ProjectDir)\..\..</ProjectRootDir>
|
|
||||||
<SvnRootDir>$(ProjectRootDir)\..\..</SvnRootDir>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup>
|
|
||||||
<_ProjectFileVersion>10.0.30128.1</_ProjectFileVersion>
|
|
||||||
</PropertyGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<BuildMacro Include="ProjectRootDir">
|
|
||||||
<Value>$(ProjectRootDir)</Value>
|
|
||||||
</BuildMacro>
|
|
||||||
<BuildMacro Include="SvnRootDir">
|
|
||||||
<Value>$(SvnRootDir)</Value>
|
|
||||||
</BuildMacro>
|
|
||||||
</ItemGroup>
|
|
||||||
</Project>
|
|
|
@ -1,57 +0,0 @@
|
||||||
EXPORTS
|
|
||||||
|
|
||||||
;
|
|
||||||
Pa_GetVersion @1
|
|
||||||
Pa_GetVersionText @2
|
|
||||||
Pa_GetErrorText @3
|
|
||||||
Pa_Initialize @4
|
|
||||||
Pa_Terminate @5
|
|
||||||
Pa_GetHostApiCount @6
|
|
||||||
Pa_GetDefaultHostApi @7
|
|
||||||
Pa_GetHostApiInfo @8
|
|
||||||
Pa_HostApiTypeIdToHostApiIndex @9
|
|
||||||
Pa_HostApiDeviceIndexToDeviceIndex @10
|
|
||||||
Pa_GetLastHostErrorInfo @11
|
|
||||||
Pa_GetDeviceCount @12
|
|
||||||
Pa_GetDefaultInputDevice @13
|
|
||||||
Pa_GetDefaultOutputDevice @14
|
|
||||||
Pa_GetDeviceInfo @15
|
|
||||||
Pa_IsFormatSupported @16
|
|
||||||
Pa_OpenStream @17
|
|
||||||
Pa_OpenDefaultStream @18
|
|
||||||
Pa_CloseStream @19
|
|
||||||
Pa_SetStreamFinishedCallback @20
|
|
||||||
Pa_StartStream @21
|
|
||||||
Pa_StopStream @22
|
|
||||||
Pa_AbortStream @23
|
|
||||||
Pa_IsStreamStopped @24
|
|
||||||
Pa_IsStreamActive @25
|
|
||||||
Pa_GetStreamInfo @26
|
|
||||||
Pa_GetStreamTime @27
|
|
||||||
Pa_GetStreamCpuLoad @28
|
|
||||||
Pa_ReadStream @29
|
|
||||||
Pa_WriteStream @30
|
|
||||||
Pa_GetStreamReadAvailable @31
|
|
||||||
Pa_GetStreamWriteAvailable @32
|
|
||||||
Pa_GetSampleSize @33
|
|
||||||
Pa_Sleep @34
|
|
||||||
PaAsio_GetAvailableBufferSizes @50
|
|
||||||
PaAsio_ShowControlPanel @51
|
|
||||||
PaUtil_InitializeX86PlainConverters @52
|
|
||||||
PaAsio_GetInputChannelName @53
|
|
||||||
PaAsio_GetOutputChannelName @54
|
|
||||||
PaUtil_SetDebugPrintFunction @55
|
|
||||||
PaWasapi_GetAudioClient @56
|
|
||||||
PaWasapi_UpdateDeviceList @57
|
|
||||||
PaWasapi_GetDeviceCurrentFormat @58
|
|
||||||
PaWasapi_GetDeviceDefaultFormat @59
|
|
||||||
PaWasapi_GetDeviceMixFormat @60
|
|
||||||
PaWasapi_GetDeviceRole @61
|
|
||||||
PaWasapi_ThreadPriorityBoost @62
|
|
||||||
PaWasapi_ThreadPriorityRevert @63
|
|
||||||
PaWasapi_GetFramesPerHostBuffer @64
|
|
||||||
PaWasapi_GetJackCount @65
|
|
||||||
PaWasapi_GetJackDescription @66
|
|
||||||
PaWasapi_SetStreamStateHandler @68
|
|
||||||
PaWasapiWinrt_SetDefaultDeviceId @67
|
|
||||||
PaWasapiWinrt_PopulateDeviceList @69
|
|
|
@ -1,85 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
|
||||||
<Import Project="$(SolutionDir)common\vsprops\BaseProjectConfig.props" />
|
|
||||||
<Import Project="$(SolutionDir)common\vsprops\WinSDK.props" />
|
|
||||||
<PropertyGroup Label="Globals">
|
|
||||||
<ProjectGuid>{0A18A071-125E-442F-AFF7-A3F68ABECF99}</ProjectGuid>
|
|
||||||
</PropertyGroup>
|
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
|
|
||||||
<PropertyGroup Label="Configuration">
|
|
||||||
<ConfigurationType>StaticLibrary</ConfigurationType>
|
|
||||||
<PlatformToolset>$(DefaultPlatformToolset)</PlatformToolset>
|
|
||||||
<CharacterSet>Unicode</CharacterSet>
|
|
||||||
<WholeProgramOptimization Condition="$(Configuration.Contains(Release))">true</WholeProgramOptimization>
|
|
||||||
<UseDebugLibraries Condition="$(Configuration.Contains(Debug))">true</UseDebugLibraries>
|
|
||||||
<UseDebugLibraries Condition="!$(Configuration.Contains(Debug))">false</UseDebugLibraries>
|
|
||||||
</PropertyGroup>
|
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
|
|
||||||
<ImportGroup Label="ExtensionSettings" />
|
|
||||||
<ImportGroup Label="PropertySheets">
|
|
||||||
<Import Project="ProjectRootDir.props" />
|
|
||||||
<Import Project="$(SolutionDir)3rdparty\3rdparty.props" />
|
|
||||||
<Import Condition="$(Configuration.Contains(Debug))" Project="$(SolutionDir)common\vsprops\CodeGen_Debug.props" />
|
|
||||||
<Import Condition="$(Configuration.Contains(Devel))" Project="$(SolutionDir)common\vsprops\CodeGen_Devel.props" />
|
|
||||||
<Import Condition="$(Configuration.Contains(Release))" Project="$(SolutionDir)common\vsprops\CodeGen_Release.props" />
|
|
||||||
<Import Condition="!$(Configuration.Contains(Release))" Project="$(SolutionDir)common\vsprops\IncrementalLinking.props" />
|
|
||||||
</ImportGroup>
|
|
||||||
<PropertyGroup Label="UserMacros" />
|
|
||||||
<PropertyGroup>
|
|
||||||
<CodeAnalysisRuleSet>AllRules.ruleset</CodeAnalysisRuleSet>
|
|
||||||
</PropertyGroup>
|
|
||||||
<ItemDefinitionGroup>
|
|
||||||
<ClCompile>
|
|
||||||
<AdditionalIncludeDirectories>..\..\src\common;..\..\include;.\;..\..\src\os\win;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
|
||||||
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;PAWIN_USE_WDMKS_DEVICE_INFO;PA_USE_DS=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
|
||||||
<PreprocessorDefinitions>PA_USE_WASAPI=1;PA_USE_WDMKS=1;PA_USE_WMME=0;PA_USE_ASIO=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
|
||||||
<PreprocessorDefinitions Condition="$(Configuration.Contains(Debug))">PA_ENABLE_DEBUG_OUTPUT;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
|
||||||
</ClCompile>
|
|
||||||
<Lib>
|
|
||||||
<AdditionalDependencies>ksuser.lib</AdditionalDependencies>
|
|
||||||
</Lib>
|
|
||||||
</ItemDefinitionGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_allocation.c" />
|
|
||||||
<ClCompile Include="..\..\src\common\pa_converters.c" />
|
|
||||||
<ClCompile Include="..\..\src\common\pa_cpuload.c" />
|
|
||||||
<ClCompile Include="..\..\src\common\pa_debugprint.c" />
|
|
||||||
<ClCompile Include="..\..\src\common\pa_dither.c" />
|
|
||||||
<ClCompile Include="..\..\src\common\pa_front.c" />
|
|
||||||
<ClCompile Include="..\..\src\common\pa_process.c" />
|
|
||||||
<ClCompile Include="..\..\src\common\pa_ringbuffer.c" />
|
|
||||||
<ClCompile Include="..\..\src\common\pa_stream.c" />
|
|
||||||
<ClCompile Include="..\..\src\common\pa_trace.c" />
|
|
||||||
<ClCompile Include="..\..\src\hostapi\dsound\pa_win_ds.c" />
|
|
||||||
<ClCompile Include="..\..\src\hostapi\dsound\pa_win_ds_dynlink.c" />
|
|
||||||
<ClCompile Include="..\..\src\hostapi\wdmks\pa_win_wdmks.c" />
|
|
||||||
<ClCompile Include="..\..\src\hostapi\wmme\pa_win_wmme.c" />
|
|
||||||
<ClCompile Include="..\..\src\hostapi\wasapi\pa_win_wasapi.c" />
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_coinitialize.c" />
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_hostapis.c" />
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_util.c" />
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_waveformat.c" />
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_wdmks_utils.c" />
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_x86_plain_converters.c" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<None Include="..\..\src\hostapi\wdmks\readme.txt" />
|
|
||||||
<None Include="portaudio.def" />
|
|
||||||
<None Include="portaudio_noasio.def" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ClInclude Include="..\..\include\pa_asio.h" />
|
|
||||||
<ClInclude Include="..\..\include\pa_jack.h" />
|
|
||||||
<ClInclude Include="..\..\include\pa_linux_alsa.h" />
|
|
||||||
<ClInclude Include="..\..\include\pa_mac_core.h" />
|
|
||||||
<ClInclude Include="..\..\include\pa_win_ds.h" />
|
|
||||||
<ClInclude Include="..\..\include\pa_win_wasapi.h" />
|
|
||||||
<ClInclude Include="..\..\include\pa_win_waveformat.h" />
|
|
||||||
<ClInclude Include="..\..\include\pa_win_wdmks.h" />
|
|
||||||
<ClInclude Include="..\..\include\pa_win_wmme.h" />
|
|
||||||
<ClInclude Include="..\..\include\portaudio.h" />
|
|
||||||
<ClInclude Include="..\..\src\os\win\pa_win_coinitialize.h" />
|
|
||||||
</ItemGroup>
|
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
|
||||||
<ImportGroup Label="ExtensionTargets" />
|
|
||||||
</Project>
|
|
|
@ -1,182 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
|
||||||
<ItemGroup>
|
|
||||||
<Filter Include="Source Files">
|
|
||||||
<UniqueIdentifier>{5cc0e5d8-728d-40a7-8083-5b983fd1aee7}</UniqueIdentifier>
|
|
||||||
<Extensions>cpp;c;cxx;rc;def;r;odl;idl;hpj;bat</Extensions>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\common">
|
|
||||||
<UniqueIdentifier>{a858f4ea-8d6b-4443-90f9-c2dd3b140b6b}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\hostapi">
|
|
||||||
<UniqueIdentifier>{0ce101a1-ed76-41ee-82e4-64060016158b}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\hostapi\ASIO">
|
|
||||||
<UniqueIdentifier>{add87864-e960-4687-b000-d88213e2b2d4}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\hostapi\ASIO\ASIOSDK">
|
|
||||||
<UniqueIdentifier>{6766d178-09d3-4194-9e43-0311d503035c}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\hostapi\dsound">
|
|
||||||
<UniqueIdentifier>{07c0df04-c6c4-4eb9-b645-d56ade6252fd}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\hostapi\wmme">
|
|
||||||
<UniqueIdentifier>{ee059c3c-2663-474c-bc48-385c1db73147}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\hostapi\wasapi">
|
|
||||||
<UniqueIdentifier>{1782b100-f22f-4c73-812d-a3c654dc9825}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\os">
|
|
||||||
<UniqueIdentifier>{1af05f1a-04d9-40b1-890c-1a34a9d0192e}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\os\win">
|
|
||||||
<UniqueIdentifier>{b6f829a2-cf78-4f0e-b051-8fccf66c5213}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Resource Files">
|
|
||||||
<UniqueIdentifier>{b10684c7-978c-4840-be31-71d29889162c}</UniqueIdentifier>
|
|
||||||
<Extensions>ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe</Extensions>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Header Files">
|
|
||||||
<UniqueIdentifier>{78689f06-8c26-4417-93e2-b809a8c41ee7}</UniqueIdentifier>
|
|
||||||
<Extensions>h;hpp;hxx;hm;inl</Extensions>
|
|
||||||
</Filter>
|
|
||||||
<Filter Include="Source Files\hostapi\wdmks">
|
|
||||||
<UniqueIdentifier>{0d9360dd-9d00-434a-ab46-7a89b2d35fd0}</UniqueIdentifier>
|
|
||||||
</Filter>
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_allocation.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_converters.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_cpuload.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_debugprint.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_dither.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_front.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_process.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_ringbuffer.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_stream.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\common\pa_trace.c">
|
|
||||||
<Filter>Source Files\common</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\asio\pa_asio.cpp">
|
|
||||||
<Filter>Source Files\hostapi\ASIO</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\asio\ASIOSDK\common\asio.cpp">
|
|
||||||
<Filter>Source Files\hostapi\ASIO\ASIOSDK</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\asio\ASIOSDK\host\ASIOConvertSamples.cpp">
|
|
||||||
<Filter>Source Files\hostapi\ASIO\ASIOSDK</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\asio\ASIOSDK\host\asiodrivers.cpp">
|
|
||||||
<Filter>Source Files\hostapi\ASIO\ASIOSDK</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\asio\ASIOSDK\host\pc\asiolist.cpp">
|
|
||||||
<Filter>Source Files\hostapi\ASIO\ASIOSDK</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\asio\ASIOSDK\common\combase.cpp">
|
|
||||||
<Filter>Source Files\hostapi\ASIO\ASIOSDK</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\asio\ASIOSDK\common\debugmessage.cpp">
|
|
||||||
<Filter>Source Files\hostapi\ASIO\ASIOSDK</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\asio\ASIOSDK\common\register.cpp">
|
|
||||||
<Filter>Source Files\hostapi\ASIO\ASIOSDK</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\dsound\pa_win_ds.c">
|
|
||||||
<Filter>Source Files\hostapi\dsound</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\dsound\pa_win_ds_dynlink.c">
|
|
||||||
<Filter>Source Files\hostapi\dsound</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\wmme\pa_win_wmme.c">
|
|
||||||
<Filter>Source Files\hostapi\wmme</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\wasapi\pa_win_wasapi.c">
|
|
||||||
<Filter>Source Files\hostapi\wasapi</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_hostapis.c">
|
|
||||||
<Filter>Source Files\os\win</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_util.c">
|
|
||||||
<Filter>Source Files\os\win</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_waveformat.c">
|
|
||||||
<Filter>Source Files\os\win</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_wdmks_utils.c">
|
|
||||||
<Filter>Source Files\os\win</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_x86_plain_converters.c">
|
|
||||||
<Filter>Source Files\os\win</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\hostapi\wdmks\pa_win_wdmks.c">
|
|
||||||
<Filter>Source Files\hostapi\wdmks</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="..\..\src\os\win\pa_win_coinitialize.c">
|
|
||||||
<Filter>Source Files\os\win</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<None Include="portaudio.def">
|
|
||||||
<Filter>Resource Files</Filter>
|
|
||||||
</None>
|
|
||||||
<None Include="portaudio_noasio.def">
|
|
||||||
<Filter>Resource Files</Filter>
|
|
||||||
</None>
|
|
||||||
<None Include="..\..\src\hostapi\wdmks\readme.txt">
|
|
||||||
<Filter>Source Files\hostapi\wdmks</Filter>
|
|
||||||
</None>
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ClInclude Include="..\..\include\pa_asio.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\include\pa_jack.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\include\pa_linux_alsa.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\include\pa_mac_core.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\include\pa_win_ds.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\include\pa_win_wasapi.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\include\pa_win_waveformat.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\include\pa_win_wmme.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\include\portaudio.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\src\os\win\pa_win_coinitialize.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="..\..\include\pa_win_wdmks.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
</ItemGroup>
|
|
||||||
</Project>
|
|
|
@ -1,46 +0,0 @@
|
||||||
EXPORTS
|
|
||||||
|
|
||||||
;
|
|
||||||
Pa_GetVersion @1
|
|
||||||
Pa_GetVersionText @2
|
|
||||||
Pa_GetErrorText @3
|
|
||||||
Pa_Initialize @4
|
|
||||||
Pa_Terminate @5
|
|
||||||
Pa_GetHostApiCount @6
|
|
||||||
Pa_GetDefaultHostApi @7
|
|
||||||
Pa_GetHostApiInfo @8
|
|
||||||
Pa_HostApiTypeIdToHostApiIndex @9
|
|
||||||
Pa_HostApiDeviceIndexToDeviceIndex @10
|
|
||||||
Pa_GetLastHostErrorInfo @11
|
|
||||||
Pa_GetDeviceCount @12
|
|
||||||
Pa_GetDefaultInputDevice @13
|
|
||||||
Pa_GetDefaultOutputDevice @14
|
|
||||||
Pa_GetDeviceInfo @15
|
|
||||||
Pa_IsFormatSupported @16
|
|
||||||
Pa_OpenStream @17
|
|
||||||
Pa_OpenDefaultStream @18
|
|
||||||
Pa_CloseStream @19
|
|
||||||
Pa_SetStreamFinishedCallback @20
|
|
||||||
Pa_StartStream @21
|
|
||||||
Pa_StopStream @22
|
|
||||||
Pa_AbortStream @23
|
|
||||||
Pa_IsStreamStopped @24
|
|
||||||
Pa_IsStreamActive @25
|
|
||||||
Pa_GetStreamInfo @26
|
|
||||||
Pa_GetStreamTime @27
|
|
||||||
Pa_GetStreamCpuLoad @28
|
|
||||||
Pa_ReadStream @29
|
|
||||||
Pa_WriteStream @30
|
|
||||||
Pa_GetStreamReadAvailable @31
|
|
||||||
Pa_GetStreamWriteAvailable @32
|
|
||||||
Pa_GetSampleSize @33
|
|
||||||
Pa_Sleep @34
|
|
||||||
PaUtil_InitializeX86PlainConverters @52
|
|
||||||
PaUtil_SetDebugPrintFunction @55
|
|
||||||
PaWasapi_GetDeviceDefaultFormat @56
|
|
||||||
PaWasapi_GetDeviceRole @57
|
|
||||||
PaWasapi_ThreadPriorityBoost @58
|
|
||||||
PaWasapi_ThreadPriorityRevert @59
|
|
||||||
PaWasapi_GetFramesPerHostBuffer @60
|
|
||||||
PaWasapi_GetJackDescription @61
|
|
||||||
PaWasapi_GetJackCount @62
|
|
|
@ -1,112 +0,0 @@
|
||||||
Hello
|
|
||||||
|
|
||||||
This is a small list of steps in order to build portaudio
|
|
||||||
(Currently v19-devel) into a VS2005 DLL and lib file.
|
|
||||||
This DLL contains all 5 current Win32 PA APIS (MME/DS/ASIO/WASAPI/WDMKS)
|
|
||||||
|
|
||||||
1)Copy the source dirs that comes with the ASIO SDK inside src\hostapi\asio\ASIOSDK
|
|
||||||
so you should now have example:
|
|
||||||
|
|
||||||
portaudio19svn\src\hostapi\asio\ASIOSDK\common
|
|
||||||
portaudio19svn\src\hostapi\asio\ASIOSDK\host
|
|
||||||
portaudio19svn\src\hostapi\asio\ASIOSDK\host\sample
|
|
||||||
portaudio19svn\src\hostapi\asio\ASIOSDK\host\pc
|
|
||||||
portaudio19svn\src\hostapi\asio\ASIOSDK\host\mac (not needed)
|
|
||||||
|
|
||||||
You dont need "driver"
|
|
||||||
|
|
||||||
To build without ASIO (or another Host API) see the "Building without ASIO support" section below.
|
|
||||||
|
|
||||||
2)
|
|
||||||
*If you have Visual Studio 6.0*, please make sure you have it updated with the latest (and final)
|
|
||||||
microsoft libraries for it, namely:
|
|
||||||
|
|
||||||
Service pack 5:
|
|
||||||
Latest known URL:
|
|
||||||
http://msdn2.microsoft.com/en-us/vstudio/aa718363.aspx
|
|
||||||
Yes there EXISTS a service pack 6 , but the processor pack (below) isn't compatible with it.
|
|
||||||
|
|
||||||
Processor Pack(only works with above SP5)
|
|
||||||
Latest known URL:
|
|
||||||
http://msdn2.microsoft.com/en-us/vstudio/Aa718349.aspx
|
|
||||||
This isn't absolutely required for portaudio, but if you plan on using SSE intrinsics and similar things.
|
|
||||||
Up to you to decide upon Service pack 5 or 6 depending on your need for intrinsics.
|
|
||||||
|
|
||||||
Platform SDK (Feb 2003) :
|
|
||||||
Latest known URL:
|
|
||||||
http://www.microsoft.com/msdownload/platformsdk/sdkupdate/psdk-full.htm
|
|
||||||
(This will allow your code base to be x64 friendly, with correct defines
|
|
||||||
for LONG_PTR and such)
|
|
||||||
NOTE A) Yes you have to use IE activex scripts to install that - wont work in Firefox, you
|
|
||||||
may have to temporarily change tyour default browser(aint life unfair)
|
|
||||||
NOTE B) Dont forget to hit "Register PSDK Directories with Visual Studio".
|
|
||||||
you can make sure its right in VC6 if you open tools/options/directories/include files and you see SDK 2003 as the FIRST entry
|
|
||||||
(it must be the same for libs)
|
|
||||||
|
|
||||||
DirectX 9.0 SDK Update - (Summer 2003)
|
|
||||||
Latest known URL:
|
|
||||||
http://www.microsoft.com/downloads/details.aspx?familyid=9216652f-51e0-402e-b7b5-feb68d00f298&displaylang=en
|
|
||||||
Again register the links in VC6, and check inside vc6 if headers are in second place right after SDk 2003
|
|
||||||
|
|
||||||
*If you have 7.0(VC.NET/2001) or 7.1(VC.2003) *
|
|
||||||
then I suggest you open portaudio.dsp (and convert if needed)
|
|
||||||
|
|
||||||
*If you have Visual Studio 2005 * (or later), I suggest you open the portaudio.sln file
|
|
||||||
which contains 2 projects (portaudio & portaudio_static) each with 6 configurations: Win32/x64 in both Debug, Release and ReleaseMinDependency,
|
|
||||||
last of which removes dependency of all but basic OS system DLLs.
|
|
||||||
|
|
||||||
hit compile and hope for the best.
|
|
||||||
|
|
||||||
3)Now in any project, in which you require portaudio,
|
|
||||||
you can just link with portaudio_x86.lib, (or _x64) and of course include the
|
|
||||||
relevant headers
|
|
||||||
(portaudio.h, and/or pa_asio.h , pa_x86_plain_converters.h) See (*)
|
|
||||||
|
|
||||||
4) Your new exe should now use portaudio_xXX.dll.
|
|
||||||
|
|
||||||
|
|
||||||
Have fun!
|
|
||||||
|
|
||||||
(*): you may want to add/remove some DLL entry points.
|
|
||||||
Right now those 6 entries are _not_ from portaudio.h
|
|
||||||
|
|
||||||
(from portaudio.def)
|
|
||||||
(...)
|
|
||||||
PaAsio_GetAvailableLatencyValues @50
|
|
||||||
PaAsio_ShowControlPanel @51
|
|
||||||
PaUtil_InitializeX86PlainConverters @52
|
|
||||||
PaAsio_GetInputChannelName @53
|
|
||||||
PaAsio_GetOutputChannelName @54
|
|
||||||
PaUtil_SetLogPrintFunction @55
|
|
||||||
|
|
||||||
|
|
||||||
*** Building without ASIO support ***
|
|
||||||
|
|
||||||
To build PortAudio without ASIO support you need to:
|
|
||||||
A. Make sure your project doesn't try to build any ASIO SDK files.
|
|
||||||
If you're using one of the shipped projects, remove the ASIO related files
|
|
||||||
from the project.
|
|
||||||
|
|
||||||
B. Make sure your project doesn't try to build the PortAudio ASIO
|
|
||||||
implementation files:
|
|
||||||
src/hostapi/pa_asio.cpp
|
|
||||||
src/hostapi/iasiothiscallresolver.cpp
|
|
||||||
If you're using one of the shipped projects remove them from the project.
|
|
||||||
|
|
||||||
C. Set the PA_USE_ASIO preprocessor symbol to zero (i.e. PA_USE_ASIO=0) in the project properties.
|
|
||||||
In VS2005 this can be added under
|
|
||||||
Project Properties > Configuration Properties > C/C++ > Preprocessor > Preprocessor Definitions
|
|
||||||
|
|
||||||
Setting PA_USE_ASIO=0 stops src/os/win/pa_win_hostapis.c
|
|
||||||
from trying to initialize the PA ASIO implementation.
|
|
||||||
|
|
||||||
D. Remove PaAsio_* entry points from portaudio.def, or comment them out with ;
|
|
||||||
|
|
||||||
|
|
||||||
A similar procedure can be used to omit any of the other host APIs from the
|
|
||||||
build. The relevant preprocessor symbols used by pa_win_hostapis.c are:
|
|
||||||
PA_USE_WMME, PA_USE_DSOUND, PA_USE_ASIO, PA_USE_WASAPI and PA_USE_WDMKS
|
|
||||||
|
|
||||||
-----
|
|
||||||
David Viens, davidv@plogue.com
|
|
||||||
Robert Bielik, robert@xponaut.se
|
|
|
@ -1,30 +0,0 @@
|
||||||
import os.path, sys
|
|
||||||
|
|
||||||
class ConfigurationError(Exception):
|
|
||||||
def __init__(self, reason):
|
|
||||||
Exception.__init__(self, "Configuration failed: %s" % reason)
|
|
||||||
|
|
||||||
env = Environment()
|
|
||||||
|
|
||||||
# sunos, aix, hpux, irix, sunos appear to be platforms known by SCons, assuming they're POSIX compliant
|
|
||||||
Posix = ("linux", "darwin", "sunos", "aix", "hpux", "irix", "sunos", "netbsd")
|
|
||||||
Windows = ("win32", "cygwin")
|
|
||||||
|
|
||||||
if env["PLATFORM"] == "posix":
|
|
||||||
if sys.platform[:5] == "linux":
|
|
||||||
Platform = "linux"
|
|
||||||
elif sys.platform[:6] == "netbsd":
|
|
||||||
Platform = "netbsd"
|
|
||||||
else:
|
|
||||||
raise ConfigurationError("Unknown platform %s" % sys.platform)
|
|
||||||
else:
|
|
||||||
if not env["PLATFORM"] in ("win32", "cygwin") + Posix:
|
|
||||||
raise ConfigurationError("Unknown platform %s" % env["PLATFORM"])
|
|
||||||
Platform = env["PLATFORM"]
|
|
||||||
|
|
||||||
# Inspired by the versioning scheme followed by Qt, it seems sensible enough. There are three components: major, minor
|
|
||||||
# and micro. Major changes with each subtraction from the API (backward-incompatible, i.e. V19 vs. V18), minor changes
|
|
||||||
# with each addition to the API (backward-compatible), micro changes with each revision of the source code.
|
|
||||||
ApiVer = "2.0.0"
|
|
||||||
|
|
||||||
Export("Platform", "Posix", "ConfigurationError", "ApiVer")
|
|
|
@ -1,91 +0,0 @@
|
||||||
import os.path, sys
|
|
||||||
|
|
||||||
def _PackageOption(pkgName, default=1):
|
|
||||||
""" Allow user to choose whether a package should be used if available. This results in a commandline option use<Pkgname>,
|
|
||||||
where Pkgname is the name of the package with a capitalized first letter.
|
|
||||||
@param pkgName: Name of package.
|
|
||||||
@param default: The default value for this option ("yes"/"no").
|
|
||||||
"""
|
|
||||||
return BoolOption("use%s" % pkgName[0].upper() + pkgName[1:], "use %s if available" % (pkgName), default)
|
|
||||||
|
|
||||||
def _BoolOption(opt, explanation, default=1):
|
|
||||||
""" Allow user to enable/disable a certain option. This results in a commandline option enable<Option>, where Option
|
|
||||||
is the name of the option with a capitalized first letter.
|
|
||||||
@param opt: Name of option.
|
|
||||||
@param explanation: Explanation of option.
|
|
||||||
@param default: The default value for this option (1/0).
|
|
||||||
"""
|
|
||||||
return BoolOption("enable%s" % opt[0].upper() + opt[1:], explanation, default)
|
|
||||||
|
|
||||||
def _EnumOption(opt, explanation, allowedValues, default):
|
|
||||||
""" Allow the user to choose among a set of values for an option. This results in a commandline option with<Option>,
|
|
||||||
where Option is the name of the option with a capitalized first letter.
|
|
||||||
@param opt: The name of the option.
|
|
||||||
@param explanation: Explanation of option.
|
|
||||||
@param allowedValues: The set of values to choose from.
|
|
||||||
@param default: The default value.
|
|
||||||
"""
|
|
||||||
assert default in allowedValues
|
|
||||||
return EnumOption("with%s" % opt[0].upper() + opt[1:], explanation, default, allowed_values=allowedValues)
|
|
||||||
|
|
||||||
def _DirectoryOption(opt, explanation, default):
|
|
||||||
""" Allow the user to configure the location for a certain directory, for instance the prefix. This results in a
|
|
||||||
commandline option which is simply the name of this option.
|
|
||||||
@param opt: The configurable directory, for instance "prefix".
|
|
||||||
@param explanation: Explanation of option.
|
|
||||||
@param default: The default value for this option.
|
|
||||||
"""
|
|
||||||
return PathOption(opt, explanation, default)
|
|
||||||
# Incompatible with the latest stable SCons
|
|
||||||
# return PathOption(path, help, default, PathOption.PathIsDir)
|
|
||||||
|
|
||||||
import SCons.Errors
|
|
||||||
try:
|
|
||||||
Import("Platform", "Posix")
|
|
||||||
except SCons.Errors.UserError:
|
|
||||||
# The common objects must be exported first
|
|
||||||
SConscript("SConscript_common")
|
|
||||||
Import("Platform", "Posix")
|
|
||||||
|
|
||||||
# Expose the options as a dictionary of sets of options
|
|
||||||
opts = {}
|
|
||||||
|
|
||||||
if Platform in Posix:
|
|
||||||
opts["Installation Dirs"] = [_DirectoryOption("prefix", "installation prefix", "/usr/local")]
|
|
||||||
elif Platform in Windows:
|
|
||||||
if Platform == "cygwin":
|
|
||||||
opts["Installation Dirs"] = [_DirectoryOption("prefix", "installation prefix", "/usr/local")]
|
|
||||||
|
|
||||||
opts["Build Targets"] = [_BoolOption("shared", "create shared library"), _BoolOption("static", "create static library"),
|
|
||||||
_BoolOption("tests", "build test programs")]
|
|
||||||
|
|
||||||
apis = []
|
|
||||||
if Platform in Posix:
|
|
||||||
apis.append(_PackageOption("OSS"))
|
|
||||||
apis.append(_PackageOption("JACK"))
|
|
||||||
apis.append(_PackageOption("ALSA", Platform == "linux"))
|
|
||||||
apis.append(_PackageOption("ASIHPI", Platform == "linux"))
|
|
||||||
apis.append(_PackageOption("COREAUDIO", Platform == "darwin"))
|
|
||||||
elif Platform in Windows:
|
|
||||||
if Platform == "cygwin":
|
|
||||||
apis.append(_EnumOption("winAPI", "Windows API to use", ("wmme", "directx", "asio"), "wmme"))
|
|
||||||
|
|
||||||
opts["Host APIs"] = apis
|
|
||||||
|
|
||||||
opts["Build Parameters"] = [\
|
|
||||||
_BoolOption("debug", "compile with debug symbols"),
|
|
||||||
_BoolOption("optimize", "compile with optimization", default=0),
|
|
||||||
_BoolOption("asserts", "runtime assertions are helpful for debugging, but can be detrimental to performance",
|
|
||||||
default=1),
|
|
||||||
_BoolOption("debugOutput", "enable debug output", default=0),
|
|
||||||
# _BoolOption("python", "create Python binding"),
|
|
||||||
("customCFlags", "customize compilation of C code", ""),
|
|
||||||
("customCxxFlags", "customize compilation of C++ code", ""),
|
|
||||||
("customLinkFlags", "customize linking", ""),
|
|
||||||
]
|
|
||||||
|
|
||||||
opts["Bindings"] = [\
|
|
||||||
_BoolOption("cxx", "build Merlijn Blaauw's PA C++ wrapper", default=0)
|
|
||||||
]
|
|
||||||
|
|
||||||
Return("opts")
|
|
|
@ -1,12 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
# Clear the Git commit SHA in the include file.
|
|
||||||
# This should be run before checking in code to Git.
|
|
||||||
#
|
|
||||||
revision_filename=src/common/pa_gitrevision.h
|
|
||||||
|
|
||||||
# Update the include file with the current GIT revision.
|
|
||||||
echo "#define PA_GIT_REVISION unknown" > ${revision_filename}
|
|
||||||
|
|
||||||
echo ${revision_filename} now contains
|
|
||||||
cat ${revision_filename}
|
|
|
@ -1,41 +0,0 @@
|
||||||
# $Id: $
|
|
||||||
#
|
|
||||||
# - Try to find the ASIO SDK
|
|
||||||
# Once done this will define
|
|
||||||
#
|
|
||||||
# ASIOSDK_FOUND - system has ASIO SDK
|
|
||||||
# ASIOSDK_ROOT_DIR - path to the ASIO SDK base directory
|
|
||||||
# ASIOSDK_INCLUDE_DIR - the ASIO SDK include directory
|
|
||||||
|
|
||||||
if(WIN32)
|
|
||||||
else(WIN32)
|
|
||||||
message(FATAL_ERROR "FindASIOSDK.cmake: Unsupported platform ${CMAKE_SYSTEM_NAME}" )
|
|
||||||
endif(WIN32)
|
|
||||||
|
|
||||||
file(GLOB results "${CMAKE_CURRENT_SOURCE_DIR}/../as*")
|
|
||||||
foreach(f ${results})
|
|
||||||
if(IS_DIRECTORY ${f})
|
|
||||||
set(ASIOSDK_PATH_HINT ${ASIOSDK_PATH_HINT} ${f})
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
|
|
||||||
find_path(ASIOSDK_ROOT_DIR
|
|
||||||
common/asio.h
|
|
||||||
HINTS
|
|
||||||
${ASIOSDK_PATH_HINT}
|
|
||||||
)
|
|
||||||
|
|
||||||
find_path(ASIOSDK_INCLUDE_DIR
|
|
||||||
asio.h
|
|
||||||
PATHS
|
|
||||||
${ASIOSDK_ROOT_DIR}/common
|
|
||||||
)
|
|
||||||
|
|
||||||
# handle the QUIETLY and REQUIRED arguments and set ASIOSDK_FOUND to TRUE if
|
|
||||||
# all listed variables are TRUE
|
|
||||||
INCLUDE(FindPackageHandleStandardArgs)
|
|
||||||
FIND_PACKAGE_HANDLE_STANDARD_ARGS(ASIOSDK DEFAULT_MSG ASIOSDK_ROOT_DIR ASIOSDK_INCLUDE_DIR)
|
|
||||||
|
|
||||||
MARK_AS_ADVANCED(
|
|
||||||
ASIOSDK_ROOT_DIR ASIOSDK_INCLUDE_DIR
|
|
||||||
)
|
|
|
@ -1,59 +0,0 @@
|
||||||
# $Id: $
|
|
||||||
#
|
|
||||||
# - Try to find the DirectX SDK
|
|
||||||
# Once done this will define
|
|
||||||
#
|
|
||||||
# DXSDK_FOUND - system has DirectX SDK
|
|
||||||
# DXSDK_ROOT_DIR - path to the DirectX SDK base directory
|
|
||||||
# DXSDK_INCLUDE_DIR - the DirectX SDK include directory
|
|
||||||
# DXSDK_LIBRARY_DIR - DirectX SDK libraries path
|
|
||||||
#
|
|
||||||
# DXSDK_DSOUND_LIBRARY - Path to dsound.lib
|
|
||||||
#
|
|
||||||
|
|
||||||
if(WIN32)
|
|
||||||
else(WIN32)
|
|
||||||
message(FATAL_ERROR "FindDXSDK.cmake: Unsupported platform ${CMAKE_SYSTEM_NAME}" )
|
|
||||||
endif(WIN32)
|
|
||||||
|
|
||||||
find_path(DXSDK_ROOT_DIR
|
|
||||||
include/dxsdkver.h
|
|
||||||
HINTS
|
|
||||||
$ENV{DXSDK_DIR}
|
|
||||||
)
|
|
||||||
|
|
||||||
find_path(DXSDK_INCLUDE_DIR
|
|
||||||
dxsdkver.h
|
|
||||||
PATHS
|
|
||||||
${DXSDK_ROOT_DIR}/include
|
|
||||||
)
|
|
||||||
|
|
||||||
IF(CMAKE_CL_64)
|
|
||||||
find_path(DXSDK_LIBRARY_DIR
|
|
||||||
dsound.lib
|
|
||||||
PATHS
|
|
||||||
${DXSDK_ROOT_DIR}/lib/x64
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
find_path(DXSDK_LIBRARY_DIR
|
|
||||||
dsound.lib
|
|
||||||
PATHS
|
|
||||||
${DXSDK_ROOT_DIR}/lib/x86
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
|
|
||||||
find_library(DXSDK_DSOUND_LIBRARY
|
|
||||||
dsound.lib
|
|
||||||
PATHS
|
|
||||||
${DXSDK_LIBRARY_DIR}
|
|
||||||
)
|
|
||||||
|
|
||||||
# handle the QUIETLY and REQUIRED arguments and set DXSDK_FOUND to TRUE if
|
|
||||||
# all listed variables are TRUE
|
|
||||||
INCLUDE(FindPackageHandleStandardArgs)
|
|
||||||
FIND_PACKAGE_HANDLE_STANDARD_ARGS(DXSDK DEFAULT_MSG DXSDK_ROOT_DIR DXSDK_INCLUDE_DIR)
|
|
||||||
|
|
||||||
MARK_AS_ADVANCED(
|
|
||||||
DXSDK_ROOT_DIR DXSDK_INCLUDE_DIR
|
|
||||||
DXSDK_LIBRARY_DIR DXSDK_DSOUND_LIBRARY
|
|
||||||
)
|
|
|
@ -1,41 +0,0 @@
|
||||||
# - Try to find jack
|
|
||||||
# Once done this will define
|
|
||||||
# JACK_FOUND - System has jack
|
|
||||||
# JACK_INCLUDE_DIRS - The jack include directories
|
|
||||||
# JACK_LIBRARIES - The libraries needed to use jack
|
|
||||||
# JACK_DEFINITIONS - Compiler switches required for using jack
|
|
||||||
|
|
||||||
if (JACK_LIBRARIES AND JACK_INCLUDE_DIRS)
|
|
||||||
|
|
||||||
# in cache already
|
|
||||||
set(JACK_FOUND TRUE)
|
|
||||||
|
|
||||||
else (JACK_LIBRARIES AND JACK_INCLUDE_DIRS)
|
|
||||||
|
|
||||||
set(JACK_DEFINITIONS "")
|
|
||||||
|
|
||||||
# Look for pkg-config and use it (if available) to find package
|
|
||||||
find_package(PkgConfig QUIET)
|
|
||||||
if (PKG_CONFIG_FOUND)
|
|
||||||
pkg_search_module(JACK QUIET jack)
|
|
||||||
endif (PKG_CONFIG_FOUND)
|
|
||||||
|
|
||||||
if (NOT JACK_FOUND)
|
|
||||||
|
|
||||||
find_path(JACK_INCLUDE_DIR jack/jack.h HINTS ${JACK_INCLUDEDIR} ${JACK_INCLUDE_DIRS} PATH_SUFFIXES jack)
|
|
||||||
find_library(JACK_LIBRARY NAMES jack HINTS ${JACK_LIBDIR} ${JACK_LIBRARY_DIRS})
|
|
||||||
|
|
||||||
set(JACK_LIBRARIES ${JACK_LIBRARY})
|
|
||||||
set(JACK_INCLUDE_DIRS ${JACK_INCLUDE_DIR})
|
|
||||||
|
|
||||||
include(FindPackageHandleStandardArgs)
|
|
||||||
|
|
||||||
# Set JACK_FOUND if the library and include paths were found
|
|
||||||
find_package_handle_standard_args(jack DEFAULT_MSG JACK_LIBRARY JACK_INCLUDE_DIR)
|
|
||||||
|
|
||||||
# Don't show include/library paths in cmake GUI
|
|
||||||
mark_as_advanced(JACK_INCLUDE_DIR JACK_LIBRARY)
|
|
||||||
|
|
||||||
endif (NOT JACK_FOUND)
|
|
||||||
|
|
||||||
endif (JACK_LIBRARIES AND JACK_INCLUDE_DIRS)
|
|
|
@ -1,21 +0,0 @@
|
||||||
if(NOT EXISTS "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt")
|
|
||||||
message(FATAL_ERROR "Cannot find install manifest: @CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt")
|
|
||||||
endif(NOT EXISTS "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt")
|
|
||||||
|
|
||||||
file(READ "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt" files)
|
|
||||||
string(REGEX REPLACE "\n" ";" files "${files}")
|
|
||||||
foreach(file ${files})
|
|
||||||
message(STATUS "Uninstalling $ENV{DESTDIR}${file}")
|
|
||||||
if(IS_SYMLINK "$ENV{DESTDIR}${file}" OR EXISTS "$ENV{DESTDIR}${file}")
|
|
||||||
exec_program(
|
|
||||||
"@CMAKE_COMMAND@" ARGS "-E remove \"$ENV{DESTDIR}${file}\""
|
|
||||||
OUTPUT_VARIABLE rm_out
|
|
||||||
RETURN_VALUE rm_retval
|
|
||||||
)
|
|
||||||
if(NOT "${rm_retval}" STREQUAL 0)
|
|
||||||
message(FATAL_ERROR "Problem when removing $ENV{DESTDIR}${file}")
|
|
||||||
endif(NOT "${rm_retval}" STREQUAL 0)
|
|
||||||
else(IS_SYMLINK "$ENV{DESTDIR}${file}" OR EXISTS "$ENV{DESTDIR}${file}")
|
|
||||||
message(STATUS "File $ENV{DESTDIR}${file} does not exist.")
|
|
||||||
endif(IS_SYMLINK "$ENV{DESTDIR}${file}" OR EXISTS "$ENV{DESTDIR}${file}")
|
|
||||||
endforeach(file)
|
|
|
@ -1,31 +0,0 @@
|
||||||
/* $Id: $
|
|
||||||
|
|
||||||
!!! @GENERATED_MESSAGE@ !!!
|
|
||||||
|
|
||||||
Header file configured by CMake to convert CMake options/vars to macros. It is done this way because if set via
|
|
||||||
preprocessor options, MSVC f.i. has no way of knowing when an option (or var) changes as there is no dependency chain.
|
|
||||||
|
|
||||||
The generated "options_cmake.h" should be included like so:
|
|
||||||
|
|
||||||
#ifdef PORTAUDIO_CMAKE_GENERATED
|
|
||||||
#include "options_cmake.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
so that non-CMake build environments are left intact.
|
|
||||||
|
|
||||||
Source template: cmake_support/options_cmake.h.in
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
#if defined(PA_USE_ASIO) || defined(PA_USE_DS) || defined(PA_USE_WMME) || defined(PA_USE_WASAPI) || defined(PA_USE_WDMKS)
|
|
||||||
#error "This header needs to be included before pa_hostapi.h!!"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#cmakedefine01 PA_USE_ASIO
|
|
||||||
#cmakedefine01 PA_USE_DS
|
|
||||||
#cmakedefine01 PA_USE_WMME
|
|
||||||
#cmakedefine01 PA_USE_WASAPI
|
|
||||||
#cmakedefine01 PA_USE_WDMKS
|
|
||||||
#else
|
|
||||||
#error "Platform currently not supported by CMake script"
|
|
||||||
#endif
|
|
|
@ -1,12 +0,0 @@
|
||||||
prefix=@CMAKE_INSTALL_PREFIX@
|
|
||||||
exec_prefix=${prefix}
|
|
||||||
libdir=${prefix}/lib
|
|
||||||
includedir=${prefix}/include
|
|
||||||
|
|
||||||
Name: PortAudio
|
|
||||||
Description: Portable audio I/O
|
|
||||||
Requires:
|
|
||||||
Version: @PA_PKGCONFIG_VERSION@
|
|
||||||
|
|
||||||
Libs: -L${libdir} -lportaudio @PA_PKGCONFIG_LDFLAGS@
|
|
||||||
Cflags: -I${includedir} @PA_PKGCONFIG_CFLAGS@
|
|
|
@ -1 +0,0 @@
|
||||||
include("${CMAKE_CURRENT_LIST_DIR}/portaudioTargets.cmake")
|
|
|
@ -1,53 +0,0 @@
|
||||||
; $Id: $
|
|
||||||
;
|
|
||||||
; !!! @GENERATED_MESSAGE@ !!!
|
|
||||||
EXPORTS
|
|
||||||
|
|
||||||
;
|
|
||||||
Pa_GetVersion @1
|
|
||||||
Pa_GetVersionText @2
|
|
||||||
Pa_GetErrorText @3
|
|
||||||
Pa_Initialize @4
|
|
||||||
Pa_Terminate @5
|
|
||||||
Pa_GetHostApiCount @6
|
|
||||||
Pa_GetDefaultHostApi @7
|
|
||||||
Pa_GetHostApiInfo @8
|
|
||||||
Pa_HostApiTypeIdToHostApiIndex @9
|
|
||||||
Pa_HostApiDeviceIndexToDeviceIndex @10
|
|
||||||
Pa_GetLastHostErrorInfo @11
|
|
||||||
Pa_GetDeviceCount @12
|
|
||||||
Pa_GetDefaultInputDevice @13
|
|
||||||
Pa_GetDefaultOutputDevice @14
|
|
||||||
Pa_GetDeviceInfo @15
|
|
||||||
Pa_IsFormatSupported @16
|
|
||||||
Pa_OpenStream @17
|
|
||||||
Pa_OpenDefaultStream @18
|
|
||||||
Pa_CloseStream @19
|
|
||||||
Pa_SetStreamFinishedCallback @20
|
|
||||||
Pa_StartStream @21
|
|
||||||
Pa_StopStream @22
|
|
||||||
Pa_AbortStream @23
|
|
||||||
Pa_IsStreamStopped @24
|
|
||||||
Pa_IsStreamActive @25
|
|
||||||
Pa_GetStreamInfo @26
|
|
||||||
Pa_GetStreamTime @27
|
|
||||||
Pa_GetStreamCpuLoad @28
|
|
||||||
Pa_ReadStream @29
|
|
||||||
Pa_WriteStream @30
|
|
||||||
Pa_GetStreamReadAvailable @31
|
|
||||||
Pa_GetStreamWriteAvailable @32
|
|
||||||
Pa_GetSampleSize @33
|
|
||||||
Pa_Sleep @34
|
|
||||||
@DEF_EXCLUDE_ASIO_SYMBOLS@PaAsio_GetAvailableBufferSizes @50
|
|
||||||
@DEF_EXCLUDE_ASIO_SYMBOLS@PaAsio_ShowControlPanel @51
|
|
||||||
@DEF_EXCLUDE_X86_PLAIN_CONVERTERS@PaUtil_InitializeX86PlainConverters @52
|
|
||||||
@DEF_EXCLUDE_ASIO_SYMBOLS@PaAsio_GetInputChannelName @53
|
|
||||||
@DEF_EXCLUDE_ASIO_SYMBOLS@PaAsio_GetOutputChannelName @54
|
|
||||||
PaUtil_SetDebugPrintFunction @55
|
|
||||||
@DEF_EXCLUDE_WASAPI_SYMBOLS@PaWasapi_GetDeviceDefaultFormat @56
|
|
||||||
@DEF_EXCLUDE_WASAPI_SYMBOLS@PaWasapi_GetDeviceRole @57
|
|
||||||
@DEF_EXCLUDE_WASAPI_SYMBOLS@PaWasapi_ThreadPriorityBoost @58
|
|
||||||
@DEF_EXCLUDE_WASAPI_SYMBOLS@PaWasapi_ThreadPriorityRevert @59
|
|
||||||
@DEF_EXCLUDE_WASAPI_SYMBOLS@PaWasapi_GetFramesPerHostBuffer @60
|
|
||||||
@DEF_EXCLUDE_WASAPI_SYMBOLS@PaWasapi_GetJackDescription @61
|
|
||||||
@DEF_EXCLUDE_WASAPI_SYMBOLS@PaWasapi_GetJackCount @62
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,525 +0,0 @@
|
||||||
dnl
|
|
||||||
dnl portaudio V19 configure.in script
|
|
||||||
dnl
|
|
||||||
dnl Dominic Mazzoni, Arve Knudsen, Stelios Bounanos
|
|
||||||
dnl
|
|
||||||
|
|
||||||
dnl Require autoconf >= 2.13
|
|
||||||
AC_PREREQ(2.13)
|
|
||||||
|
|
||||||
dnl Init autoconf and make sure configure is being called
|
|
||||||
dnl from the right directory
|
|
||||||
AC_INIT([include/portaudio.h])
|
|
||||||
|
|
||||||
dnl Define build, build_cpu, build_vendor, build_os
|
|
||||||
AC_CANONICAL_BUILD
|
|
||||||
dnl Define host, host_cpu, host_vendor, host_os
|
|
||||||
AC_CANONICAL_HOST
|
|
||||||
dnl Define target, target_cpu, target_vendor, target_os
|
|
||||||
AC_CANONICAL_TARGET
|
|
||||||
|
|
||||||
dnl Specify options
|
|
||||||
|
|
||||||
AC_ARG_WITH(alsa,
|
|
||||||
AS_HELP_STRING([--with-alsa], [Enable support for ALSA @<:@autodetect@:>@]),
|
|
||||||
[with_alsa=$withval])
|
|
||||||
|
|
||||||
AC_ARG_WITH(jack,
|
|
||||||
AS_HELP_STRING([--with-jack], [Enable support for JACK @<:@autodetect@:>@]),
|
|
||||||
[with_jack=$withval])
|
|
||||||
|
|
||||||
AC_ARG_WITH(oss,
|
|
||||||
AS_HELP_STRING([--with-oss], [Enable support for OSS @<:@autodetect@:>@]),
|
|
||||||
[with_oss=$withval])
|
|
||||||
|
|
||||||
AC_ARG_WITH(asihpi,
|
|
||||||
AS_HELP_STRING([--with-asihpi], [Enable support for ASIHPI @<:@autodetect@:>@]),
|
|
||||||
[with_asihpi=$withval])
|
|
||||||
|
|
||||||
AC_ARG_WITH(winapi,
|
|
||||||
AS_HELP_STRING([--with-winapi],
|
|
||||||
[Select Windows API support (@<:@wmme|directx|asio|wasapi|wdmks@:>@@<:@,...@:>@) @<:@wmme@:>@]),
|
|
||||||
[with_winapi=$withval], [with_winapi="wmme"])
|
|
||||||
case "$target_os" in *mingw* | *cygwin*)
|
|
||||||
with_wmme=no
|
|
||||||
with_directx=no
|
|
||||||
with_asio=no
|
|
||||||
with_wasapi=no
|
|
||||||
with_wdmks=no
|
|
||||||
for api in $(echo $with_winapi | sed 's/,/ /g'); do
|
|
||||||
case "$api" in
|
|
||||||
wmme|directx|asio|wasapi|wdmks)
|
|
||||||
eval with_$api=yes
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
AC_MSG_ERROR([unknown Windows API \"$api\" (do you need --help?)])
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
AC_ARG_WITH(asiodir,
|
|
||||||
AS_HELP_STRING([--with-asiodir], [ASIO directory @<:@/usr/local/asiosdk2@:>@]),
|
|
||||||
with_asiodir=$withval, with_asiodir="/usr/local/asiosdk2")
|
|
||||||
|
|
||||||
AC_ARG_WITH(dxdir,
|
|
||||||
AS_HELP_STRING([--with-dxdir], [DirectX directory @<:@/usr/local/dx7sdk@:>@]),
|
|
||||||
with_dxdir=$withval, with_dxdir="/usr/local/dx7sdk")
|
|
||||||
|
|
||||||
debug_output=no
|
|
||||||
AC_ARG_ENABLE(debug-output,
|
|
||||||
AS_HELP_STRING([--enable-debug-output], [Enable debug output @<:@no@:>@]),
|
|
||||||
[if test "x$enableval" != "xno" ; then
|
|
||||||
AC_DEFINE(PA_ENABLE_DEBUG_OUTPUT,,[Enable debugging messages])
|
|
||||||
debug_output=yes
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_ARG_ENABLE(cxx,
|
|
||||||
AS_HELP_STRING([--enable-cxx], [Enable C++ bindings @<:@no@:>@]),
|
|
||||||
enable_cxx=$enableval, enable_cxx="no")
|
|
||||||
|
|
||||||
AC_ARG_ENABLE(mac-debug,
|
|
||||||
AS_HELP_STRING([--enable-mac-debug], [Enable Mac debug @<:@no@:>@]),
|
|
||||||
enable_mac_debug=$enableval, enable_mac_debug="no")
|
|
||||||
|
|
||||||
AC_ARG_ENABLE(mac-universal,
|
|
||||||
AS_HELP_STRING([--enable-mac-universal], [Build Mac universal binaries @<:@yes@:>@]),
|
|
||||||
enable_mac_universal=$enableval, enable_mac_universal="yes")
|
|
||||||
|
|
||||||
dnl Continue to accept --host_os for compatibility but do not document
|
|
||||||
dnl it (the correct way to change host_os is with --host=...). Moved
|
|
||||||
dnl here because the empty help string generates a blank line which we
|
|
||||||
dnl can use to separate PA options from libtool options.
|
|
||||||
AC_ARG_WITH(host_os, [], host_os=$withval)
|
|
||||||
|
|
||||||
dnl Checks for programs.
|
|
||||||
|
|
||||||
AC_PROG_CC
|
|
||||||
dnl ASIO and CXX bindings need a C++ compiler
|
|
||||||
if [[ "$with_asio" = "yes" ] || [ "$enable_cxx" = "yes" ]] ; then
|
|
||||||
AC_PROG_CXX
|
|
||||||
fi
|
|
||||||
AC_LIBTOOL_WIN32_DLL
|
|
||||||
AC_PROG_LIBTOOL
|
|
||||||
AC_PROG_INSTALL
|
|
||||||
AC_PROG_LN_S
|
|
||||||
AC_PATH_PROG(AR, ar, no)
|
|
||||||
if [[ $AR = "no" ]] ; then
|
|
||||||
AC_MSG_ERROR("Could not find ar - needed to create a library")
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl This must be one of the first tests we do or it will fail...
|
|
||||||
AC_C_BIGENDIAN
|
|
||||||
|
|
||||||
dnl checks for various host APIs and arguments to configure that
|
|
||||||
dnl turn them on or off
|
|
||||||
|
|
||||||
have_alsa=no
|
|
||||||
if test "x$with_alsa" != "xno"; then
|
|
||||||
AC_CHECK_LIB(asound, snd_pcm_open, have_alsa=yes, have_alsa=no)
|
|
||||||
fi
|
|
||||||
have_asihpi=no
|
|
||||||
if test "x$with_asihpi" != "xno"; then
|
|
||||||
AC_CHECK_LIB(hpi, HPI_SubSysCreate, have_asihpi=yes, have_asihpi=no, -lm)
|
|
||||||
fi
|
|
||||||
have_libossaudio=no
|
|
||||||
have_oss=no
|
|
||||||
if test "x$with_oss" != "xno"; then
|
|
||||||
AC_CHECK_HEADERS([sys/soundcard.h linux/soundcard.h machine/soundcard.h], [have_oss=yes])
|
|
||||||
if test "x$have_oss" = "xyes"; then
|
|
||||||
AC_CHECK_LIB(ossaudio, _oss_ioctl, have_libossaudio=yes, have_libossaudio=no)
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
have_jack=no
|
|
||||||
if test "x$with_jack" != "xno"; then
|
|
||||||
PKG_CHECK_MODULES(JACK, jack, have_jack=yes, have_jack=no)
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
dnl sizeof checks: we will need a 16-bit and a 32-bit type
|
|
||||||
|
|
||||||
AC_CHECK_SIZEOF(short)
|
|
||||||
AC_CHECK_SIZEOF(int)
|
|
||||||
AC_CHECK_SIZEOF(long)
|
|
||||||
|
|
||||||
save_LIBS="${LIBS}"
|
|
||||||
AC_CHECK_LIB(rt, clock_gettime, [rt_libs=" -lrt"])
|
|
||||||
LIBS="${LIBS}${rt_libs}"
|
|
||||||
DLL_LIBS="${DLL_LIBS}${rt_libs}"
|
|
||||||
AC_CHECK_FUNCS([clock_gettime nanosleep])
|
|
||||||
LIBS="${save_LIBS}"
|
|
||||||
|
|
||||||
dnl LT_RELEASE=19
|
|
||||||
LT_CURRENT=2
|
|
||||||
LT_REVISION=0
|
|
||||||
LT_AGE=0
|
|
||||||
|
|
||||||
AC_SUBST(LT_CURRENT)
|
|
||||||
AC_SUBST(LT_REVISION)
|
|
||||||
AC_SUBST(LT_AGE)
|
|
||||||
|
|
||||||
dnl extra variables
|
|
||||||
AC_SUBST(OTHER_OBJS)
|
|
||||||
AC_SUBST(PADLL)
|
|
||||||
AC_SUBST(SHARED_FLAGS)
|
|
||||||
AC_SUBST(THREAD_CFLAGS)
|
|
||||||
AC_SUBST(DLL_LIBS)
|
|
||||||
AC_SUBST(CXXFLAGS)
|
|
||||||
AC_SUBST(NASM)
|
|
||||||
AC_SUBST(NASMOPT)
|
|
||||||
AC_SUBST(INCLUDES)
|
|
||||||
|
|
||||||
dnl -g is optional on darwin
|
|
||||||
if ( echo "${host_os}" | grep ^darwin >> /dev/null ) &&
|
|
||||||
[[ "$enable_mac_universal" = "yes" ] &&
|
|
||||||
[ "$enable_mac_debug" != "yes" ]] ; then
|
|
||||||
CFLAGS="-O2 -Wall -pedantic -pipe -fPIC -DNDEBUG"
|
|
||||||
else
|
|
||||||
CFLAGS=${CFLAGS:-"-g -O2 -Wall -pedantic -pipe -fPIC"}
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ $ac_cv_c_bigendian = "yes" ]] ; then
|
|
||||||
CFLAGS="$CFLAGS -DPA_BIG_ENDIAN"
|
|
||||||
else
|
|
||||||
CFLAGS="$CFLAGS -DPA_LITTLE_ENDIAN"
|
|
||||||
fi
|
|
||||||
|
|
||||||
add_objects()
|
|
||||||
{
|
|
||||||
for o in $@; do
|
|
||||||
test "${OTHER_OBJS#*${o}*}" = "${OTHER_OBJS}" && OTHER_OBJS="$OTHER_OBJS $o"
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
INCLUDES=portaudio.h
|
|
||||||
|
|
||||||
dnl Include directories needed by all implementations
|
|
||||||
CFLAGS="$CFLAGS -I\$(top_srcdir)/include -I\$(top_srcdir)/src/common"
|
|
||||||
|
|
||||||
case "${host_os}" in
|
|
||||||
darwin* )
|
|
||||||
dnl Mac OS X configuration
|
|
||||||
|
|
||||||
AC_DEFINE(PA_USE_COREAUDIO,1)
|
|
||||||
|
|
||||||
CFLAGS="$CFLAGS -I\$(top_srcdir)/src/os/unix -Wno-deprecated -Werror"
|
|
||||||
LIBS="-framework CoreAudio -framework AudioToolbox -framework AudioUnit -framework Carbon"
|
|
||||||
|
|
||||||
if test "x$enable_mac_universal" = "xyes" ; then
|
|
||||||
case `xcodebuild -version | sed -n 's/Xcode \(.*\)/\1/p'` in
|
|
||||||
|
|
||||||
3.0|3.1)
|
|
||||||
dnl In pre-3.2 versions of Xcode, xcodebuild doesn't
|
|
||||||
dnl support -sdk, so we can't use that to look for
|
|
||||||
dnl SDKs. However, in those versions of Xcode, the
|
|
||||||
dnl SDKs are under /Developer/SDKs, so we can just look
|
|
||||||
dnl there. Also, we assume they had no SDKs later
|
|
||||||
dnl than 10.5, as 3.2 was the version that came with
|
|
||||||
dnl 10.6, at least if the Wikipedia page for Xcode
|
|
||||||
dnl is to be believed.
|
|
||||||
if [[ -d /Developer/SDKs/MacOSX10.5.sdk ]] ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.3"
|
|
||||||
mac_sysroot="-isysroot /Developer/SDKs/MacOSX10.5.sdk"
|
|
||||||
else
|
|
||||||
mac_version_min="-mmacosx-version-min=10.3"
|
|
||||||
mac_sysroot="-isysroot /Developer/SDKs/MacOSX10.4u.sdk"
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
dnl In 3.2 and later, xcodebuild supports -sdk, and, in
|
|
||||||
dnl 4.3 and later, the SDKs aren't under /Developer/SDKs
|
|
||||||
dnl as there *is* no /Developer, so we use -sdk to check
|
|
||||||
dnl what SDKs are available and to get the full path of
|
|
||||||
dnl the SDKs.
|
|
||||||
if xcodebuild -version -sdk macosx10.5 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.3"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.5 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.6 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.6 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.7 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.7 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.8 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.8 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.9 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.9 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.10 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.10 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.11 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.11 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.12 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.12 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.13 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.13 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.14 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.14 Path`"
|
|
||||||
elif xcodebuild -version -sdk macosx10.15 Path >/dev/null 2>&1 ; then
|
|
||||||
mac_version_min="-mmacosx-version-min=10.4"
|
|
||||||
mac_sysroot="-isysroot `xcodebuild -version -sdk macosx10.15 Path`"
|
|
||||||
else
|
|
||||||
AC_MSG_ERROR([Could not find 10.5 to 10.13 SDK.])
|
|
||||||
fi
|
|
||||||
esac
|
|
||||||
|
|
||||||
dnl Pick which architectures to build for based on what
|
|
||||||
dnl the compiler supports.
|
|
||||||
mac_arches=""
|
|
||||||
for arch in x86_64
|
|
||||||
do
|
|
||||||
save_CFLAGS="$CFLAGS"
|
|
||||||
CFLAGS="$CFLAGS -arch $arch"
|
|
||||||
AC_TRY_COMPILE([], [return 0;],
|
|
||||||
[
|
|
||||||
if [[ -z "$mac_arches" ]] ; then
|
|
||||||
mac_arches="-arch $arch"
|
|
||||||
else
|
|
||||||
mac_arches="$mac_arches -arch $arch"
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
CFLAGS="$save_CFLAGS"
|
|
||||||
done
|
|
||||||
else
|
|
||||||
mac_arches=""
|
|
||||||
mac_sysroot=""
|
|
||||||
mac_version=""
|
|
||||||
fi
|
|
||||||
SHARED_FLAGS="$LIBS -dynamiclib $mac_arches $mac_sysroot $mac_version_min"
|
|
||||||
CFLAGS="-std=c99 $CFLAGS $mac_arches $mac_sysroot $mac_version_min"
|
|
||||||
OTHER_OBJS="src/os/unix/pa_unix_hostapis.o src/os/unix/pa_unix_util.o src/hostapi/coreaudio/pa_mac_core.o src/hostapi/coreaudio/pa_mac_core_utilities.o src/hostapi/coreaudio/pa_mac_core_blocking.o src/common/pa_ringbuffer.o"
|
|
||||||
PADLL="libportaudio.dylib"
|
|
||||||
;;
|
|
||||||
|
|
||||||
mingw* )
|
|
||||||
dnl MingW configuration
|
|
||||||
|
|
||||||
PADLL="portaudio.dll"
|
|
||||||
THREAD_CFLAGS="-mthreads"
|
|
||||||
SHARED_FLAGS="-shared"
|
|
||||||
CFLAGS="$CFLAGS -I\$(top_srcdir)/src/os/win -DPA_USE_WMME=0 -DPA_USE_ASIO=0 -DPA_USE_WDMKS=0 -DPA_USE_DS=0 -DPA_USE_WASAPI=0"
|
|
||||||
|
|
||||||
if [[ "x$with_directx" = "xyes" ]]; then
|
|
||||||
DXDIR="$with_dxdir"
|
|
||||||
add_objects src/hostapi/dsound/pa_win_ds.o src/hostapi/dsound/pa_win_ds_dynlink.o src/os/win/pa_win_hostapis.o src/os/win/pa_win_util.o src/os/win/pa_win_coinitialize.o src/os/win/pa_win_waveformat.o
|
|
||||||
LIBS="${LIBS} -lwinmm -lm -ldsound -lole32"
|
|
||||||
DLL_LIBS="${DLL_LIBS} -lwinmm -lm -L$DXDIR/lib -ldsound -lole32"
|
|
||||||
#VC98="\"/c/Program Files/Microsoft Visual Studio/VC98/Include\""
|
|
||||||
#CFLAGS="$CFLAGS -I$VC98 -DPA_NO_WMME -DPA_NO_ASIO"
|
|
||||||
CFLAGS="$CFLAGS -I$DXDIR/include -UPA_USE_DS -DPA_USE_DS=1"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "x$with_asio" = "xyes" ]]; then
|
|
||||||
ASIODIR="$with_asiodir"
|
|
||||||
add_objects src/hostapi/asio/pa_asio.o src/common/pa_ringbuffer.o src/os/win/pa_win_hostapis.o src/os/win/pa_win_util.o src/os/win/pa_win_coinitialize.o src/hostapi/asio/iasiothiscallresolver.o $ASIODIR/common/asio.o $ASIODIR/host/asiodrivers.o $ASIODIR/host/pc/asiolist.o
|
|
||||||
LIBS="${LIBS} -lwinmm -lm -lole32 -luuid"
|
|
||||||
DLL_LIBS="${DLL_LIBS} -lwinmm -lm -lole32 -luuid"
|
|
||||||
CFLAGS="$CFLAGS -ffast-math -fomit-frame-pointer -I\$(top_srcdir)/src/hostapi/asio -I$ASIODIR/host/pc -I$ASIODIR/common -I$ASIODIR/host -UPA_USE_ASIO -DPA_USE_ASIO=1 -DWINDOWS"
|
|
||||||
|
|
||||||
dnl Setting the windows version flags below resolves a conflict between Interlocked*
|
|
||||||
dnl definitions in mingw winbase.h and Interlocked* hacks in ASIO SDK combase.h
|
|
||||||
dnl combase.h is included by asiodrvr.h
|
|
||||||
dnl PortAudio does not actually require Win XP (winver 501) APIs
|
|
||||||
CFLAGS="$CFLAGS -D_WIN32_WINNT=0x0501 -DWINVER=0x0501"
|
|
||||||
|
|
||||||
CXXFLAGS="$CFLAGS"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "x$with_wdmks" = "xyes" ]]; then
|
|
||||||
DXDIR="$with_dxdir"
|
|
||||||
add_objects src/hostapi/wdmks/pa_win_wdmks.o src/common/pa_ringbuffer.o src/os/win/pa_win_hostapis.o src/os/win/pa_win_util.o src/os/win/pa_win_wdmks_utils.o src/os/win/pa_win_waveformat.o
|
|
||||||
LIBS="${LIBS} -lwinmm -lm -luuid -lsetupapi -lole32"
|
|
||||||
DLL_LIBS="${DLL_LIBS} -lwinmm -lm -L$DXDIR/lib -luuid -lsetupapi -lole32"
|
|
||||||
#VC98="\"/c/Program Files/Microsoft Visual Studio/VC98/Include\""
|
|
||||||
#CFLAGS="$CFLAGS -I$VC98 -DPA_NO_WMME -DPA_NO_ASIO"
|
|
||||||
CFLAGS="$CFLAGS -I$DXDIR/include -UPA_USE_WDMKS -DPA_USE_WDMKS=1"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "x$with_wmme" = "xyes" ]]; then
|
|
||||||
add_objects src/hostapi/wmme/pa_win_wmme.o src/os/win/pa_win_hostapis.o src/os/win/pa_win_util.o src/os/win/pa_win_waveformat.o
|
|
||||||
LIBS="${LIBS} -lwinmm -lm -lole32 -luuid"
|
|
||||||
DLL_LIBS="${DLL_LIBS} -lwinmm"
|
|
||||||
CFLAGS="$CFLAGS -UPA_USE_WMME -DPA_USE_WMME=1"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "x$with_wasapi" = "xyes" ]]; then
|
|
||||||
add_objects src/hostapi/wasapi/pa_win_wasapi.o src/common/pa_ringbuffer.o src/os/win/pa_win_hostapis.o src/os/win/pa_win_util.o src/os/win/pa_win_coinitialize.o src/os/win/pa_win_waveformat.o
|
|
||||||
LIBS="${LIBS} -lwinmm -lm -lole32 -luuid"
|
|
||||||
DLL_LIBS="${DLL_LIBS} -lwinmm -lole32"
|
|
||||||
CFLAGS="$CFLAGS -UPA_USE_WASAPI -DPA_USE_WASAPI=1"
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
cygwin* )
|
|
||||||
dnl Cygwin configuration
|
|
||||||
|
|
||||||
OTHER_OBJS="src/hostapi/wmme/pa_win_wmme.o src/os/win/pa_win_hostapis.o src/os/win/pa_win_util.o src/os/win/pa_win_waveformat.o"
|
|
||||||
CFLAGS="$CFLAGS -I\$(top_srcdir)/src/os/win -DPA_USE_DS=0 -DPA_USE_WDMKS=0 -DPA_USE_ASIO=0 -DPA_USE_WASAPI=0 -DPA_USE_WMME=1"
|
|
||||||
LIBS="-lwinmm -lm"
|
|
||||||
PADLL="portaudio.dll"
|
|
||||||
THREAD_CFLAGS="-mthreads"
|
|
||||||
SHARED_FLAGS="-shared"
|
|
||||||
DLL_LIBS="${DLL_LIBS} -lwinmm"
|
|
||||||
;;
|
|
||||||
|
|
||||||
irix* )
|
|
||||||
dnl SGI IRIX audio library (AL) configuration (Pieter, oct 2-13, 2003).
|
|
||||||
dnl The 'dmedia' library is needed to read the Unadjusted System Time (UST).
|
|
||||||
dnl
|
|
||||||
AC_CHECK_LIB(pthread, pthread_create, , AC_MSG_ERROR([IRIX posix thread library not found!]))
|
|
||||||
AC_CHECK_LIB(audio, alOpenPort, , AC_MSG_ERROR([IRIX audio library not found!]))
|
|
||||||
AC_CHECK_LIB(dmedia, dmGetUST, , AC_MSG_ERROR([IRIX digital media library not found!]))
|
|
||||||
|
|
||||||
dnl See the '#ifdef PA_USE_SGI' in file pa_unix/pa_unix_hostapis.c
|
|
||||||
dnl which selects the appropriate PaXXX_Initialize() function.
|
|
||||||
dnl
|
|
||||||
AC_DEFINE(PA_USE_SGI,1)
|
|
||||||
|
|
||||||
CFLAGS="$CFLAGS -I\$(top_srcdir)/src/os/unix"
|
|
||||||
|
|
||||||
dnl The _REENTRANT option for pthread safety. Perhaps not necessary but it 'll do no harm.
|
|
||||||
dnl
|
|
||||||
THREAD_CFLAGS="-D_REENTRANT"
|
|
||||||
|
|
||||||
OTHER_OBJS="pa_sgi/pa_sgi.o src/os/unix/pa_unix_hostapis.o src/os/unix/pa_unix_util.o"
|
|
||||||
|
|
||||||
dnl SGI books say -lpthread should be the last of the libs mentioned.
|
|
||||||
dnl
|
|
||||||
LIBS="-lm -ldmedia -laudio -lpthread"
|
|
||||||
PADLL="libportaudio.so"
|
|
||||||
SHARED_FLAGS=""
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
dnl Unix configuration
|
|
||||||
|
|
||||||
CFLAGS="$CFLAGS -I\$(top_srcdir)/src/os/unix"
|
|
||||||
|
|
||||||
AC_CHECK_LIB(pthread, pthread_create,[have_pthread="yes"],
|
|
||||||
AC_MSG_ERROR([libpthread not found!]))
|
|
||||||
|
|
||||||
if [[ "$have_alsa" = "yes" ] && [ "$with_alsa" != "no" ]] ; then
|
|
||||||
DLL_LIBS="$DLL_LIBS -lasound"
|
|
||||||
LIBS="$LIBS -lasound"
|
|
||||||
OTHER_OBJS="$OTHER_OBJS src/hostapi/alsa/pa_linux_alsa.o"
|
|
||||||
INCLUDES="$INCLUDES pa_linux_alsa.h"
|
|
||||||
AC_DEFINE(PA_USE_ALSA,1)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "$have_jack" = "yes" ] && [ "$with_jack" != "no" ]] ; then
|
|
||||||
DLL_LIBS="$DLL_LIBS $JACK_LIBS"
|
|
||||||
CFLAGS="$CFLAGS $JACK_CFLAGS"
|
|
||||||
OTHER_OBJS="$OTHER_OBJS src/hostapi/jack/pa_jack.o src/common/pa_ringbuffer.o"
|
|
||||||
INCLUDES="$INCLUDES pa_jack.h"
|
|
||||||
AC_DEFINE(PA_USE_JACK,1)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "$with_oss" != "no" ]] ; then
|
|
||||||
OTHER_OBJS="$OTHER_OBJS src/hostapi/oss/pa_unix_oss.o"
|
|
||||||
if [[ "$have_libossaudio" = "yes" ]] ; then
|
|
||||||
DLL_LIBS="$DLL_LIBS -lossaudio"
|
|
||||||
LIBS="$LIBS -lossaudio"
|
|
||||||
fi
|
|
||||||
AC_DEFINE(PA_USE_OSS,1)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "$have_asihpi" = "yes" ] && [ "$with_asihpi" != "no" ]] ; then
|
|
||||||
LIBS="$LIBS -lhpi"
|
|
||||||
DLL_LIBS="$DLL_LIBS -lhpi"
|
|
||||||
OTHER_OBJS="$OTHER_OBJS src/hostapi/asihpi/pa_linux_asihpi.o"
|
|
||||||
AC_DEFINE(PA_USE_ASIHPI,1)
|
|
||||||
fi
|
|
||||||
|
|
||||||
DLL_LIBS="$DLL_LIBS -lm -lpthread"
|
|
||||||
LIBS="$LIBS -lm -lpthread"
|
|
||||||
PADLL="libportaudio.so"
|
|
||||||
|
|
||||||
## support sun cc compiler flags
|
|
||||||
case "${host_os}" in
|
|
||||||
solaris*)
|
|
||||||
SHARED_FLAGS="-G"
|
|
||||||
THREAD_CFLAGS="-mt"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
SHARED_FLAGS="-fPIC"
|
|
||||||
THREAD_CFLAGS="-pthread"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
OTHER_OBJS="$OTHER_OBJS src/os/unix/pa_unix_hostapis.o src/os/unix/pa_unix_util.o"
|
|
||||||
esac
|
|
||||||
CFLAGS="$CFLAGS $THREAD_CFLAGS"
|
|
||||||
|
|
||||||
test "$enable_shared" != "yes" && SHARED_FLAGS=""
|
|
||||||
|
|
||||||
if test "$enable_cxx" = "yes"; then
|
|
||||||
AC_CONFIG_SUBDIRS([bindings/cpp])
|
|
||||||
ENABLE_CXX_TRUE=""
|
|
||||||
ENABLE_CXX_FALSE="#"
|
|
||||||
else
|
|
||||||
ENABLE_CXX_TRUE="#"
|
|
||||||
ENABLE_CXX_FALSE=""
|
|
||||||
fi
|
|
||||||
AC_SUBST(ENABLE_CXX_TRUE)
|
|
||||||
AC_SUBST(ENABLE_CXX_FALSE)
|
|
||||||
|
|
||||||
if test "x$with_asio" = "xyes"; then
|
|
||||||
WITH_ASIO_TRUE=""
|
|
||||||
WITH_ASIO_FALSE="@ #"
|
|
||||||
else
|
|
||||||
WITH_ASIO_TRUE="@ #"
|
|
||||||
WITH_ASIO_FALSE=""
|
|
||||||
fi
|
|
||||||
AC_SUBST(WITH_ASIO_TRUE)
|
|
||||||
AC_SUBST(WITH_ASIO_FALSE)
|
|
||||||
|
|
||||||
AC_OUTPUT([Makefile portaudio-2.0.pc])
|
|
||||||
|
|
||||||
AC_MSG_RESULT([
|
|
||||||
Configuration summary:
|
|
||||||
|
|
||||||
Target ...................... $target
|
|
||||||
C++ bindings ................ $enable_cxx
|
|
||||||
Debug output ................ $debug_output])
|
|
||||||
|
|
||||||
case "$target_os" in *linux*)
|
|
||||||
AC_MSG_RESULT([
|
|
||||||
ALSA ........................ $have_alsa
|
|
||||||
ASIHPI ...................... $have_asihpi])
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
case "$target_os" in
|
|
||||||
*mingw* | *cygwin*)
|
|
||||||
test "x$with_directx" = "xyes" && with_directx="$with_directx (${with_dxdir})"
|
|
||||||
test "x$with_wdmks" = "xyes" && with_wdmks="$with_wdmks (${with_dxdir})"
|
|
||||||
test "x$with_asio" = "xyes" && with_asio="$with_asio (${with_asiodir})"
|
|
||||||
test "x$with_wasapi" = "xyes"
|
|
||||||
AC_MSG_RESULT([
|
|
||||||
WMME ........................ $with_wmme
|
|
||||||
DSound ...................... $with_directx
|
|
||||||
ASIO ........................ $with_asio
|
|
||||||
WASAPI ...................... $with_wasapi
|
|
||||||
WDMKS ....................... $with_wdmks
|
|
||||||
])
|
|
||||||
;;
|
|
||||||
*darwin*)
|
|
||||||
AC_MSG_RESULT([
|
|
||||||
Mac debug flags ............. $enable_mac_debug
|
|
||||||
])
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
AC_MSG_RESULT([
|
|
||||||
OSS ......................... $have_oss
|
|
||||||
JACK ........................ $have_jack
|
|
||||||
])
|
|
||||||
;;
|
|
||||||
esac
|
|
|
@ -1,791 +0,0 @@
|
||||||
#! /bin/sh
|
|
||||||
# depcomp - compile a program generating dependencies as side-effects
|
|
||||||
|
|
||||||
scriptversion=2013-05-30.07; # UTC
|
|
||||||
|
|
||||||
# Copyright (C) 1999-2013 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
|
|
||||||
# This program 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 General Public License for more details.
|
|
||||||
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
# Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>.
|
|
||||||
|
|
||||||
case $1 in
|
|
||||||
'')
|
|
||||||
echo "$0: No command. Try '$0 --help' for more information." 1>&2
|
|
||||||
exit 1;
|
|
||||||
;;
|
|
||||||
-h | --h*)
|
|
||||||
cat <<\EOF
|
|
||||||
Usage: depcomp [--help] [--version] PROGRAM [ARGS]
|
|
||||||
|
|
||||||
Run PROGRAMS ARGS to compile a file, generating dependencies
|
|
||||||
as side-effects.
|
|
||||||
|
|
||||||
Environment variables:
|
|
||||||
depmode Dependency tracking mode.
|
|
||||||
source Source file read by 'PROGRAMS ARGS'.
|
|
||||||
object Object file output by 'PROGRAMS ARGS'.
|
|
||||||
DEPDIR directory where to store dependencies.
|
|
||||||
depfile Dependency file to output.
|
|
||||||
tmpdepfile Temporary file to use when outputting dependencies.
|
|
||||||
libtool Whether libtool is used (yes/no).
|
|
||||||
|
|
||||||
Report bugs to <bug-automake@gnu.org>.
|
|
||||||
EOF
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
-v | --v*)
|
|
||||||
echo "depcomp $scriptversion"
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Get the directory component of the given path, and save it in the
|
|
||||||
# global variables '$dir'. Note that this directory component will
|
|
||||||
# be either empty or ending with a '/' character. This is deliberate.
|
|
||||||
set_dir_from ()
|
|
||||||
{
|
|
||||||
case $1 in
|
|
||||||
*/*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;;
|
|
||||||
*) dir=;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
# Get the suffix-stripped basename of the given path, and save it the
|
|
||||||
# global variable '$base'.
|
|
||||||
set_base_from ()
|
|
||||||
{
|
|
||||||
base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'`
|
|
||||||
}
|
|
||||||
|
|
||||||
# If no dependency file was actually created by the compiler invocation,
|
|
||||||
# we still have to create a dummy depfile, to avoid errors with the
|
|
||||||
# Makefile "include basename.Plo" scheme.
|
|
||||||
make_dummy_depfile ()
|
|
||||||
{
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Factor out some common post-processing of the generated depfile.
|
|
||||||
# Requires the auxiliary global variable '$tmpdepfile' to be set.
|
|
||||||
aix_post_process_depfile ()
|
|
||||||
{
|
|
||||||
# If the compiler actually managed to produce a dependency file,
|
|
||||||
# post-process it.
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
# Each line is of the form 'foo.o: dependency.h'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# $object: dependency.h
|
|
||||||
# and one to simply output
|
|
||||||
# dependency.h:
|
|
||||||
# which is needed to avoid the deleted-header problem.
|
|
||||||
{ sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile"
|
|
||||||
sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile"
|
|
||||||
} > "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
else
|
|
||||||
make_dummy_depfile
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# A tabulation character.
|
|
||||||
tab=' '
|
|
||||||
# A newline character.
|
|
||||||
nl='
|
|
||||||
'
|
|
||||||
# Character ranges might be problematic outside the C locale.
|
|
||||||
# These definitions help.
|
|
||||||
upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
|
||||||
lower=abcdefghijklmnopqrstuvwxyz
|
|
||||||
digits=0123456789
|
|
||||||
alpha=${upper}${lower}
|
|
||||||
|
|
||||||
if test -z "$depmode" || test -z "$source" || test -z "$object"; then
|
|
||||||
echo "depcomp: Variables source, object and depmode must be set" 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po.
|
|
||||||
depfile=${depfile-`echo "$object" |
|
|
||||||
sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`}
|
|
||||||
tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
|
|
||||||
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
|
|
||||||
# Avoid interferences from the environment.
|
|
||||||
gccflag= dashmflag=
|
|
||||||
|
|
||||||
# Some modes work just like other modes, but use different flags. We
|
|
||||||
# parameterize here, but still list the modes in the big case below,
|
|
||||||
# to make depend.m4 easier to write. Note that we *cannot* use a case
|
|
||||||
# here, because this file can only contain one case statement.
|
|
||||||
if test "$depmode" = hp; then
|
|
||||||
# HP compiler uses -M and no extra arg.
|
|
||||||
gccflag=-M
|
|
||||||
depmode=gcc
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = dashXmstdout; then
|
|
||||||
# This is just like dashmstdout with a different argument.
|
|
||||||
dashmflag=-xM
|
|
||||||
depmode=dashmstdout
|
|
||||||
fi
|
|
||||||
|
|
||||||
cygpath_u="cygpath -u -f -"
|
|
||||||
if test "$depmode" = msvcmsys; then
|
|
||||||
# This is just like msvisualcpp but w/o cygpath translation.
|
|
||||||
# Just convert the backslash-escaped backslashes to single forward
|
|
||||||
# slashes to satisfy depend.m4
|
|
||||||
cygpath_u='sed s,\\\\,/,g'
|
|
||||||
depmode=msvisualcpp
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = msvc7msys; then
|
|
||||||
# This is just like msvc7 but w/o cygpath translation.
|
|
||||||
# Just convert the backslash-escaped backslashes to single forward
|
|
||||||
# slashes to satisfy depend.m4
|
|
||||||
cygpath_u='sed s,\\\\,/,g'
|
|
||||||
depmode=msvc7
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = xlc; then
|
|
||||||
# IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information.
|
|
||||||
gccflag=-qmakedep=gcc,-MF
|
|
||||||
depmode=gcc
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$depmode" in
|
|
||||||
gcc3)
|
|
||||||
## gcc 3 implements dependency tracking that does exactly what
|
|
||||||
## we want. Yay! Note: for some reason libtool 1.4 doesn't like
|
|
||||||
## it if -MD -MP comes after the -MF stuff. Hmm.
|
|
||||||
## Unfortunately, FreeBSD c89 acceptance of flags depends upon
|
|
||||||
## the command line argument order; so add the flags where they
|
|
||||||
## appear in depend2.am. Note that the slowdown incurred here
|
|
||||||
## affects only configure: in makefiles, %FASTDEP% shortcuts this.
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;;
|
|
||||||
*) set fnord "$@" "$arg" ;;
|
|
||||||
esac
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
done
|
|
||||||
"$@"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
mv "$tmpdepfile" "$depfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
gcc)
|
|
||||||
## Note that this doesn't just cater to obsosete pre-3.x GCC compilers.
|
|
||||||
## but also to in-use compilers like IMB xlc/xlC and the HP C compiler.
|
|
||||||
## (see the conditional assignment to $gccflag above).
|
|
||||||
## There are various ways to get dependency output from gcc. Here's
|
|
||||||
## why we pick this rather obscure method:
|
|
||||||
## - Don't want to use -MD because we'd like the dependencies to end
|
|
||||||
## up in a subdir. Having to rename by hand is ugly.
|
|
||||||
## (We might end up doing this anyway to support other compilers.)
|
|
||||||
## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
|
|
||||||
## -MM, not -M (despite what the docs say). Also, it might not be
|
|
||||||
## supported by the other compilers which use the 'gcc' depmode.
|
|
||||||
## - Using -M directly means running the compiler twice (even worse
|
|
||||||
## than renaming).
|
|
||||||
if test -z "$gccflag"; then
|
|
||||||
gccflag=-MD,
|
|
||||||
fi
|
|
||||||
"$@" -Wp,"$gccflag$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
# The second -e expression handles DOS-style file names with drive
|
|
||||||
# letters.
|
|
||||||
sed -e 's/^[^:]*: / /' \
|
|
||||||
-e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
|
|
||||||
## This next piece of magic avoids the "deleted header file" problem.
|
|
||||||
## The problem is that when a header file which appears in a .P file
|
|
||||||
## is deleted, the dependency causes make to die (because there is
|
|
||||||
## typically no way to rebuild the header). We avoid this by adding
|
|
||||||
## dummy dependencies for each header file. Too bad gcc doesn't do
|
|
||||||
## this for us directly.
|
|
||||||
## Some versions of gcc put a space before the ':'. On the theory
|
|
||||||
## that the space means something, we add a space to the output as
|
|
||||||
## well. hp depmode also adds that space, but also prefixes the VPATH
|
|
||||||
## to the object. Take care to not repeat it in the output.
|
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
hp)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
sgi)
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
"$@" "-Wp,-MDupdate,$tmpdepfile"
|
|
||||||
else
|
|
||||||
"$@" -MDupdate "$tmpdepfile"
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
# Clip off the initial element (the dependent). Don't try to be
|
|
||||||
# clever and replace this with sed code, as IRIX sed won't handle
|
|
||||||
# lines with more than a fixed number of characters (4096 in
|
|
||||||
# IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
|
|
||||||
# the IRIX cc adds comments like '#:fec' to the end of the
|
|
||||||
# dependency line.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \
|
|
||||||
| tr "$nl" ' ' >> "$depfile"
|
|
||||||
echo >> "$depfile"
|
|
||||||
# The second pass generates a dummy entry for each header file.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
|
|
||||||
>> "$depfile"
|
|
||||||
else
|
|
||||||
make_dummy_depfile
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
xlc)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
aix)
|
|
||||||
# The C for AIX Compiler uses -M and outputs the dependencies
|
|
||||||
# in a .u file. In older versions, this file always lives in the
|
|
||||||
# current directory. Also, the AIX compiler puts '$object:' at the
|
|
||||||
# start of each line; $object doesn't have directory information.
|
|
||||||
# Version 6 uses the directory in both cases.
|
|
||||||
set_dir_from "$object"
|
|
||||||
set_base_from "$object"
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
tmpdepfile1=$dir$base.u
|
|
||||||
tmpdepfile2=$base.u
|
|
||||||
tmpdepfile3=$dir.libs/$base.u
|
|
||||||
"$@" -Wc,-M
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.u
|
|
||||||
tmpdepfile2=$dir$base.u
|
|
||||||
tmpdepfile3=$dir$base.u
|
|
||||||
"$@" -M
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
aix_post_process_depfile
|
|
||||||
;;
|
|
||||||
|
|
||||||
tcc)
|
|
||||||
# tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26
|
|
||||||
# FIXME: That version still under development at the moment of writing.
|
|
||||||
# Make that this statement remains true also for stable, released
|
|
||||||
# versions.
|
|
||||||
# It will wrap lines (doesn't matter whether long or short) with a
|
|
||||||
# trailing '\', as in:
|
|
||||||
#
|
|
||||||
# foo.o : \
|
|
||||||
# foo.c \
|
|
||||||
# foo.h \
|
|
||||||
#
|
|
||||||
# It will put a trailing '\' even on the last line, and will use leading
|
|
||||||
# spaces rather than leading tabs (at least since its commit 0394caf7
|
|
||||||
# "Emit spaces for -MD").
|
|
||||||
"$@" -MD -MF "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
# Each non-empty line is of the form 'foo.o : \' or ' dep.h \'.
|
|
||||||
# We have to change lines of the first kind to '$object: \'.
|
|
||||||
sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile"
|
|
||||||
# And for each line of the second kind, we have to emit a 'dep.h:'
|
|
||||||
# dummy dependency, to avoid the deleted-header problem.
|
|
||||||
sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
## The order of this option in the case statement is important, since the
|
|
||||||
## shell code in configure will try each of these formats in the order
|
|
||||||
## listed in this file. A plain '-MD' option would be understood by many
|
|
||||||
## compilers, so we must ensure this comes after the gcc and icc options.
|
|
||||||
pgcc)
|
|
||||||
# Portland's C compiler understands '-MD'.
|
|
||||||
# Will always output deps to 'file.d' where file is the root name of the
|
|
||||||
# source file under compilation, even if file resides in a subdirectory.
|
|
||||||
# The object file name does not affect the name of the '.d' file.
|
|
||||||
# pgcc 10.2 will output
|
|
||||||
# foo.o: sub/foo.c sub/foo.h
|
|
||||||
# and will wrap long lines using '\' :
|
|
||||||
# foo.o: sub/foo.c ... \
|
|
||||||
# sub/foo.h ... \
|
|
||||||
# ...
|
|
||||||
set_dir_from "$object"
|
|
||||||
# Use the source, not the object, to determine the base name, since
|
|
||||||
# that's sadly what pgcc will do too.
|
|
||||||
set_base_from "$source"
|
|
||||||
tmpdepfile=$base.d
|
|
||||||
|
|
||||||
# For projects that build the same source file twice into different object
|
|
||||||
# files, the pgcc approach of using the *source* file root name can cause
|
|
||||||
# problems in parallel builds. Use a locking strategy to avoid stomping on
|
|
||||||
# the same $tmpdepfile.
|
|
||||||
lockdir=$base.d-lock
|
|
||||||
trap "
|
|
||||||
echo '$0: caught signal, cleaning up...' >&2
|
|
||||||
rmdir '$lockdir'
|
|
||||||
exit 1
|
|
||||||
" 1 2 13 15
|
|
||||||
numtries=100
|
|
||||||
i=$numtries
|
|
||||||
while test $i -gt 0; do
|
|
||||||
# mkdir is a portable test-and-set.
|
|
||||||
if mkdir "$lockdir" 2>/dev/null; then
|
|
||||||
# This process acquired the lock.
|
|
||||||
"$@" -MD
|
|
||||||
stat=$?
|
|
||||||
# Release the lock.
|
|
||||||
rmdir "$lockdir"
|
|
||||||
break
|
|
||||||
else
|
|
||||||
# If the lock is being held by a different process, wait
|
|
||||||
# until the winning process is done or we timeout.
|
|
||||||
while test -d "$lockdir" && test $i -gt 0; do
|
|
||||||
sleep 1
|
|
||||||
i=`expr $i - 1`
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
i=`expr $i - 1`
|
|
||||||
done
|
|
||||||
trap - 1 2 13 15
|
|
||||||
if test $i -le 0; then
|
|
||||||
echo "$0: failed to acquire lock after $numtries attempts" >&2
|
|
||||||
echo "$0: check lockdir '$lockdir'" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
# Each line is of the form `foo.o: dependent.h',
|
|
||||||
# or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# `$object: dependent.h' and one to simply `dependent.h:'.
|
|
||||||
sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
hp2)
|
|
||||||
# The "hp" stanza above does not work with aCC (C++) and HP's ia64
|
|
||||||
# compilers, which have integrated preprocessors. The correct option
|
|
||||||
# to use with these is +Maked; it writes dependencies to a file named
|
|
||||||
# 'foo.d', which lands next to the object file, wherever that
|
|
||||||
# happens to be.
|
|
||||||
# Much of this is similar to the tru64 case; see comments there.
|
|
||||||
set_dir_from "$object"
|
|
||||||
set_base_from "$object"
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
tmpdepfile1=$dir$base.d
|
|
||||||
tmpdepfile2=$dir.libs/$base.d
|
|
||||||
"$@" -Wc,+Maked
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.d
|
|
||||||
tmpdepfile2=$dir$base.d
|
|
||||||
"$@" +Maked
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile"
|
|
||||||
# Add 'dependent.h:' lines.
|
|
||||||
sed -ne '2,${
|
|
||||||
s/^ *//
|
|
||||||
s/ \\*$//
|
|
||||||
s/$/:/
|
|
||||||
p
|
|
||||||
}' "$tmpdepfile" >> "$depfile"
|
|
||||||
else
|
|
||||||
make_dummy_depfile
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile2"
|
|
||||||
;;
|
|
||||||
|
|
||||||
tru64)
|
|
||||||
# The Tru64 compiler uses -MD to generate dependencies as a side
|
|
||||||
# effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'.
|
|
||||||
# At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
|
|
||||||
# dependencies in 'foo.d' instead, so we check for that too.
|
|
||||||
# Subdirectories are respected.
|
|
||||||
set_dir_from "$object"
|
|
||||||
set_base_from "$object"
|
|
||||||
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
# Libtool generates 2 separate objects for the 2 libraries. These
|
|
||||||
# two compilations output dependencies in $dir.libs/$base.o.d and
|
|
||||||
# in $dir$base.o.d. We have to check for both files, because
|
|
||||||
# one of the two compilations can be disabled. We should prefer
|
|
||||||
# $dir$base.o.d over $dir.libs/$base.o.d because the latter is
|
|
||||||
# automatically cleaned when .libs/ is deleted, while ignoring
|
|
||||||
# the former would cause a distcleancheck panic.
|
|
||||||
tmpdepfile1=$dir$base.o.d # libtool 1.5
|
|
||||||
tmpdepfile2=$dir.libs/$base.o.d # Likewise.
|
|
||||||
tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504
|
|
||||||
"$@" -Wc,-MD
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.d
|
|
||||||
tmpdepfile2=$dir$base.d
|
|
||||||
tmpdepfile3=$dir$base.d
|
|
||||||
"$@" -MD
|
|
||||||
fi
|
|
||||||
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
# Same post-processing that is required for AIX mode.
|
|
||||||
aix_post_process_depfile
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvc7)
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
showIncludes=-Wc,-showIncludes
|
|
||||||
else
|
|
||||||
showIncludes=-showIncludes
|
|
||||||
fi
|
|
||||||
"$@" $showIncludes > "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
grep -v '^Note: including file: ' "$tmpdepfile"
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
# The first sed program below extracts the file names and escapes
|
|
||||||
# backslashes for cygpath. The second sed program outputs the file
|
|
||||||
# name when reading, but also accumulates all include files in the
|
|
||||||
# hold buffer in order to output them again at the end. This only
|
|
||||||
# works with sed implementations that can handle large buffers.
|
|
||||||
sed < "$tmpdepfile" -n '
|
|
||||||
/^Note: including file: *\(.*\)/ {
|
|
||||||
s//\1/
|
|
||||||
s/\\/\\\\/g
|
|
||||||
p
|
|
||||||
}' | $cygpath_u | sort -u | sed -n '
|
|
||||||
s/ /\\ /g
|
|
||||||
s/\(.*\)/'"$tab"'\1 \\/p
|
|
||||||
s/.\(.*\) \\/\1:/
|
|
||||||
H
|
|
||||||
$ {
|
|
||||||
s/.*/'"$tab"'/
|
|
||||||
G
|
|
||||||
p
|
|
||||||
}' >> "$depfile"
|
|
||||||
echo >> "$depfile" # make sure the fragment doesn't end with a backslash
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvc7msys)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
#nosideeffect)
|
|
||||||
# This comment above is used by automake to tell side-effect
|
|
||||||
# dependency tracking mechanisms from slower ones.
|
|
||||||
|
|
||||||
dashmstdout)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout, regardless of -o.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove '-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
test -z "$dashmflag" && dashmflag=-M
|
|
||||||
# Require at least two characters before searching for ':'
|
|
||||||
# in the target name. This is to cope with DOS-style filenames:
|
|
||||||
# a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise.
|
|
||||||
"$@" $dashmflag |
|
|
||||||
sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
cat < "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process this sed invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
dashXmstdout)
|
|
||||||
# This case only exists to satisfy depend.m4. It is never actually
|
|
||||||
# run, as this mode is specially recognized in the preamble.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
makedepend)
|
|
||||||
"$@" || exit $?
|
|
||||||
# Remove any Libtool call
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
# X makedepend
|
|
||||||
shift
|
|
||||||
cleared=no eat=no
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $cleared in
|
|
||||||
no)
|
|
||||||
set ""; shift
|
|
||||||
cleared=yes ;;
|
|
||||||
esac
|
|
||||||
if test $eat = yes; then
|
|
||||||
eat=no
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
case "$arg" in
|
|
||||||
-D*|-I*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
# Strip any option that makedepend may not understand. Remove
|
|
||||||
# the object too, otherwise makedepend will parse it as a source file.
|
|
||||||
-arch)
|
|
||||||
eat=yes ;;
|
|
||||||
-*|$object)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
obj_suffix=`echo "$object" | sed 's/^.*\././'`
|
|
||||||
touch "$tmpdepfile"
|
|
||||||
${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
|
|
||||||
rm -f "$depfile"
|
|
||||||
# makedepend may prepend the VPATH from the source file name to the object.
|
|
||||||
# No need to regex-escape $object, excess matching of '.' is harmless.
|
|
||||||
sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process the last invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed '1,2d' "$tmpdepfile" \
|
|
||||||
| tr ' ' "$nl" \
|
|
||||||
| sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile".bak
|
|
||||||
;;
|
|
||||||
|
|
||||||
cpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove '-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
"$@" -E \
|
|
||||||
| sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
|
||||||
-e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
|
||||||
| sed '$ s: \\$::' > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
cat < "$tmpdepfile" >> "$depfile"
|
|
||||||
sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvisualcpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case "$arg" in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
"-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
|
|
||||||
set fnord "$@"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
"$@" -E 2>/dev/null |
|
|
||||||
sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile"
|
|
||||||
echo "$tab" >> "$depfile"
|
|
||||||
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvcmsys)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
none)
|
|
||||||
exec "$@"
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
echo "Unknown depmode $depmode" 1>&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exit 0
|
|
||||||
|
|
||||||
# Local Variables:
|
|
||||||
# mode: shell-script
|
|
||||||
# sh-indentation: 2
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
|
@ -1,162 +0,0 @@
|
||||||
/** @page api_overview PortAudio API Overview
|
|
||||||
|
|
||||||
This page provides a top-down overview of the entire PortAudio API. It describes how all of the PortAudio data types and functions fit together. It provides links to the documentation for each function and data type. You can find all of the detailed documentation for each API function and data type on the portaudio.h page.
|
|
||||||
|
|
||||||
@section introduction Introduction
|
|
||||||
|
|
||||||
PortAudio provides a uniform application programming interface (API) across all supported platforms. You can think of the PortAudio library as a wrapper that converts calls to the PortAudio API into calls to platform-specific native audio APIs. Operating systems often offer more than one native audio API and some APIs (such as JACK) may be available on multiple target operating systems. PortAudio supports all the major native audio APIs on each supported platform. The diagram below illustrates the relationship between your application, PortAudio, and the supported native audio APIs:
|
|
||||||
|
|
||||||
@image html portaudio-external-architecture-diagram.png
|
|
||||||
|
|
||||||
PortAudio provides a uniform interface to native audio APIs. However, it doesn't always provide totally uniform functionality. There are cases where PortAudio is limited by the capabilities of the underlying native audio API. For example, PortAudio doesn't provide sample rate conversion if you request a sample rate that is not supported by the native audio API. Another example is that the ASIO SDK only allows one device to be open at a time, so PortAudio/ASIO doesn't currently support opening multiple ASIO devices simultaneously.
|
|
||||||
|
|
||||||
@section key_abstractions Key abstractions: Host APIs, Devices and Streams
|
|
||||||
|
|
||||||
The PortAudio processing model includes three main abstractions: <i>Host APIs</i>, audio <i>Devices</i> and audio <i>Streams</i>.
|
|
||||||
|
|
||||||
Host APIs represent platform-specific native audio APIs. Some examples of Host APIs are Core Audio on Mac OS, WMME and DirectSound on Windows and OSS and ALSA on Linux. The diagram in the previous section shows many of the supported native APIs. Sometimes it's useful to know which Host APIs you're dealing with, but it is easy to use PortAudio without ever interacting directly with the Host API abstraction.
|
|
||||||
|
|
||||||
Devices represent individual hardware audio interfaces or audio ports on the host platform. Devices have names and certain capabilities such as supported sample rates and the number of supported input and output channels. PortAudio provides functions to enumerate available Devices and to query for Device capabilities.
|
|
||||||
|
|
||||||
Streams manage active audio input and output from and to Devices. Streams may be half duplex (input or output) or full duplex (simultaneous input and output). Streams operate at a specific sample rate with particular sample formats, buffer sizes and internal buffering latencies. You specify these parameters when you open the Stream. Audio data is communicated between a Stream and your application via a user provided asynchronous callback function or by invoking synchronous read and write functions.
|
|
||||||
|
|
||||||
PortAudio supports audio input and output in a variety of sample formats: 8, 16, 24 and 32 bit integer formats and 32 bit floating point, irrespective of the formats supported by the native audio API. PortAudio also supports multichannel buffers in both interleaved and non-interleaved (separate buffer per channel) formats and automatically performs conversion when necessary. If requested, PortAudio can clamp out-of range samples and/or dither to a native format.
|
|
||||||
|
|
||||||
The PortAudio API offers the following functionality:
|
|
||||||
- Initialize and terminate the library
|
|
||||||
- Enumerate available Host APIs
|
|
||||||
- Enumerate available Devices either globally, or within each Host API
|
|
||||||
- Discover default or recommended Devices and Device settings
|
|
||||||
- Discover Device capabilities such as supported audio data formats and sample rates
|
|
||||||
- Create and control audio Streams to acquire audio from and output audio to Devices
|
|
||||||
- Provide Stream timing information to support synchronising audio with other parts of your application
|
|
||||||
- Retrieve version and error information.
|
|
||||||
|
|
||||||
These functions are described in more detail below.
|
|
||||||
|
|
||||||
|
|
||||||
@section top_level_functions Initialization, termination and utility functions
|
|
||||||
|
|
||||||
The PortAudio library must be initialized before it can be used and terminated to clean up afterwards. You initialize PortAudio by calling Pa_Initialize() and clean up by calling Pa_Terminate().
|
|
||||||
|
|
||||||
You can query PortAudio for version information using Pa_GetVersion() to get a numeric version number and Pa_GetVersionText() to get a string.
|
|
||||||
|
|
||||||
The size in bytes of the various sample formats represented by the @ref PaSampleFormat enumeration can be obtained using Pa_GetSampleSize().
|
|
||||||
|
|
||||||
Pa_Sleep() sleeps for a specified number of milliseconds. This isn't intended for use in production systems; it's provided only as a simple portable way to implement tests and examples where the main thread sleeps while audio is acquired or played by an asynchronous callback function.
|
|
||||||
|
|
||||||
@section host_apis Host APIs
|
|
||||||
|
|
||||||
A Host API acts as a top-level grouping for all of the Devices offered by a single native platform audio API. Each Host API has a unique type identifier, a name, zero or more Devices, and nominated default input and output Devices.
|
|
||||||
|
|
||||||
Host APIs are usually referenced by index: an integer of type @ref PaHostApiIndex that ranges between zero and Pa_GetHostApiCount() - 1. You can enumerate all available Host APIs by counting across this range.
|
|
||||||
|
|
||||||
You can retrieve the index of the default Host API by calling Pa_GetDefaultHostApi().
|
|
||||||
|
|
||||||
Information about a Host API, such as it's name and default devices, is stored in a @ref PaHostApiInfo structure. You can retrieve a pointer to a particular Host API's @ref PaHostApiInfo structure by calling Pa_GetHostApiInfo() with the Host API's index as a parameter.
|
|
||||||
|
|
||||||
Most PortAudio functions reference Host APIs by @ref PaHostApiIndex indices. Each Host API also has a unique type identifier defined in the @ref PaHostApiTypeId enumeration.
|
|
||||||
You can call Pa_HostApiTypeIdToHostApiIndex() to retrieve the current @ref PaHostApiIndex for a particular @ref PaHostApiTypeId.
|
|
||||||
|
|
||||||
@section devices Devices
|
|
||||||
|
|
||||||
A Device represents an audio endpoint provided by a particular native audio API. This usually corresponds to a specific input or output port on a hardware audio interface, or to the interface as a whole. Each Host API operates independently, so a single physical audio port may be addressable via different Devices exposed by different Host APIs.
|
|
||||||
|
|
||||||
A Device has a name, is associated with a Host API, and has a maximum number of supported input and output channels. PortAudio provides recommended default latency values and a default sample rate for each Device. To obtain more detailed information about device capabilities you can call Pa_IsFormatSupported() to query whether it is possible to open a Stream using particular Devices, parameters and sample rate.
|
|
||||||
|
|
||||||
Although each Device conceptually belongs to a specific Host API, most PortAudio functions and data structures refer to Devices using a global, Host API-independent index of type @ref PaDeviceIndex – an integer of that ranges between zero and Pa_GetDeviceCount() - 1. The reasons for this are partly historical but it also makes it easy for applications to ignore the Host API abstraction and just work with Devices and Streams.
|
|
||||||
|
|
||||||
If you want to enumerate Devices belonging to a particular Host API you can count between 0 and PaHostApiInfo::deviceCount - 1. You can convert this Host API-specific index value to a global @ref PaDeviceIndex value by calling Pa_HostApiDeviceIndexToDeviceIndex().
|
|
||||||
|
|
||||||
Information about a Device is stored in a @ref PaDeviceInfo structure. You can retrieve a pointer to a Devices's @ref PaDeviceInfo structure by calling Pa_GetDeviceInfo() with the Device's index as a parameter.
|
|
||||||
|
|
||||||
You can retrieve the indices of the global default input and output devices using Pa_GetDefaultInputDevice() and Pa_GetDefaultOutputDevice(). Default Devices for each Host API are stored in the Host API's @ref PaHostApiInfo structures.
|
|
||||||
|
|
||||||
For an example of enumerating devices and printing information about their capabilities see the pa_devs.c program in the test directory of the PortAudio distribution.
|
|
||||||
|
|
||||||
@section streams Streams
|
|
||||||
|
|
||||||
A Stream represents an active flow of audio data between your application and one or more audio Devices. A Stream operates at a specific sample rate with specific sample formats and buffer sizes.
|
|
||||||
|
|
||||||
@subsection io_methods I/O Methods: callback and read/write
|
|
||||||
|
|
||||||
PortAudio offers two methods for communicating audio data between an open Stream and your Application: (1) an asynchronous callback interface, where PortAudio calls a user defined callback function when new audio data is available or required, and (2) synchronous read and write functions which can be used in a blocking or non-blocking manner. You choose between the two methods when you open a Stream. The two methods are discussed in more detail below.
|
|
||||||
|
|
||||||
@subsection opening_and_closing_streams Opening and Closing Streams
|
|
||||||
|
|
||||||
You call Pa_OpenStream() to open a Stream, specifying the Device(s) to use, the number of input and output channels, sample formats, suggested latency values and flags that control dithering, clipping and overflow handling. You specify many of these parameters in two PaStreamParameters structures, one for input and one for output. If you're using the callback I/O method you also pass a callback buffer size, callback function pointer and user data pointer.
|
|
||||||
|
|
||||||
Devices may be full duplex (supporting simultaneous input and output) or half duplex (supporting input or output) – usually this reflects the structure of the underlying native audio API. When opening a Stream you can specify one full duplex Device for both input and output, or two different Devices for input and output. Some Host APIs only support full-duplex operation with a full-duplex device (e.g. ASIO) but most are able to aggregate two half duplex devices into a full duplex Stream. PortAudio requires that all devices specified in a call to Pa_OpenStream() belong to the same Host API.
|
|
||||||
|
|
||||||
A successful call to Pa_OpenStream() creates a pointer to a @ref PaStream – an opaque handle representing the open Stream. All PortAudio API functions that operate on open Streams take a pointer to a @ref PaStream as their first parameter.
|
|
||||||
|
|
||||||
PortAudio also provides Pa_OpenDefaultStream() – a simpler alternative to Pa_OpenStream() which you can use when you want to open the default audio Device(s) with default latency parameters.
|
|
||||||
|
|
||||||
You call Pa_CloseStream() to close a Stream when you've finished using it.
|
|
||||||
|
|
||||||
@subsection starting_and_stopping_streams Starting and Stopping Streams
|
|
||||||
|
|
||||||
Newly opened Streams are initially stopped. You call Pa_StartStream() to start a Stream. You can stop a running Stream using Pa_StopStream() or Pa_AbortStream() (the Stop function plays out all internally queued audio data, while Abort tries to stop as quickly as possible). An open Stream can be started and stopped multiple times. You can call Pa_IsStreamStopped() to query whether a Stream is running or stopped.
|
|
||||||
|
|
||||||
By calling Pa_SetStreamFinishedCallback() it is possible to register a special @ref PaStreamFinishedCallback that will be called when the Stream has completed playing any internally queued buffers. This can be used in conjunction with the @ref paComplete stream callback return value (see below) to avoid blocking on a call to Pa_StopStream() while queued audio data is still playing.
|
|
||||||
|
|
||||||
@subsection callback_io_method The Callback I/O Method
|
|
||||||
|
|
||||||
So-called 'callback Streams' operate by periodically invoking a callback function you supply to Pa_OpenStream(). The callback function must implement the @ref PaStreamCallback signature. It gets called by PortAudio every time PortAudio needs your application to consume or produce audio data. The callback is passed pointers to buffers containing the audio to process. The format (interleave, sample data type) and size of these buffers is determined by the parameters passed to Pa_OpenStream() when the Stream was opened.
|
|
||||||
|
|
||||||
Stream callbacks usually return @ref paContinue to indicate that PortAudio should keep the stream running. It is possible to deactivate a Stream from the stream callback by returning either @ref paComplete or @ref paAbort. In this case the Stream enters a deactivated state after the last buffer has finished playing (@ref paComplete) or as soon as possible (@ref paAbort). You can detect the deactivated state by calling Pa_IsStreamActive() or by using Pa_SetStreamFinishedCallback() to subscribe to a stream finished notification. Note that even if the stream callback returns @ref paComplete it's still necessary to call Pa_StopStream() or Pa_AbortStream() to enter the stopped state.
|
|
||||||
|
|
||||||
Many of the tests in the /tests directory of the PortAudio distribution implement PortAudio stream callbacks. For example see: patest_sine.c (audio output), patest_record.c (audio input), patest_wire.c (audio pass-through) and pa_fuzz.c (simple audio effects processing).
|
|
||||||
|
|
||||||
<strong>IMPORTANT:</strong> The stream callback function often needs to operate with very high or real-time priority. As a result there are strict requirements placed on the type of code that can be executed in a stream callback. In general this means avoiding any code that might block, including: acquiring locks, calling OS API functions including allocating memory. With the exception of Pa_GetStreamCpuLoad() you may not call PortAudio API functions from within the stream callback.
|
|
||||||
|
|
||||||
@subsection read_write_io_method The Read/Write I/O Method
|
|
||||||
|
|
||||||
As an alternative to the callback I/O method, PortAudio provides a synchronous read/write interface for acquiring and playing audio. This can be useful for applications that don't require the lowest possibly latency, or don't warrant the increased complexity of synchronising with an asynchronous callback function. This I/O method is also useful when calling PortAudio from programming languages that don't support asynchronous callbacks.
|
|
||||||
|
|
||||||
To open a Stream in read/write mode you pass a NULL stream callback function pointer to Pa_OpenStream().
|
|
||||||
|
|
||||||
To write audio data to a Stream call Pa_WriteStream() and to read data call Pa_ReadStream(). These functions will block if the internal buffers are full, making them safe to call in a tight loop. If you want to avoid blocking you can query the amount of available read or write space using Pa_GetStreamReadAvailable() or Pa_GetStreamWriteAvailable() and use the returned values to limit the amount of data you read or write.
|
|
||||||
|
|
||||||
For examples of the read/write I/O method see the following examples in the /tests directory of the PortAudio distribution: patest_read_record.c (audio input), patest_write_sine.c (audio output), patest_read_write_wire.c (audio pass-through).
|
|
||||||
|
|
||||||
@subsection stream_info Retrieving Stream Information
|
|
||||||
|
|
||||||
You can retrieve information about an open Stream by calling Pa_GetStreamInfo(). This returns a @ref PaStreamInfo structure containing the actual input and output latency and sample rate of the stream. It's possible for these values to be different from the suggested values passed to Pa_OpenStream().
|
|
||||||
|
|
||||||
When using a callback stream you can call Pa_GetStreamCpuLoad() to retrieve a rough estimate of the amount of CPU time your callback function is using.
|
|
||||||
|
|
||||||
@subsection stream_timing Stream Timing Information
|
|
||||||
|
|
||||||
When using the callback I/O method your stream callback function receives timing information via a pointer to a PaStreamCallbackTimeInfo structure. This structure contains the current time along with the estimated hardware capture and playback time of the first sample of the input and output buffers. All times are measured in seconds relative to a Stream-specific clock. The current Stream clock time can be retrieved using Pa_GetStreamTime().
|
|
||||||
|
|
||||||
You can use the stream callback @ref PaStreamCallbackTimeInfo times in conjunction with timestamps returned by Pa_GetStreamTime() to implement time synchronization schemes such as time aligning your GUI display with rendered audio, or maintaining synchronization between MIDI and audio playback.
|
|
||||||
|
|
||||||
@section error_handling Error Handling
|
|
||||||
|
|
||||||
Most PortAudio functions return error codes using values from the @ref PaError enumeration. All error codes are negative values. Some functions return values greater than or equal to zero for normal results and a negative error code in case of error.
|
|
||||||
|
|
||||||
You can convert @ref PaError error codes to human readable text by calling Pa_GetErrorText().
|
|
||||||
|
|
||||||
PortAudio usually tries to translate error conditions into portable @ref PaError error codes. However if an unexpected error is encountered the @ref paUnanticipatedHostError code may be returned. In this case a further mechanism is provided to query for Host API-specific error information. If PortAudio returns @ref paUnanticipatedHostError you can call Pa_GetLastHostErrorInfo() to retrieve a pointer to a @ref PaHostErrorInfo structure that provides more information, including the Host API that encountered the error, a native API error code and error text.
|
|
||||||
|
|
||||||
@section host_api_extensions Host API and Platform-specific Extensions
|
|
||||||
|
|
||||||
The public PortAudio API only exposes functionality that can be provided across all target platforms. In some cases individual native audio APIs offer unique functionality. Some PortAudio Host APIs expose this functionality via Host API-specific extensions. Examples include access to low-level buffering and priority parameters, opening a Stream with only a subset of a Device's channels, or accessing channel metadata such as channel names.
|
|
||||||
|
|
||||||
Host API-specific extensions are provided in the form of additional functions and data structures defined in Host API-specific header files found in the /include directory.
|
|
||||||
|
|
||||||
The @ref PaStreamParameters structure passed to Pa_IsFormatSupported() and Pa_OpenStream() has a field named @ref PaStreamParameters::hostApiSpecificStreamInfo that is sometimes used to pass low level information when opening a Stream.
|
|
||||||
|
|
||||||
See the documentation for the individual Host API-specific header files for details of the extended functionality they expose:
|
|
||||||
|
|
||||||
- pa_asio.h
|
|
||||||
- pa_jack.h
|
|
||||||
- pa_linux_alsa.h
|
|
||||||
- pa_mac_core.h
|
|
||||||
- pa_win_ds.h
|
|
||||||
- pa_win_wasapi.h
|
|
||||||
- pa_win_wmme.h
|
|
||||||
- pa_win_waveformat.h
|
|
||||||
|
|
||||||
*/
|
|
Binary file not shown.
Before Width: | Height: | Size: 20 KiB |
|
@ -1,38 +0,0 @@
|
||||||
/** @page License PortAudio License
|
|
||||||
|
|
||||||
PortAudio Portable Real-Time Audio Library <br>
|
|
||||||
Copyright (c) 1999-2011 Ross Bencina, Phil Burk
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
a copy of this software and associated documentation files
|
|
||||||
(the "Software"), to deal in the Software without restriction,
|
|
||||||
including without limitation the rights to use, copy, modify, merge,
|
|
||||||
publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
and to permit persons to whom the Software is furnished to do so,
|
|
||||||
subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be
|
|
||||||
included in all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
|
|
||||||
<br>
|
|
||||||
|
|
||||||
The text above constitutes the entire PortAudio license; however,
|
|
||||||
the PortAudio community also makes the following non-binding requests:
|
|
||||||
|
|
||||||
Any person wishing to distribute modifications to the Software is
|
|
||||||
requested to send the modifications to the original developer so that
|
|
||||||
they can be incorporated into the canonical version. It is also
|
|
||||||
requested that these non-binding requests be included along with the
|
|
||||||
license above.
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,63 +0,0 @@
|
||||||
/* doxygen index page */
|
|
||||||
/** @mainpage
|
|
||||||
|
|
||||||
@section overview Overview
|
|
||||||
|
|
||||||
PortAudio is a cross-platform, open-source C language library for real-time audio input and output.
|
|
||||||
The library provides functions that allow your software to acquire and output real-time audio streams from your computer's hardware audio interfaces. It is designed to simplify writing cross-platform audio applications, and also to simplify the development of audio software in general by hiding the complexities of dealing directly with each native audio API. PortAudio is used to implement sound recording, editing and mixing applications, software synthesizers, effects processors, music players, internet telephony applications, software defined radios and more. Supported platforms include MS Windows, Mac OS X and Linux. Third-party language bindings make it possible to call PortAudio from other programming languages including @ref java_binding "Java", C++, C#, Python, PureBasic, FreePascal and Lazarus.
|
|
||||||
|
|
||||||
@section start_here Start here
|
|
||||||
|
|
||||||
- @ref api_overview <br>
|
|
||||||
A top-down view of the PortAudio API, its capabilities, functions and data structures
|
|
||||||
|
|
||||||
- @ref tutorial_start <br>
|
|
||||||
Get started writing code with PortAudio tutorials
|
|
||||||
|
|
||||||
- @ref examples_src "Examples"<br>
|
|
||||||
Simple example programs demonstrating PortAudio usage
|
|
||||||
|
|
||||||
- @ref License <br>
|
|
||||||
PortAudio is licenced under the MIT Expat open source licence. We make a non-binding request for you to contribute your changes back to the project.
|
|
||||||
|
|
||||||
|
|
||||||
@section reference API Reference
|
|
||||||
|
|
||||||
- portaudio.h Portable API<br>
|
|
||||||
Detailed documentation for each portable API function and data type
|
|
||||||
|
|
||||||
- @ref public_header "Host API Specific Extensions"<br>
|
|
||||||
Documentation for non-portable platform-specific host API extensions
|
|
||||||
|
|
||||||
|
|
||||||
@section resources Resources
|
|
||||||
|
|
||||||
- <a href="http://www.portaudio.com">The PortAudio website</a>
|
|
||||||
|
|
||||||
- <a href="http://www.portaudio.com/contacts.html">Our mailing list for users and developers</a><br>
|
|
||||||
|
|
||||||
- <a href="https://github.com/PortAudio/portaudio/wiki">The PortAudio wiki</a>
|
|
||||||
|
|
||||||
@section developer_resources Developer Resources
|
|
||||||
|
|
||||||
@if INTERNAL
|
|
||||||
- @ref srcguide
|
|
||||||
@endif
|
|
||||||
|
|
||||||
- <a href="https://github.com/PortAudio/portaudio/">Our repository on GitHub</a>
|
|
||||||
|
|
||||||
- <a href="https://github.com/PortAudio/portaudio/wiki/DeveloperGuidelines">Developer guidelines</a>
|
|
||||||
|
|
||||||
- <a href="https://github.com/PortAudio/portaudio/wiki/ImplementationStyleGuidelines">Implementation style guidelines</a>
|
|
||||||
|
|
||||||
If you're interested in helping out with PortAudio development we're more than happy for you to be involved.
|
|
||||||
Just drop by the PortAudio mailing list and ask how you can help.
|
|
||||||
Or check out these <a href="https://github.com/PortAudio/portaudio/issues?q=is%3Aopen+is%3Aissue+label%3A%22good+first+issue%22">
|
|
||||||
recommended starter issues</a>.
|
|
||||||
|
|
||||||
@section older_api_versions Older API Versions
|
|
||||||
|
|
||||||
This documentation covers the current API version: PortAudio V19, API version 2.0. API 2.0 differs in a number of ways from previous versions (most often encountered in PortAudio V18), please consult the enhancement proposals for details of what was added/changed for V19:
|
|
||||||
http://www.portaudio.com/docs/proposals/index.html
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,55 +0,0 @@
|
||||||
/*
|
|
||||||
define all of the file groups used to structure the documentation.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@defgroup public_header Public API definitions for users of PortAudio
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@internal
|
|
||||||
@defgroup common_src Source code common to all implementations
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@internal
|
|
||||||
@defgroup win_src Source code common to all Windows implementations
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@internal
|
|
||||||
@defgroup unix_src Source code common to all Unix implementations
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@internal
|
|
||||||
@defgroup macosx_src Source code common to all Macintosh implementations
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@internal
|
|
||||||
@defgroup hostapi_src Source code for specific Host APIs
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@internal
|
|
||||||
@defgroup test_src Test programs
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@defgroup examples_src Example programs demonstrating PortAudio usage
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@internal
|
|
||||||
@page srcguide A guide to the PortAudio sources
|
|
||||||
|
|
||||||
- \ref public_header
|
|
||||||
- \ref examples_src
|
|
||||||
- \ref common_src
|
|
||||||
- \ref win_src
|
|
||||||
- \ref unix_src
|
|
||||||
- \ref macosx_src
|
|
||||||
- \ref hostapi_src
|
|
||||||
- \ref test_src
|
|
||||||
*/
|
|
|
@ -1,68 +0,0 @@
|
||||||
/** @page blocking_read_write Blocking Read/Write Functions
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
PortAudio V19 adds a huge advance over previous versions with a feature called Blocking I/O. Although it may have lower performance that the callback method described earlier in this tutorial, blocking I/O is easier to understand and is, in some cases, more compatible with third party systems than the callback method. Most people starting audio programming also find Blocking I/O easier to learn.
|
|
||||||
|
|
||||||
Blocking I/O works in much the same way as the callback method except that instead of providing a function to provide (or consume) audio data, you must feed data to (or consume data from) PortAudio at regular intervals, usually inside a loop. The example below, excepted from patest_read_write_wire.c, shows how to open the default device, and pass data from its input to its output for a set period of time. Note that we use the default high latency values to help avoid underruns since we are usually reading and writing audio data from a relatively low priority thread, and there is usually extra buffering required to make blocking I/O work.
|
|
||||||
|
|
||||||
Note that not all API's implement Blocking I/O at this point, so for maximum portability or performance, you'll still want to use callbacks.
|
|
||||||
|
|
||||||
@code
|
|
||||||
/* -- initialize PortAudio -- */
|
|
||||||
err = Pa_Initialize();
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
/* -- setup input and output -- */
|
|
||||||
inputParameters.device = Pa_GetDefaultInputDevice(); /* default input device */
|
|
||||||
inputParameters.channelCount = NUM_CHANNELS;
|
|
||||||
inputParameters.sampleFormat = PA_SAMPLE_TYPE;
|
|
||||||
inputParameters.suggestedLatency = Pa_GetDeviceInfo( inputParameters.device )->defaultHighInputLatency ;
|
|
||||||
inputParameters.hostApiSpecificStreamInfo = NULL;
|
|
||||||
|
|
||||||
outputParameters.device = Pa_GetDefaultOutputDevice(); /* default output device */
|
|
||||||
outputParameters.channelCount = NUM_CHANNELS;
|
|
||||||
outputParameters.sampleFormat = PA_SAMPLE_TYPE;
|
|
||||||
outputParameters.suggestedLatency = Pa_GetDeviceInfo( outputParameters.device )->defaultHighOutputLatency;
|
|
||||||
outputParameters.hostApiSpecificStreamInfo = NULL;
|
|
||||||
|
|
||||||
/* -- setup stream -- */
|
|
||||||
err = Pa_OpenStream(
|
|
||||||
&stream,
|
|
||||||
&inputParameters,
|
|
||||||
&outputParameters,
|
|
||||||
SAMPLE_RATE,
|
|
||||||
FRAMES_PER_BUFFER,
|
|
||||||
paClipOff, /* we won't output out of range samples so don't bother clipping them */
|
|
||||||
NULL, /* no callback, use blocking API */
|
|
||||||
NULL ); /* no callback, so no callback userData */
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
/* -- start stream -- */
|
|
||||||
err = Pa_StartStream( stream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
printf("Wire on. Will run one minute.\n"); fflush(stdout);
|
|
||||||
|
|
||||||
/* -- Here's the loop where we pass data from input to output -- */
|
|
||||||
for( i=0; i<(60*SAMPLE_RATE)/FRAMES_PER_BUFFER; ++i )
|
|
||||||
{
|
|
||||||
err = Pa_WriteStream( stream, sampleBlock, FRAMES_PER_BUFFER );
|
|
||||||
if( err ) goto xrun;
|
|
||||||
err = Pa_ReadStream( stream, sampleBlock, FRAMES_PER_BUFFER );
|
|
||||||
if( err ) goto xrun;
|
|
||||||
}
|
|
||||||
/* -- Now we stop the stream -- */
|
|
||||||
err = Pa_StopStream( stream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
/* -- don't forget to cleanup! -- */
|
|
||||||
err = Pa_CloseStream( stream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
Pa_Terminate();
|
|
||||||
return 0;
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
Previous: \ref querying_devices | Next: \ref exploring
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,57 +0,0 @@
|
||||||
/** @page compile_cmake PortAudio on Windows, OS X or Linux via. CMake
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
@section cmake_building Building PortAudio stand-alone on Windows, OS X or Linux
|
|
||||||
|
|
||||||
CMake can be used to generate Visual Studio solutions on Windows, Makefiles (on Linux and OS X) and build metadata for other build systems for PortAudio. You should obtain a recent version of CMake from [http://www.cmake.org] if you do not have one already. If you are unfamiliar with CMake, this section will provide some information on using CMake to build PortAudio.
|
|
||||||
|
|
||||||
On Linux, CMake serves a very similar purpose to an autotools "configure" script - except it can generate build metadata apart from Makefiles. The equivalent of the following on POSIX'y systems:
|
|
||||||
|
|
||||||
build_path> {portaudio path}/configure --prefix=/install_location
|
|
||||||
build_path> make
|
|
||||||
build_path> make install
|
|
||||||
|
|
||||||
Would be:
|
|
||||||
|
|
||||||
build_path> cmake {portaudio path} -G "Unix Makefiles" -DCMAKE_INSTALL_PREFIX=/install_location
|
|
||||||
build_path> make
|
|
||||||
build_path> make install
|
|
||||||
|
|
||||||
The "-G" option specifies the type of build metadata which will be generated. You can obtain a list of supported build metadata formats by invoking (on any platform):
|
|
||||||
|
|
||||||
cmake -G
|
|
||||||
|
|
||||||
"make install" should install the same set of files that are installed using the usual configure script included with PortAudio along with a few extra files (similar to pkg-config metadata files) which make it easier for other CMake projects to use the installed libraries.
|
|
||||||
|
|
||||||
On Windows, you can use CMake to generate Visual Studio project files which can be used to create the PortAudio libraries. The following serves as an example (and should be done from a directory outside the PortAudio tree) which will create Visual Studio 2015 project files targeting a 64-bit build:
|
|
||||||
|
|
||||||
C:\PABUILD> cmake {portaudio path} -G "Visual Studio 14 2015 Win64"
|
|
||||||
|
|
||||||
After executing the above, you can either open the generated solution with Visual Studio or use CMake to invoke the build process. The following shows an example of how to build a release configuration (assuming the above command was executed previously in the same directory):
|
|
||||||
|
|
||||||
C:\PABUILD> cmake --build . --config Release
|
|
||||||
|
|
||||||
If you want ASIO support you need to obtain the ASIO2 SDK from Steinberg and place it according to \ref compile_windows_asio_msvc. Both ASIO and the DirectX SDK are automatically searched for by the CMake script - if they are found, they will be enabled by default.
|
|
||||||
|
|
||||||
@section cmake_using Using PortAudio in your CMake project
|
|
||||||
|
|
||||||
PortAudio defines the following CMake targets:
|
|
||||||
|
|
||||||
- "portaudio_static" for a static library and
|
|
||||||
- "portaudio" for a dynamic library
|
|
||||||
|
|
||||||
If you installed PortAudio as described above in \ref cmake_building and the install prefix you used (CMAKE_INSTALL_PREFIX) is in your system PATH or CMAKE_MODULE_PATH CMake variable, you should be able to use:
|
|
||||||
|
|
||||||
find_package(portaudio)
|
|
||||||
|
|
||||||
To define the "portaudio_static" and "portaudio" targets in your CMake project.
|
|
||||||
|
|
||||||
If you do not want to install portaudio into your system but would rather just have it get built as part of your own project (which may be particularly convenient on Windows), you may also use:
|
|
||||||
|
|
||||||
add_subdirectory("path to PortAudio location" "some binary directory" EXCLUDE_FROM_ALL)
|
|
||||||
|
|
||||||
EXCLUDE_FROM_ALL is not strictly necessary, but will ensure that targets which you don't use in your project won't get built.
|
|
||||||
|
|
||||||
Back to \ref tutorial_start
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,83 +0,0 @@
|
||||||
/** @page compile_linux Building Portaudio for Linux
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
<i>Note: this page has not been reviewed, and may contain errors.</i>
|
|
||||||
|
|
||||||
@section comp_linux1 Installing ALSA Development Kit
|
|
||||||
|
|
||||||
The OSS sound API is very old and not well supported. It is recommended that you use the ALSA sound API.
|
|
||||||
The PortAudio configure script will look for the ALSA SDK. You can install the ALSA SDK on Ubuntu using:
|
|
||||||
|
|
||||||
@code
|
|
||||||
sudo apt-get install libasound-dev
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
You might need to use yum, or some other package manager, instead of apt-get on your machine.
|
|
||||||
If you do not install ALSA then you might get a message when testing that says you have no audio devices.
|
|
||||||
|
|
||||||
You can find out more about ALSA here: http://www.alsa-project.org/
|
|
||||||
|
|
||||||
@section comp_linux2 Configuring and Compiling PortAudio
|
|
||||||
|
|
||||||
You can build PortAudio in Linux Environments using the standard configure/make tools:
|
|
||||||
|
|
||||||
@code
|
|
||||||
./configure && make
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
That will build PortAudio using Jack, ALSA and OSS in whatever combination they are found on your system. For example, if you have Jack and OSS but not ALSA, it will build using Jack and OSS but not ALSA. This step also builds a number of tests, which can be found in the bin directory of PortAudio. It's a good idea to run some of these tests to make sure PortAudio is working correctly.
|
|
||||||
|
|
||||||
@section comp_linux3 Using PortAudio in your Projects
|
|
||||||
|
|
||||||
To use PortAudio in your apps, you can simply install the .so files:
|
|
||||||
|
|
||||||
@code
|
|
||||||
sudo make install
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Projects built this way will expect PortAudio to be installed on target systems in order to run. If you want to build a more self-contained binary, you may use the libportaudio.a file:
|
|
||||||
|
|
||||||
@code
|
|
||||||
cp lib/.libs/libportaudio.a /YOUR/PROJECT/DIR
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
On some systems you may need to use:
|
|
||||||
|
|
||||||
@code
|
|
||||||
cp /usr/local/lib/libportaudio.a /YOUR/PROJECT/DIR
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
You may also need to copy portaudio.h, located in the include/ directory of PortAudio into your project. Note that you will usually need to link with the appropriate libraries that you used, such as ALSA and JACK, as well as with librt and libpthread. For example:
|
|
||||||
|
|
||||||
@code
|
|
||||||
gcc main.c libportaudio.a -lrt -lm -lasound -ljack -pthread -o YOUR_BINARY
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section comp_linux4 Linux Extensions
|
|
||||||
|
|
||||||
Note that the ALSA PortAudio back-end adds a few extensions to the standard API that you may take advantage of. To use these functions be sure to include the pa_linux_alsa.h file found in the include file in the PortAudio folder. This file contains further documentation on the following functions:
|
|
||||||
|
|
||||||
PaAlsaStreamInfo/PaAlsa_InitializeStreamInfo::
|
|
||||||
Objects of the !PaAlsaStreamInfo type may be used for the !hostApiSpecificStreamInfo attribute of a !PaStreamParameters object, in order to specify the name of an ALSA device to open directly. Specify the device via !PaAlsaStreamInfo.deviceString, after initializing the object with PaAlsa_InitializeStreamInfo.
|
|
||||||
|
|
||||||
PaAlsa_EnableRealtimeScheduling::
|
|
||||||
PA ALSA supports real-time scheduling of the audio callback thread (using the FIFO pthread scheduling policy), via the extension PaAlsa_EnableRealtimeScheduling. Call this on the stream before starting it with the <i>enableScheduling</i> parameter set to true or false, to enable or disable this behaviour respectively.
|
|
||||||
|
|
||||||
PaAlsa_GetStreamInputCard::
|
|
||||||
Use this function to get the ALSA-lib card index of the stream's input device.
|
|
||||||
|
|
||||||
PaAlsa_GetStreamOutputCard::
|
|
||||||
Use this function to get the ALSA-lib card index of the stream's output device.
|
|
||||||
|
|
||||||
Of particular importance is PaAlsa_EnableRealtimeScheduling, which allows ALSA to run at a high priority to prevent ordinary processes on the system from preempting audio playback. Without this, low latency audio playback will be irregular and will contain frequent drop-outs.
|
|
||||||
|
|
||||||
@section comp_linux5 Linux Debugging
|
|
||||||
|
|
||||||
Eliot Blennerhassett writes:
|
|
||||||
|
|
||||||
On linux build, use e.g. "libtool gdb bin/patest_sine8" to debug that program.
|
|
||||||
This is because on linux bin/patest_sine8 is a libtool shell script that wraps
|
|
||||||
bin/.libs/patest_sine8 and allows it to find the appropriate libraries within
|
|
||||||
the build tree.
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,122 +0,0 @@
|
||||||
/** @page compile_mac_coreaudio Building Portaudio for Mac OS X
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
@section comp_mac_ca_1 Requirements
|
|
||||||
|
|
||||||
* OS X 10.4 or later. PortAudio v19 currently only compiles and runs on OS X version 10.4 or later. Because of its heavy reliance on memory barriers, it's not clear how easy it would be to back-port PortAudio to OS X version 10.3. Leopard support requires the 2007 snapshot or later.
|
|
||||||
|
|
||||||
* Apple's Xcode and its related tools installed in the default location. There is no Xcode project for PortAudio.
|
|
||||||
|
|
||||||
* Mac 10.4 SDK. Look for "/Developer/SDKs/MacOSX10.4u.sdk" folder on your system. It may be installed with XCode. If not then you can download it from Apple Developer Connection. http://connect.apple.com/
|
|
||||||
|
|
||||||
@section comp_mac_ca_2 Building
|
|
||||||
|
|
||||||
To build PortAudio, simply use the Unix-style "./configure && make":
|
|
||||||
|
|
||||||
@code
|
|
||||||
./configure && make
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
You do <b>not</b> need to do "make install", and we don't recommend it; however, you may be using software that instructs you to do so, in which case you should follow those instructions. (Note from Phil: I had to do "sudo make install" after the command above, otherwise XCode complained that it could not find "/usr/local/lib/libportaudio.dylib" when I compiled an example.)
|
|
||||||
|
|
||||||
The result of these steps will be a file named "libportaudio.dylib" in the directory "usr/local/lib/".
|
|
||||||
|
|
||||||
By default, this will create universal binaries and therefore requires the Universal SDK from Apple, included with XCode 2.1 and higher.
|
|
||||||
|
|
||||||
@section comp_mac_ca_3 Other Build Options
|
|
||||||
|
|
||||||
There are a variety of other options for building PortAudio. The default described above is recommended as it is the most supported and tested; however, your needs may differ and require other options, which are described below.
|
|
||||||
|
|
||||||
@subsection comp_mac_ca_3.1 Building Non-Universal Libraries
|
|
||||||
|
|
||||||
By default, PortAudio is built as a universal binary. This includes 64-bit versions if you are compiling on 10.5, Leopard. If you want a "thin", or single architecture library, you have two options:
|
|
||||||
|
|
||||||
* build a non-universal library using configure options.
|
|
||||||
* use lipo(1) on whatever part of the library you plan to use.
|
|
||||||
|
|
||||||
Note that the first option may require an extremely recent version of PortAudio (February 5th '08 at least).
|
|
||||||
|
|
||||||
@subsection comp_mac_ca_3.2 Building with <i>--disable-mac-universal</i>
|
|
||||||
|
|
||||||
To build a non-universal library for the host architecture, simply use the <i>--disable-mac-universal</i> option with configure.
|
|
||||||
|
|
||||||
@code
|
|
||||||
./configure --disable-mac-universal && make
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The <i>--disable-mac-universal</i> option may also be used in conjunction with environment variables to give you more control over the universal binary build process. For example, to build a universal binary for the i386 and ppc architectures using the 10.4u sdk (which is the default on 10.4, but not 10.5), you might specify this configure command line:
|
|
||||||
|
|
||||||
@code
|
|
||||||
CFLAGS="-O2 -g -Wall -arch i386 -arch ppc -isysroot /Developer/SDKs/MacOSX10.4u.sdk -mmacosx-version-min=10.3" \
|
|
||||||
LDFLAGS="-arch i386 -arch ppc -isysroot /Developer/SDKs/MacOSX10.4u.sdk -mmacosx-version-min=10.3" \
|
|
||||||
./configure --disable-mac-universal --disable-dependency-tracking
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
For more info, see Apple's documentation on the matter:
|
|
||||||
|
|
||||||
* http://developer.apple.com/technotes/tn2005/tn2137.html
|
|
||||||
* http://developer.apple.com/documentation/Porting/Conceptual/PortingUnix/intro/chapter_1_section_1.html
|
|
||||||
|
|
||||||
@subsection comp_mac_ca_3.3 Using lipo
|
|
||||||
|
|
||||||
The second option is to build normally, and use lipo (1) to extract the architectures you want. For example, if you want a "thin", i386 library only:
|
|
||||||
|
|
||||||
@code
|
|
||||||
lipo lib/.libs/libportaudio.a -thin i386 -output libportaudio.a
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
or if you want to extract a single architecture fat file:
|
|
||||||
|
|
||||||
@code
|
|
||||||
lipo lib/.libs/libportaudio.a -extract i386 -output libportaudio.a
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@subsection comp_mac_ca_3.4 Building With Debug Options
|
|
||||||
|
|
||||||
By default, PortAudio on the mac is built without any debugging options. This is because asserts are generally inappropriate for a production environment and debugging information has been suspected, though not proven, to cause trouble with some interfaces. If you would like to compile with debugging, you must run configure with the appropriate flags. For example:
|
|
||||||
|
|
||||||
@code
|
|
||||||
./configure --enable-mac-debug && make
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
This will enable -g and disable -DNDEBUG which will effectively enable asserts.
|
|
||||||
|
|
||||||
@section comp_mac_ca_4 Using the Library in XCode Projects
|
|
||||||
|
|
||||||
If you are planning to follow the rest of the tutorial, several project types will work. You can create a "Standard Tool" under "Command Line Utility". If you are not following the rest of the tutorial, any type of project should work with PortAudio, but these instructions may not work perfectly.
|
|
||||||
|
|
||||||
Once you've compiled PortAudio, the easiest and recommended way to use PortAudio in your XCode project is to add "<portaudio>/include/portaudio.h" and "<portaudio>/lib/.libs/libportaudio.a" to your project. Because "<portaudio>/lib/.libs/" is a hidden directory, you won't be able to navigate to it using the finder or the standard Mac OS file dialogs by clicking on files and folders. You can use command-shift-G in the finder to specify the exact path, or, from the shell, if you are in the portaudio directory, you can enter this command:
|
|
||||||
|
|
||||||
@code
|
|
||||||
open lib/.libs
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Then drag the "libportaudio.a" file into your XCode project and place it in the "External Frameworks and Libraries" group, if the project type has it. If not you can simply add it to the top level folder of the project.
|
|
||||||
|
|
||||||
You will need to add the following frameworks to your XCode project:
|
|
||||||
|
|
||||||
- CoreAudio.framework
|
|
||||||
- AudioToolbox.framework
|
|
||||||
- AudioUnit.framework
|
|
||||||
- CoreServices.framework
|
|
||||||
- Carbon.framework
|
|
||||||
|
|
||||||
@section comp_mac_ca_5 Using the Library in Other Projects
|
|
||||||
|
|
||||||
For gcc/Make style projects, include "include/portaudio.h" and link "libportaudio.a", and use the frameworks listed in the previous section. How you do so depends on your build.
|
|
||||||
|
|
||||||
@section comp_mac_ca_6 Using Mac-only Extensions to PortAudio
|
|
||||||
|
|
||||||
For additional, Mac-only extensions to the PortAudio interface, you may also want to grab "include/pa_mac_core.h". This file contains some special, mac-only features relating to sample-rate conversion, channel mapping, performance and device hogging. See "src/hostapi/coreaudio/notes.txt" for more details on these features.
|
|
||||||
|
|
||||||
@section comp_mac_ca_7 What Happened to Makefile.darwin?
|
|
||||||
|
|
||||||
Note, there used to be a special makefile just for darwin. This is no longer supported because you can build universal binaries from the standard configure routine. If you find this file in your directory structure it means you have an outdated version of PortAudio.
|
|
||||||
|
|
||||||
@code
|
|
||||||
make -f Makefile.darwin
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Back to the Tutorial: \ref tutorial_start
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,108 +0,0 @@
|
||||||
/** @page compile_windows Building PortAudio for Windows using Microsoft Visual Studio
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
Below is a list of steps to build PortAudio into a dll and lib file. The resulting dll file may contain all five current win32 PortAudio APIs: MME, DirectSound, WASAPI, WDM/KS and ASIO, depending on the preprocessor definitions set in step 9 below.
|
|
||||||
|
|
||||||
PortAudio can be compiled using Visual C++ Express Edition which is available free from Microsoft. If you do not already have a C++ development environment, simply download and install. These instructions have been observed to succeed using Visual Studio 2010 as well.
|
|
||||||
|
|
||||||
1) Building PortAudio with DirectSound support requires the files <i>dsound.h</i> and <i>dsconf.h</i>. Download and install the DirectX SDK from http://www.microsoft.com/downloads/details.aspx?displaylang=en&FamilyID=3021d52b-514e-41d3-ad02-438a3ba730ba to obtain these files. If you installed the DirectX SDK then the DirectSound libraries and header files should be found automatically by Visual Studio/Visual C++. If you get an error saying dsound.h or dsconf.h is missing, you will need to add an extra include path to the Visual Studio project file referencing the DirectX includes directory.
|
|
||||||
|
|
||||||
2) For ASIO support, download the ASIO SDK from Steinberg at http://www.steinberg.net/en/company/developer.html . The SDK is free, but you will need to set up a developer account with Steinberg. To use the Visual Studio projects mentioned below, copy the entire ASIOSDK2 folder into src\\hostapi\\asio\\. Rename it from ASIOSDK2 to ASIOSDK. To build without ASIO (or other host API) see the "Building without ASIO support" section below.
|
|
||||||
|
|
||||||
3) If you have Visual Studio 6.0, 7.0(VC.NET/2001) or 7.1(VC.2003), open portaudio.dsp and convert if needed.
|
|
||||||
|
|
||||||
4) If you have Visual Studio 2005, Visual C++ 2008 Express Edition or Visual Studio 2010, open the portaudio.sln file located in build\\msvc\\. Doing so will open Visual Studio or Visual C++. Click "Finish" if a conversion wizard appears. The sln file contains four configurations: Win32 and Win64 in both Release and Debug variants.
|
|
||||||
|
|
||||||
@section comp_win1 For Visual Studio 2005, Visual C++ 2008 Express Edition or Visual Studio 2010
|
|
||||||
|
|
||||||
The steps below describe settings for recent versions of Visual Studio. Similar settings can be set in earlier versions of Visual Studio.
|
|
||||||
|
|
||||||
5) Open Project -> portaudio Properties and select "Configuration Properties" in the tree view.
|
|
||||||
|
|
||||||
6) Select "all configurations" in the "Configurations" combo box above. Select "All Platforms" in the "Platforms" combo box.
|
|
||||||
|
|
||||||
7) Now set a few options:
|
|
||||||
|
|
||||||
Required:
|
|
||||||
|
|
||||||
C/C++ -> Code Generation -> Runtime library = /MT
|
|
||||||
|
|
||||||
Optional:
|
|
||||||
|
|
||||||
C/C++ -> Optimization -> Omit frame pointers = Yes
|
|
||||||
|
|
||||||
Optional: C/C++ -> Code Generation -> Floating point model = fast
|
|
||||||
|
|
||||||
NOTE: When using PortAudio from C/C++ it is not usually necessary to explicitly set the structure member alignment; the default should work fine. However some languages require, for example, 4-byte alignment. If you are having problems with portaudio.h structure members not being properly read or written to, it may be necessary to explicitly set this value by going to C/C++ -> Code Generation -> Struct member alignment and setting it to an appropriate value (four is a common value). If your compiler is configurable, you should ensure that it is set to use the same structure member alignment value as used for the PortAudio build.
|
|
||||||
|
|
||||||
Click "Ok" when you have finished setting these parameters.
|
|
||||||
|
|
||||||
@section comp_win2 Preprocessor Definitions
|
|
||||||
|
|
||||||
Since the preprocessor definitions are different for each configuration and platform, you'll need to edit these individually for each configuration/platform combination that you want to modify using the "Configurations" and "Platforms" combo boxes.
|
|
||||||
|
|
||||||
8) To suppress PortAudio runtime debug console output, go to Project -> Properties -> Configuration Properties -> C/C++ -> Preprocessor. In the field 'Preprocessor Definitions', find PA_ENABLE_DEBUG_OUTPUT and remove it. The console will not output debug messages.
|
|
||||||
|
|
||||||
9) Also in the preprocessor definitions you need to explicitly define the native audio APIs you wish to use. For Windows the available API definitions are:
|
|
||||||
|
|
||||||
PA_USE_ASIO<br>
|
|
||||||
PA_USE_DS (DirectSound)<br>
|
|
||||||
PA_USE_WMME (MME)<br>
|
|
||||||
PA_USE_WASAPI<br>
|
|
||||||
PA_USE_WDMKS<br>
|
|
||||||
PA_USE_SKELETON
|
|
||||||
|
|
||||||
For each of these, the value of 0 indicates that support for this API should not be included. The value 1 indicates that support for this API should be included. (PA_USE_SKELETON is not usually used, it is a code sample for developers wanting to support a new API).
|
|
||||||
|
|
||||||
@section comp_win3 Building
|
|
||||||
|
|
||||||
As when setting Preprocessor definitions, building is a per-configuration per-platform process. Follow these instructions for each configuration/platform combination that you're interested in.
|
|
||||||
|
|
||||||
10) From the Build menu click Build -> Build solution. For 32-bit compilations, the dll file created by this process (portaudio_x86.dll) can be found in the directory build\\msvc\\Win32\\Release. For 64-bit compilations, the dll file is called portaudio_x64.dll, and is found in the directory build\\msvc\\x64\\Release.
|
|
||||||
|
|
||||||
11) Now, any project that requires portaudio can be linked with portaudio_x86.lib (or _x64) and include the relevant headers (portaudio.h, and/or pa_asio.h , pa_x86_plain_converters.h) You may want to add/remove some DLL entry points. At the time of writing the following 6 entries are not part of the official PortAudio API defined in portaudio.h:
|
|
||||||
|
|
||||||
(from portaudio.def)
|
|
||||||
@code
|
|
||||||
...
|
|
||||||
PaAsio_GetAvailableLatencyValues @50
|
|
||||||
PaAsio_ShowControlPanel @51
|
|
||||||
PaUtil_InitializeX86PlainConverters @52
|
|
||||||
PaAsio_GetInputChannelName @53
|
|
||||||
PaAsio_GetOutputChannelName @54
|
|
||||||
PaUtil_SetLogPrintFunction @55
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section comp_win4 Building without ASIO support
|
|
||||||
|
|
||||||
To build PortAudio without ASIO support you need to:
|
|
||||||
|
|
||||||
1) Make sure your project doesn't try to build any ASIO SDK files. If you're using one of the shipped projects, remove the ASIO related files from the project. In the shipped projects you can find them in the project tree under portaudio > Source Files > hostapi > ASIO > ASIOSDK
|
|
||||||
|
|
||||||
2) Make sure your project doesn't try to build the PortAudio ASIO implementation files:
|
|
||||||
|
|
||||||
@code
|
|
||||||
src\\hostapi\\pa_asio.cpp
|
|
||||||
src\\hostapi\\iasiothiscallresolver.cpp
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
If you're using one of the shipped projects, remove them from the project. In the shipped projects you can find them in the project tree under portaudio > Source Files > hostapi > ASIO
|
|
||||||
|
|
||||||
3) Define the preprocessor symbols in the project properties as described in step 9 above. In VS2005 this can be accomplished by selecting
|
|
||||||
Project Properties -> Configuration Properties -> C/C++ -> Preprocessor -> Preprocessor Definitions. Omitting PA_USE_ASIO or setting it to 0 stops src\\os\\win\\pa_win_hostapis.c from trying to initialize the PortAudio ASIO implementation.
|
|
||||||
|
|
||||||
4) Remove PaAsio_* entry points from portaudio.def
|
|
||||||
|
|
||||||
|
|
||||||
-----
|
|
||||||
David Viens, davidv@plogue.com
|
|
||||||
|
|
||||||
Updated by Chris on 5/26/2011
|
|
||||||
|
|
||||||
Improvements by John Clements on 12/15/2011
|
|
||||||
|
|
||||||
Edits by Ross on 1/20/2014
|
|
||||||
|
|
||||||
Back to the Tutorial: \ref tutorial_start
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,97 +0,0 @@
|
||||||
/** @page compile_windows_asio_msvc Building Portaudio for Windows with ASIO support using MSVC
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
@section comp_win_asiomsvc1 Portaudio Windows ASIO with MSVC
|
|
||||||
|
|
||||||
This tutorial describes how to build PortAudio with ASIO support using MSVC *from scratch*, without an existing Visual Studio project. For instructions for building PortAudio (including ASIO support) using the bundled Visual Studio project file see the compiling instructions for \ref compile_windows.
|
|
||||||
|
|
||||||
ASIO is a low latency audio API from Steinberg. To compile an ASIO
|
|
||||||
application, you must first download the ASIO SDK from Steinberg. You also
|
|
||||||
need to obtain ASIO drivers for your audio device. Download the ASIO SDK from Steinberg at http://www.steinberg.net/en/company/developer.html . The SDK is free but you will need to set up a developer account with Steinberg.
|
|
||||||
|
|
||||||
This tutorial assumes that you have 3 directories set up at the same level (side by side), one containing PortAudio, one containing the ASIO SDK and one containing your Visual Studio project:
|
|
||||||
|
|
||||||
@code
|
|
||||||
/ASIOSDK2
|
|
||||||
/portaudio
|
|
||||||
/DirContainingYourVisualStudioProject (should directly contain the .sln, .vcproj or .vcprojx etc.)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
First, make sure that the Steinberg SDK and the portaudio files are "side by side" in the same directory.
|
|
||||||
|
|
||||||
Open Microsoft Visual C++ and create a new blank Console exe Project/Workspace in that same directory.
|
|
||||||
|
|
||||||
For example, the paths for all three groups might read like this:
|
|
||||||
|
|
||||||
@code
|
|
||||||
C:\Program Files\Microsoft Visual Studio\VC98\My Projects\ASIOSDK2
|
|
||||||
C:\Program Files\Microsoft Visual Studio\VC98\My Projects\portaudio
|
|
||||||
C:\Program Files\Microsoft Visual Studio\VC98\My Projects\Sawtooth
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
Next, add the following Steinberg ASIO SDK files to the project Source Files:
|
|
||||||
|
|
||||||
@code
|
|
||||||
asio.cpp (ASIOSDK2\common)
|
|
||||||
asiodrivers.cpp (ASIOSDK2\host)
|
|
||||||
asiolist.cpp (ASIOSDK2\host\pc)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
Then, add the following PortAudio files to the project Source Files:
|
|
||||||
|
|
||||||
@code
|
|
||||||
pa_asio.cpp (portaudio\src\hostapi\asio)
|
|
||||||
pa_allocation.c (portaudio\src\common)
|
|
||||||
pa_converters.c (portaudio\src\common)
|
|
||||||
pa_cpuload.c (portaudio\src\common)
|
|
||||||
pa_dither.c (portaudio\src\common)
|
|
||||||
pa_front.c (portaudio\src\common)
|
|
||||||
pa_process.c (portaudio\src\common)
|
|
||||||
pa_ringbuffer.c (portaudio\src\common)
|
|
||||||
pa_stream.c (portaudio\src\common)
|
|
||||||
pa_trace.c (portaudio\src\common)
|
|
||||||
pa_win_hostapis.c (portaudio\src\os\win)
|
|
||||||
pa_win_util.c (portaudio\src\os\win)
|
|
||||||
pa_win_coinitialize.c (portaudio\src\os\win)
|
|
||||||
pa_win_waveformat.c (portaudio\src\os\win)
|
|
||||||
pa_x86_plain_converters.c (portaudio\src\os\win)
|
|
||||||
paex_saw.c (portaudio\examples) (Or another file containing main()
|
|
||||||
for the console exe to be built.)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
Although not strictly necessary, you may also want to add the following files to the project Header Files:
|
|
||||||
|
|
||||||
@code
|
|
||||||
portaudio.h (portaudio\include)
|
|
||||||
pa_asio.h (portaudio\include)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
These header files define the interfaces to the PortAudio API.
|
|
||||||
|
|
||||||
|
|
||||||
Next, go to Project Settings > All Configurations > C/C++ > Preprocessor > Preprocessor Definitions and add
|
|
||||||
PA_USE_ASIO=1 to any entries that might be there.
|
|
||||||
|
|
||||||
eg: WIN32;_CONSOLE;_MBCS changes to WIN32;_CONSOLE,_MBCS;PA_USE_ASIO=1
|
|
||||||
|
|
||||||
Then, on the same Project Settings tab, go down to Additional Include Directories (in VS2010 you'll find this setting under C/C++ > General) and enter the following relative include paths:
|
|
||||||
|
|
||||||
@code
|
|
||||||
..\portaudio\include;..\portaudio\src\common;..\portaudio\src\os\win;..\asiosdk2\common;..\asiosdk2\host;..\asiosdk2\host\pc
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
You'll need to make sure the relative paths are correct for the particular directory layout you're using. The above should work fine if you use the side-by-side layout we recommended earlier.
|
|
||||||
|
|
||||||
Some source code in the ASIO SDK is not compatible with the Win32 API UNICODE mode (The ASIO SDK expects the non-Unicode Win32 API). Therefore you need to make sure your project is set to not use Unicode. You do this by setting the project Character Set to "Use Multi-Byte Character Set" (NOT "Use Unicode Character Set"). In VS2010 the Character Set option can be found at Configuration Properties > General > Character Set. (An alternative to setting the project to non-Unicode is to patch asiolist.cpp to work when UNICODE is defined: put #undef UNICODE at the top of the file before windows.h is included.)
|
|
||||||
|
|
||||||
You should now be able to build any of the test executables in the portaudio\\examples directory.
|
|
||||||
We suggest that you start with paex_saw.c because it's one of the simplest example files.
|
|
||||||
|
|
||||||
--- Chris Share, Tom McCandless, Ross Bencina
|
|
||||||
|
|
||||||
Back to the Tutorial: \ref tutorial_start
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,56 +0,0 @@
|
||||||
/** @page compile_windows_mingw Building Portaudio for Windows with MinGW
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
@section comp_mingw1 Portaudio for Windows With MinGW
|
|
||||||
|
|
||||||
<strong>This document contains old or out-of-date information. Please see
|
|
||||||
a draft of new MinGW information on our
|
|
||||||
Wiki: <a href="https://github.com/PortAudio/portaudio/wiki/Notes_about_building_PortAudio_with_MinGW">
|
|
||||||
PortAudio Wiki: Notes about building PortAudio with MinGW</a></strong>
|
|
||||||
|
|
||||||
= MinGW/MSYS =
|
|
||||||
|
|
||||||
From the [http://www.mingw.org MinGW projectpage]:
|
|
||||||
|
|
||||||
MinGW: A collection of freely available and freely distributable
|
|
||||||
Windows specific header files and import libraries, augmenting
|
|
||||||
the GNU Compiler Collection, (GCC), and its associated
|
|
||||||
tools, (GNU binutils). MinGW provides a complete Open Source
|
|
||||||
programming tool set which is suitable for the development of
|
|
||||||
native Windows programs that do not depend on any 3rd-party C
|
|
||||||
runtime DLLs.
|
|
||||||
|
|
||||||
MSYS: A Minimal SYStem providing a POSIX compatible Bourne shell
|
|
||||||
environment, with a small collection of UNIX command line
|
|
||||||
tools. Primarily developed as a means to execute the configure
|
|
||||||
scripts and Makefiles used to build Open Source software, but
|
|
||||||
also useful as a general purpose command line interface to
|
|
||||||
replace Windows cmd.exe.
|
|
||||||
|
|
||||||
MinGW provides a compiler/linker toolchain while MSYS is required
|
|
||||||
to actually run the PortAudio configure script.
|
|
||||||
|
|
||||||
Once MinGW and MSYS are installed (see the [http://www.mingw.org/MinGWiki MinGW-Wiki]) open an MSYS shell and run the famous:
|
|
||||||
|
|
||||||
@code
|
|
||||||
./configure
|
|
||||||
make
|
|
||||||
make install
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The above should create a working version though you might want to
|
|
||||||
provide '--prefix=<path-to-install-dir>' to configure.
|
|
||||||
|
|
||||||
'./configure --help' gives details as to what can be tinkered with.
|
|
||||||
|
|
||||||
--- Mikael Magnusson
|
|
||||||
|
|
||||||
To update your copy or check out a fresh copy of the source
|
|
||||||
|
|
||||||
[wiki:UsingThePortAudioSvnRepository SVN instructions]
|
|
||||||
|
|
||||||
--- Bob !McGwier
|
|
||||||
|
|
||||||
Back to the Tutorial: \ref tutorial_start
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,15 +0,0 @@
|
||||||
/** @page exploring Exploring PortAudio
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
Now that you have a good idea of how PortAudio works, you can try out the example programs. You'll find them in the examples/ directory in the PortAudio distribution.
|
|
||||||
|
|
||||||
For an example of playing a sine wave, see examples/paex_sine.c.
|
|
||||||
|
|
||||||
For an example of recording and playing back a sound, see examples/paex_record.c.
|
|
||||||
|
|
||||||
I also encourage you to examine the source for the PortAudio libraries. If you have suggestions on ways to improve them, please let us know. If you want to implement PortAudio on a new platform, please let us know as well so we can coordinate people's efforts.
|
|
||||||
|
|
||||||
|
|
||||||
Previous: \ref blocking_read_write | Next: This is the end of the tutorial.
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,29 +0,0 @@
|
||||||
/** @page initializing_portaudio Initializing PortAudio
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
@section tut_init1 Initializing PortAudio
|
|
||||||
|
|
||||||
Before making any other calls to PortAudio, you 'must' call Pa_Initialize(). This will trigger a scan of available devices which can be queried later. Like most PA functions, it will return a result of type paError. If the result is not paNoError, then an error has occurred.
|
|
||||||
@code
|
|
||||||
err = Pa_Initialize();
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
You can get a text message that explains the error message by passing it to Pa_GetErrorText( err ). For Example:
|
|
||||||
|
|
||||||
@code
|
|
||||||
printf( "PortAudio error: %s\n", Pa_GetErrorText( err ) );
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
It is also important, when you are done with PortAudio, to Terminate it:
|
|
||||||
|
|
||||||
@code
|
|
||||||
err = Pa_Terminate();
|
|
||||||
if( err != paNoError )
|
|
||||||
printf( "PortAudio error: %s\n", Pa_GetErrorText( err ) );
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
Previous: \ref writing_a_callback | Next: \ref open_default_stream
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,48 +0,0 @@
|
||||||
/** @page open_default_stream Opening a Stream Using Defaults
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
The next step is to open a stream, which is similar to opening a file. You can specify whether you want audio input and/or output, how many channels, the data format, sample rate, etc. Opening a ''default'' stream means opening the default input and output devices, which saves you the trouble of getting a list of devices and choosing one from the list. (We'll see how to do that later.)
|
|
||||||
@code
|
|
||||||
#define SAMPLE_RATE (44100)
|
|
||||||
static paTestData data;
|
|
||||||
|
|
||||||
.....
|
|
||||||
|
|
||||||
PaStream *stream;
|
|
||||||
PaError err;
|
|
||||||
|
|
||||||
/* Open an audio I/O stream. */
|
|
||||||
err = Pa_OpenDefaultStream( &stream,
|
|
||||||
0, /* no input channels */
|
|
||||||
2, /* stereo output */
|
|
||||||
paFloat32, /* 32 bit floating point output */
|
|
||||||
SAMPLE_RATE,
|
|
||||||
256, /* frames per buffer, i.e. the number
|
|
||||||
of sample frames that PortAudio will
|
|
||||||
request from the callback. Many apps
|
|
||||||
may want to use
|
|
||||||
paFramesPerBufferUnspecified, which
|
|
||||||
tells PortAudio to pick the best,
|
|
||||||
possibly changing, buffer size.*/
|
|
||||||
patestCallback, /* this is your callback function */
|
|
||||||
&data ); /*This is a pointer that will be passed to
|
|
||||||
your callback*/
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The data structure and callback are described in \ref writing_a_callback.
|
|
||||||
|
|
||||||
The above example opens the stream for writing, which is sufficient for playback. It is also possible to open a stream for reading, to do recording, or both reading and writing, for simultaneous recording and playback or even real-time audio processing. If you plan to do playback and recording at the same time, open only one stream with valid input and output parameters.
|
|
||||||
|
|
||||||
There are some caveats to note about simultaneous read/write:
|
|
||||||
|
|
||||||
- Some platforms can only open a read/write stream using the same device.
|
|
||||||
- Although multiple streams can be opened, it is difficult to synchronize them.
|
|
||||||
- Some platforms don't support opening multiple streams on the same device.
|
|
||||||
- Using multiple streams may not be as well tested as other features.
|
|
||||||
- The PortAudio library calls must be made from the same thread or synchronized by the user.
|
|
||||||
|
|
||||||
|
|
||||||
Previous: \ref initializing_portaudio | Next: \ref start_stop_abort
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,111 +0,0 @@
|
||||||
/** @page querying_devices Enumerating and Querying PortAudio Devices
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
@section tut_query1 Querying Devices
|
|
||||||
|
|
||||||
It is often fine to use the default device as we did previously in this tutorial, but there are times when you'll want to explicitly choose the device from a list of available devices on the system. To see a working example of this, check out pa_devs.c in the tests/ directory of the PortAudio source code. To do so, you'll need to first initialize PortAudio and Query for the number of Devices:
|
|
||||||
|
|
||||||
@code
|
|
||||||
int numDevices;
|
|
||||||
|
|
||||||
numDevices = Pa_GetDeviceCount();
|
|
||||||
if( numDevices < 0 )
|
|
||||||
{
|
|
||||||
printf( "ERROR: Pa_CountDevices returned 0x%x\n", numDevices );
|
|
||||||
err = numDevices;
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
If you want to get information about each device, simply loop through as follows:
|
|
||||||
|
|
||||||
@code
|
|
||||||
const PaDeviceInfo *deviceInfo;
|
|
||||||
|
|
||||||
for( i=0; i<numDevices; i++ )
|
|
||||||
{
|
|
||||||
deviceInfo = Pa_GetDeviceInfo( i );
|
|
||||||
...
|
|
||||||
}
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The Pa_DeviceInfo structure contains a wealth of information such as the name of the devices, the default latency associated with the devices and more. The structure has the following fields:
|
|
||||||
|
|
||||||
@code
|
|
||||||
int structVersion
|
|
||||||
const char * name
|
|
||||||
PaHostApiIndex hostApi
|
|
||||||
int maxInputChannels
|
|
||||||
int maxOutputChannels
|
|
||||||
PaTime defaultLowInputLatency
|
|
||||||
PaTime defaultLowOutputLatency
|
|
||||||
PaTime defaultHighInputLatency
|
|
||||||
PaTime defaultHighOutputLatency
|
|
||||||
double defaultSampleRate
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
You may notice that you can't determine, from this information alone, whether or not a particular sample rate is supported. This is because some devices support ranges of sample rates, others support, a list of sample rates, and still others support some sample rates and number of channels combinations but not others. To get around this, PortAudio offers a function for testing a particular device with a given format:
|
|
||||||
|
|
||||||
@code
|
|
||||||
const PaStreamParameters *inputParameters;
|
|
||||||
const PaStreamParameters *outputParameters;
|
|
||||||
double desiredSampleRate;
|
|
||||||
...
|
|
||||||
PaError err;
|
|
||||||
|
|
||||||
err = Pa_IsFormatSupported( inputParameters, outputParameters, desiredSampleRate );
|
|
||||||
if( err == paFormatIsSupported )
|
|
||||||
{
|
|
||||||
printf( "Hooray!\n");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
printf("Too Bad.\n");
|
|
||||||
}
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Filling in the inputParameters and outputParameters fields is shown in a moment.
|
|
||||||
|
|
||||||
Once you've found a configuration you like, or one you'd like to go ahead and try, you can open the stream by filling in the PaStreamParameters structures, and calling Pa_OpenStream:
|
|
||||||
|
|
||||||
@code
|
|
||||||
double srate = ... ;
|
|
||||||
PaStream *stream;
|
|
||||||
unsigned long framesPerBuffer = ... ; //could be paFramesPerBufferUnspecified, in which case PortAudio will do its best to manage it for you, but, on some platforms, the framesPerBuffer will change in each call to the callback
|
|
||||||
PaStreamParameters outputParameters;
|
|
||||||
PaStreamParameters inputParameters;
|
|
||||||
|
|
||||||
bzero( &inputParameters, sizeof( inputParameters ) ); //not necessary if you are filling in all the fields
|
|
||||||
inputParameters.channelCount = inChan;
|
|
||||||
inputParameters.device = inDevNum;
|
|
||||||
inputParameters.hostApiSpecificStreamInfo = NULL;
|
|
||||||
inputParameters.sampleFormat = paFloat32;
|
|
||||||
inputParameters.suggestedLatency = Pa_GetDeviceInfo(inDevNum)->defaultLowInputLatency ;
|
|
||||||
inputParameters.hostApiSpecificStreamInfo = NULL; //See you specific host's API docs for info on using this field
|
|
||||||
|
|
||||||
|
|
||||||
bzero( &outputParameters, sizeof( outputParameters ) ); //not necessary if you are filling in all the fields
|
|
||||||
outputParameters.channelCount = outChan;
|
|
||||||
outputParameters.device = outDevNum;
|
|
||||||
outputParameters.hostApiSpecificStreamInfo = NULL;
|
|
||||||
outputParameters.sampleFormat = paFloat32;
|
|
||||||
outputParameters.suggestedLatency = Pa_GetDeviceInfo(outDevNum)->defaultLowOutputLatency ;
|
|
||||||
outputParameters.hostApiSpecificStreamInfo = NULL; //See you specific host's API docs for info on using this field
|
|
||||||
|
|
||||||
err = Pa_OpenStream(
|
|
||||||
&stream,
|
|
||||||
&inputParameters,
|
|
||||||
&outputParameters,
|
|
||||||
srate,
|
|
||||||
framesPerBuffer,
|
|
||||||
paNoFlag, //flags that can be used to define dither, clip settings and more
|
|
||||||
portAudioCallback, //your callback function
|
|
||||||
(void *)this ); //data to be passed to callback. In C++, it is frequently (void *)this
|
|
||||||
//don't forget to check errors!
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
Previous: \ref utility_functions | Next: \ref blocking_read_write
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,35 +0,0 @@
|
||||||
/** @page start_stop_abort Starting, Stopping and Aborting a Stream
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
@section tut_startstop1 Starting, Stopping and Aborting a Stream
|
|
||||||
|
|
||||||
PortAudio will not start playing back audio until you start the stream. After calling Pa_StartStream(), PortAudio will start calling your callback function to perform the audio processing.
|
|
||||||
|
|
||||||
@code
|
|
||||||
err = Pa_StartStream( stream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
You can communicate with your callback routine through the data structure you passed in on the open call, or through global variables, or using other interprocess communication techniques, but please be aware that your callback function may be called at interrupt time when your foreground process is least expecting it. So avoid sharing complex data structures that are easily corrupted like double linked lists, and avoid using locks such as mutexes as this may cause your callback function to block and therefore drop audio. Such techniques may even cause deadlock on some platforms.
|
|
||||||
|
|
||||||
PortAudio will continue to call your callback and process audio until you stop the stream. This can be done in one of several ways, but, before we do so, we'll want to see that some of our audio gets processed by sleeping for a few seconds. This is easy to do with Pa_Sleep(), which is used by many of the examples in the patests/ directory for exactly this purpose. Note that, for a variety of reasons, you can not rely on this function for accurate scheduling, so your stream may not run for exactly the same amount of time as you expect, but it's good enough for our example.
|
|
||||||
|
|
||||||
@code
|
|
||||||
/* Sleep for several seconds. */
|
|
||||||
Pa_Sleep(NUM_SECONDS*1000);
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Now we need to stop playback. There are several ways to do this, the simplest of which is to call Pa_StopStream():
|
|
||||||
|
|
||||||
@code
|
|
||||||
err = Pa_StopStream( stream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Pa_StopStream() is designed to make sure that the buffers you've processed in your callback are all played, which may cause some delay. Alternatively, you could call Pa_AbortStream(). On some platforms, aborting the stream is much faster and may cause some data processed by your callback not to be played.
|
|
||||||
|
|
||||||
Another way to stop the stream is to return either paComplete, or paAbort from your callback. paComplete ensures that the last buffer is played whereas paAbort stops the stream as soon as possible. If you stop the stream using this technique, you will need to call Pa_StopStream() before starting the stream again.
|
|
||||||
|
|
||||||
Previous: \ref open_default_stream | Next: \ref terminating_portaudio
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,20 +0,0 @@
|
||||||
/** @page terminating_portaudio Closing a Stream and Terminating PortAudio
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
When you are done with a stream, you should close it to free up resources:
|
|
||||||
|
|
||||||
@code
|
|
||||||
err = Pa_CloseStream( stream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
We've already mentioned this in \ref initializing_portaudio, but in case you forgot, be sure to terminate PortAudio when you are done:
|
|
||||||
|
|
||||||
@code
|
|
||||||
err = Pa_Terminate( );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Previous: \ref start_stop_abort | Next: \ref utility_functions
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,61 +0,0 @@
|
||||||
/** @page tutorial_start PortAudio Tutorials
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
These tutorials takes you through a hands-on example of using PortAudio to make sound. If you'd prefer to start with a top-down overview of the PortAudio API, check out the @ref api_overview.
|
|
||||||
|
|
||||||
@section tut_start1 Downloading
|
|
||||||
|
|
||||||
First thing you need to do is download the PortAudio source code either <a href="http://www.portaudio.com/download.html">as a tarball from the website</a>, or <a href="http://www.portaudio.com/usingsvn.html">from the Subversion Repository</a>.
|
|
||||||
|
|
||||||
@section tut_start2 Compiling
|
|
||||||
|
|
||||||
Once you've downloaded PortAudio you'll need to compile it, which of course, depends on your environment:
|
|
||||||
|
|
||||||
- Windows
|
|
||||||
- \ref compile_windows
|
|
||||||
- \ref compile_windows_mingw
|
|
||||||
- \ref compile_windows_asio_msvc
|
|
||||||
- Mac OS X
|
|
||||||
- \ref compile_mac_coreaudio
|
|
||||||
- POSIX
|
|
||||||
- \ref compile_linux
|
|
||||||
|
|
||||||
You can also use CMake to generate project files for PortAudio on Windows, OS X or Linux or include PortAudio easily in your own CMake project. See \ref compile_cmake.
|
|
||||||
|
|
||||||
Many platforms with GCC/make can use the simple ./configure && make combination and simply use the resulting libraries in their code.
|
|
||||||
|
|
||||||
@section tut_start3 Programming with PortAudio
|
|
||||||
|
|
||||||
Below are the steps to writing a PortAudio application using the callback technique:
|
|
||||||
|
|
||||||
- Write a callback function that will be called by PortAudio when audio processing is needed.
|
|
||||||
- Initialize the PA library and open a stream for audio I/O.
|
|
||||||
- Start the stream. Your callback function will be now be called repeatedly by PA in the background.
|
|
||||||
- In your callback you can read audio data from the inputBuffer and/or write data to the outputBuffer.
|
|
||||||
- Stop the stream by returning 1 from your callback, or by calling a stop function.
|
|
||||||
- Close the stream and terminate the library.
|
|
||||||
|
|
||||||
In addition to this "Callback" architecture, V19 also supports a "Blocking I/O" model which uses read and write calls which may be more familiar to non-audio programmers. Note that at this time, not all APIs support this functionality.
|
|
||||||
|
|
||||||
In this tutorial, we'll show how to use the callback architecture to play a sawtooth wave. Much of the tutorial is taken from the file paex_saw.c, which is part of the PortAudio distribution. When you're done with this tutorial, you'll be armed with the basic knowledge you need to write an audio program. If you need more sample code, look in the "examples" and "test" directory of the PortAudio distribution. Another great source of info is the portaudio.h Doxygen page, which documents the entire V19 API.
|
|
||||||
Also see the page for <a href="https://github.com/PortAudio/portaudio/wiki/Tips">tips on programming PortAudio</a>
|
|
||||||
on the PortAudio wiki.
|
|
||||||
|
|
||||||
@section tut_start4 Programming Tutorial Contents
|
|
||||||
|
|
||||||
- \ref writing_a_callback
|
|
||||||
- \ref initializing_portaudio
|
|
||||||
- \ref open_default_stream
|
|
||||||
- \ref start_stop_abort
|
|
||||||
- \ref terminating_portaudio
|
|
||||||
- \ref utility_functions
|
|
||||||
- \ref querying_devices
|
|
||||||
- \ref blocking_read_write
|
|
||||||
|
|
||||||
If you are upgrading from V18, you may want to look at the <a href="http://www.portaudio.com/docs/proposals/index.html">Proposed Enhancements to PortAudio</a>, which describes the differences between V18 and V19.
|
|
||||||
|
|
||||||
Once you have a basic understanding of how to use PortAudio, you might be interested in \ref exploring.
|
|
||||||
|
|
||||||
Next: \ref writing_a_callback
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,69 +0,0 @@
|
||||||
/** @page utility_functions Utility Functions
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
In addition to the functions described elsewhere in this tutorial, PortAudio provides a number of Utility functions that are useful in a variety of circumstances.
|
|
||||||
You'll want to read the portaudio.h reference, which documents the entire V19 API for details, but we'll try to cover the basics here.
|
|
||||||
|
|
||||||
@section tut_util2 Version Information
|
|
||||||
|
|
||||||
PortAudio offers two functions to determine the PortAudio Version. This is most useful when you are using PortAudio as a dynamic library, but it may also be useful at other times.
|
|
||||||
|
|
||||||
@code
|
|
||||||
int Pa_GetVersion (void)
|
|
||||||
const char * Pa_GetVersionText (void)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section tut_util3 Error Text
|
|
||||||
|
|
||||||
PortAudio allows you to get error text from an error number.
|
|
||||||
|
|
||||||
@code
|
|
||||||
const char * Pa_GetErrorText (PaError errorCode)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section tut_util4 Stream State
|
|
||||||
|
|
||||||
PortAudio Streams exist in 3 states: Active, Stopped, and Callback Stopped. If a stream is in callback stopped state, you'll need to stop it before you can start it again. If you need to query the state of a PortAudio stream, there are two functions for doing so:
|
|
||||||
|
|
||||||
@code
|
|
||||||
PaError Pa_IsStreamStopped (PaStream *stream)
|
|
||||||
PaError Pa_IsStreamActive (PaStream *stream)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section tut_util5 Stream Info
|
|
||||||
|
|
||||||
If you need to retrieve info about a given stream, such as latency, and sample rate info, there's a function for that too:
|
|
||||||
|
|
||||||
@code
|
|
||||||
const PaStreamInfo * Pa_GetStreamInfo (PaStream *stream)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section tut_util6 Stream Time
|
|
||||||
|
|
||||||
If you need to synchronise other activities such as display updates or MIDI output with the PortAudio callback you need to know the current time according to the same timebase used by the stream callback timestamps.
|
|
||||||
|
|
||||||
@code
|
|
||||||
PaTime Pa_GetStreamTime (PaStream *stream)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section tut_util6CPU Usage
|
|
||||||
|
|
||||||
To determine how much CPU is being used by the callback, use these:
|
|
||||||
|
|
||||||
@code
|
|
||||||
double Pa_GetStreamCpuLoad (PaStream *stream)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section tut_util7 Other utilities
|
|
||||||
|
|
||||||
These functions allow you to determine the size of a sample from its format and sleep for a given amount of time. The sleep function should not be used for precise timing or synchronization because it makes few guarantees about the exact length of time it waits. It is most useful for testing.
|
|
||||||
|
|
||||||
@code
|
|
||||||
PaError Pa_GetSampleSize (PaSampleFormat format)
|
|
||||||
void Pa_Sleep (long msec)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
Previous: \ref terminating_portaudio | Next: \ref querying_devices
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,70 +0,0 @@
|
||||||
/** @page writing_a_callback Writing a Callback Function
|
|
||||||
@ingroup tutorial
|
|
||||||
|
|
||||||
To write a program using PortAudio, you must include the "portaudio.h" include file. You may wish to read "portaudio.h" because it contains a complete description of the PortAudio functions and constants. Alternatively, you could browse the [http://www.portaudio.com/docs/v19-doxydocs/portaudio_8h.html "portaudio.h" Doxygen page]
|
|
||||||
@code
|
|
||||||
#include "portaudio.h"
|
|
||||||
@endcode
|
|
||||||
The next task is to write your own "callback" function. The "callback" is a function that is called by the PortAudio engine whenever it has captured audio data, or when it needs more audio data for output.
|
|
||||||
|
|
||||||
Before we begin, it's important to realize that the callback is a delicate place. This is because some systems perform the callback in a special thread, or interrupt handler, and it is rarely treated the same as the rest of your code.
|
|
||||||
For most modern systems, you won't be able to cause crashes by making disallowed calls in the callback, but if you want your code to produce glitch-free audio, you will have to make sure you avoid function calls that may take an unbounded amount of time
|
|
||||||
to execute. Exactly what these are depend on your platform but almost certainly include the following: memory allocation/deallocation, I/O (including file I/O as well as console I/O, such as printf()), context switching (such as exec() or
|
|
||||||
yield()), mutex operations, or anything else that might rely on the OS. If you think short critical sections are safe please go read about priority inversion. Windows amd Mac OS schedulers have no real-time safe priority inversion prevention. Other platforms require special mutex flags. In addition, it is not safe to call any PortAudio API functions in the callback except as explicitly permitted in the documentation.
|
|
||||||
|
|
||||||
|
|
||||||
Your callback function must return an int and accept the exact parameters specified in this typedef:
|
|
||||||
|
|
||||||
@code
|
|
||||||
typedef int PaStreamCallback( const void *input,
|
|
||||||
void *output,
|
|
||||||
unsigned long frameCount,
|
|
||||||
const PaStreamCallbackTimeInfo* timeInfo,
|
|
||||||
PaStreamCallbackFlags statusFlags,
|
|
||||||
void *userData ) ;
|
|
||||||
@endcode
|
|
||||||
Here is an example callback function from the test file "patests/patest_saw.c". It calculates a simple left and right sawtooth signal and writes it to the output buffer. Notice that in this example, the signals are of float data type. The signals must be between -1.0 and +1.0. You can also use 16 bit integers or other formats which are specified during setup, but floats are easiest to work with. You can pass a pointer to your data structure through PortAudio which will appear as userData.
|
|
||||||
|
|
||||||
@code
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
float left_phase;
|
|
||||||
float right_phase;
|
|
||||||
}
|
|
||||||
paTestData;
|
|
||||||
|
|
||||||
/* This routine will be called by the PortAudio engine when audio is needed.
|
|
||||||
** It may called at interrupt level on some machines so don't do anything
|
|
||||||
** that could mess up the system like calling malloc() or free().
|
|
||||||
*/
|
|
||||||
static int patestCallback( const void *inputBuffer, void *outputBuffer,
|
|
||||||
unsigned long framesPerBuffer,
|
|
||||||
const PaStreamCallbackTimeInfo* timeInfo,
|
|
||||||
PaStreamCallbackFlags statusFlags,
|
|
||||||
void *userData )
|
|
||||||
{
|
|
||||||
/* Cast data passed through stream to our structure. */
|
|
||||||
paTestData *data = (paTestData*)userData;
|
|
||||||
float *out = (float*)outputBuffer;
|
|
||||||
unsigned int i;
|
|
||||||
(void) inputBuffer; /* Prevent unused variable warning. */
|
|
||||||
|
|
||||||
for( i=0; i<framesPerBuffer; i++ )
|
|
||||||
{
|
|
||||||
*out++ = data->left_phase; /* left */
|
|
||||||
*out++ = data->right_phase; /* right */
|
|
||||||
/* Generate simple sawtooth phaser that ranges between -1.0 and 1.0. */
|
|
||||||
data->left_phase += 0.01f;
|
|
||||||
/* When signal reaches top, drop back down. */
|
|
||||||
if( data->left_phase >= 1.0f ) data->left_phase -= 2.0f;
|
|
||||||
/* higher pitch so we can distinguish left and right. */
|
|
||||||
data->right_phase += 0.03f;
|
|
||||||
if( data->right_phase >= 1.0f ) data->right_phase -= 2.0f;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Previous: \ref tutorial_start | Next: \ref initializing_portaudio
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,87 +0,0 @@
|
||||||
import os
|
|
||||||
import os.path
|
|
||||||
import string
|
|
||||||
|
|
||||||
paRootDirectory = '../../'
|
|
||||||
paHtmlDocDirectory = os.path.join( paRootDirectory, "doc", "html" )
|
|
||||||
|
|
||||||
## Script to check documentation status
|
|
||||||
## this script assumes that html doxygen documentation has been generated
|
|
||||||
##
|
|
||||||
## it then walks the entire portaudio source tree and check that
|
|
||||||
## - every source file (.c,.h,.cpp) has a doxygen comment block containing
|
|
||||||
## - a @file directive
|
|
||||||
## - a @brief directive
|
|
||||||
## - a @ingroup directive
|
|
||||||
## - it also checks that a corresponding html documentation file has been generated.
|
|
||||||
##
|
|
||||||
## This can be used as a first-level check to make sure the documentation is in order.
|
|
||||||
##
|
|
||||||
## The idea is to get a list of which files are missing doxygen documentation.
|
|
||||||
##
|
|
||||||
## How to run:
|
|
||||||
## $ cd doc/utils
|
|
||||||
## $ python checkfiledocs.py
|
|
||||||
|
|
||||||
def oneOf_a_in_b(a, b):
|
|
||||||
for x in a:
|
|
||||||
if x in b:
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
|
|
||||||
# recurse from top and return a list of all with the given
|
|
||||||
# extensions. ignore .svn directories. return absolute paths
|
|
||||||
def recursiveFindFiles( top, extensions, dirBlacklist, includePaths ):
|
|
||||||
result = []
|
|
||||||
for (dirpath, dirnames, filenames) in os.walk(top):
|
|
||||||
if not oneOf_a_in_b(dirBlacklist, dirpath):
|
|
||||||
for f in filenames:
|
|
||||||
if os.path.splitext(f)[1] in extensions:
|
|
||||||
if includePaths:
|
|
||||||
result.append( os.path.abspath( os.path.join( dirpath, f ) ) )
|
|
||||||
else:
|
|
||||||
result.append( f )
|
|
||||||
return result
|
|
||||||
|
|
||||||
# generate the html file name that doxygen would use for
|
|
||||||
# a particular source file. this is a brittle conversion
|
|
||||||
# which i worked out by trial and error
|
|
||||||
def doxygenHtmlDocFileName( sourceFile ):
|
|
||||||
return sourceFile.replace( '_', '__' ).replace( '.', '_8' ) + '.html'
|
|
||||||
|
|
||||||
|
|
||||||
sourceFiles = recursiveFindFiles( os.path.join(paRootDirectory,'src'), [ '.c', '.h', '.cpp' ], ['.svn', 'mingw-include'], True );
|
|
||||||
sourceFiles += recursiveFindFiles( os.path.join(paRootDirectory,'include'), [ '.c', '.h', '.cpp' ], ['.svn'], True );
|
|
||||||
docFiles = recursiveFindFiles( paHtmlDocDirectory, [ '.html' ], ['.svn'], False );
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
currentFile = ""
|
|
||||||
|
|
||||||
def printError( f, message ):
|
|
||||||
global currentFile
|
|
||||||
if f != currentFile:
|
|
||||||
currentFile = f
|
|
||||||
print f, ":"
|
|
||||||
print "\t!", message
|
|
||||||
|
|
||||||
|
|
||||||
for f in sourceFiles:
|
|
||||||
if not doxygenHtmlDocFileName( os.path.basename(f) ) in docFiles:
|
|
||||||
printError( f, "no doxygen generated doc page" )
|
|
||||||
|
|
||||||
s = file( f, 'rt' ).read()
|
|
||||||
|
|
||||||
if not '/**' in s:
|
|
||||||
printError( f, "no doxygen /** block" )
|
|
||||||
|
|
||||||
if not '@file' in s:
|
|
||||||
printError( f, "no doxygen @file tag" )
|
|
||||||
|
|
||||||
if not '@brief' in s:
|
|
||||||
printError( f, "no doxygen @brief tag" )
|
|
||||||
|
|
||||||
if not '@ingroup' in s:
|
|
||||||
printError( f, "no doxygen @ingroup tag" )
|
|
||||||
|
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
rem Use Astyle to fix style in 'C' files
|
|
||||||
cd %1%
|
|
||||||
|
|
||||||
fixlines -p *.c
|
|
||||||
fixlines -p *.cpp
|
|
||||||
fixlines -p *.cc
|
|
||||||
|
|
||||||
astyle --style=ansi -c -o --convert-tabs --indent-preprocessor *.c
|
|
||||||
astyle --style=ansi -c -o --convert-tabs --indent-preprocessor *.cpp
|
|
||||||
astyle --style=ansi -c -o --convert-tabs --indent-preprocessor *.cc
|
|
||||||
del *.orig
|
|
||||||
@rem convert line terminators to Unix style LFs
|
|
||||||
fixlines -u *.c
|
|
||||||
fixlines -u *.cpp
|
|
||||||
fixlines -u *.cc
|
|
||||||
fixlines -u *.h
|
|
||||||
del *.bak
|
|
||||||
|
|
||||||
cd ..\
|
|
|
@ -1,7 +0,0 @@
|
||||||
rem Use Astyle to fix style in a file
|
|
||||||
fixlines -p %1%
|
|
||||||
astyle --style=ansi -c -o --convert-tabs --indent-preprocessor %1%
|
|
||||||
del %1%.orig
|
|
||||||
@rem convert line terminators to Unix style LFs
|
|
||||||
fixlines -u %1%
|
|
||||||
del %1%.bak
|
|
|
@ -1,150 +0,0 @@
|
||||||
#ifndef PA_ASIO_H
|
|
||||||
#define PA_ASIO_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* ASIO specific extensions
|
|
||||||
*
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup public_header
|
|
||||||
@brief ASIO-specific PortAudio API extension header file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
/** Retrieve legal native buffer sizes for the specified device, in sample frames.
|
|
||||||
|
|
||||||
@param device The global index of the device about which the query is being made.
|
|
||||||
@param minBufferSizeFrames A pointer to the location which will receive the minimum buffer size value.
|
|
||||||
@param maxBufferSizeFrames A pointer to the location which will receive the maximum buffer size value.
|
|
||||||
@param preferredBufferSizeFrames A pointer to the location which will receive the preferred buffer size value.
|
|
||||||
@param granularity A pointer to the location which will receive the "granularity". This value determines
|
|
||||||
the step size used to compute the legal values between minBufferSizeFrames and maxBufferSizeFrames.
|
|
||||||
If granularity is -1 then available buffer size values are powers of two.
|
|
||||||
|
|
||||||
@see ASIOGetBufferSize in the ASIO SDK.
|
|
||||||
|
|
||||||
@note: this function used to be called PaAsio_GetAvailableLatencyValues. There is a
|
|
||||||
#define that maps PaAsio_GetAvailableLatencyValues to this function for backwards compatibility.
|
|
||||||
*/
|
|
||||||
PaError PaAsio_GetAvailableBufferSizes( PaDeviceIndex device,
|
|
||||||
long *minBufferSizeFrames, long *maxBufferSizeFrames, long *preferredBufferSizeFrames, long *granularity );
|
|
||||||
|
|
||||||
|
|
||||||
/** Backwards compatibility alias for PaAsio_GetAvailableBufferSizes
|
|
||||||
|
|
||||||
@see PaAsio_GetAvailableBufferSizes
|
|
||||||
*/
|
|
||||||
#define PaAsio_GetAvailableLatencyValues PaAsio_GetAvailableBufferSizes
|
|
||||||
|
|
||||||
|
|
||||||
/** Display the ASIO control panel for the specified device.
|
|
||||||
|
|
||||||
@param device The global index of the device whose control panel is to be displayed.
|
|
||||||
@param systemSpecific On Windows, the calling application's main window handle,
|
|
||||||
on Macintosh this value should be zero.
|
|
||||||
*/
|
|
||||||
PaError PaAsio_ShowControlPanel( PaDeviceIndex device, void* systemSpecific );
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/** Retrieve a pointer to a string containing the name of the specified
|
|
||||||
input channel. The string is valid until Pa_Terminate is called.
|
|
||||||
|
|
||||||
The string will be no longer than 32 characters including the null terminator.
|
|
||||||
*/
|
|
||||||
PaError PaAsio_GetInputChannelName( PaDeviceIndex device, int channelIndex,
|
|
||||||
const char** channelName );
|
|
||||||
|
|
||||||
|
|
||||||
/** Retrieve a pointer to a string containing the name of the specified
|
|
||||||
input channel. The string is valid until Pa_Terminate is called.
|
|
||||||
|
|
||||||
The string will be no longer than 32 characters including the null terminator.
|
|
||||||
*/
|
|
||||||
PaError PaAsio_GetOutputChannelName( PaDeviceIndex device, int channelIndex,
|
|
||||||
const char** channelName );
|
|
||||||
|
|
||||||
|
|
||||||
/** Set the sample rate of an open paASIO stream.
|
|
||||||
|
|
||||||
@param stream The stream to operate on.
|
|
||||||
@param sampleRate The new sample rate.
|
|
||||||
|
|
||||||
Note that this function may fail if the stream is already running and the
|
|
||||||
ASIO driver does not support switching the sample rate of a running stream.
|
|
||||||
|
|
||||||
Returns paIncompatibleStreamHostApi if stream is not a paASIO stream.
|
|
||||||
*/
|
|
||||||
PaError PaAsio_SetStreamSampleRate( PaStream* stream, double sampleRate );
|
|
||||||
|
|
||||||
|
|
||||||
#define paAsioUseChannelSelectors (0x01)
|
|
||||||
|
|
||||||
typedef struct PaAsioStreamInfo{
|
|
||||||
unsigned long size; /**< sizeof(PaAsioStreamInfo) */
|
|
||||||
PaHostApiTypeId hostApiType; /**< paASIO */
|
|
||||||
unsigned long version; /**< 1 */
|
|
||||||
|
|
||||||
unsigned long flags;
|
|
||||||
|
|
||||||
/* Support for opening only specific channels of an ASIO device.
|
|
||||||
If the paAsioUseChannelSelectors flag is set, channelSelectors is a
|
|
||||||
pointer to an array of integers specifying the device channels to use.
|
|
||||||
When used, the length of the channelSelectors array must match the
|
|
||||||
corresponding channelCount parameter to Pa_OpenStream() otherwise a
|
|
||||||
crash may result.
|
|
||||||
The values in the selectors array must specify channels within the
|
|
||||||
range of supported channels for the device or paInvalidChannelCount will
|
|
||||||
result.
|
|
||||||
*/
|
|
||||||
int *channelSelectors;
|
|
||||||
}PaAsioStreamInfo;
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
#endif /* PA_ASIO_H */
|
|
|
@ -1,77 +0,0 @@
|
||||||
#ifndef PA_JACK_H
|
|
||||||
#define PA_JACK_H
|
|
||||||
|
|
||||||
/*
|
|
||||||
* $Id:
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* JACK-specific extensions
|
|
||||||
*
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
* @ingroup public_header
|
|
||||||
* @brief JACK-specific PortAudio API extension header file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/** Set the JACK client name.
|
|
||||||
*
|
|
||||||
* During Pa_Initialize, When PA JACK connects as a client of the JACK server, it requests a certain
|
|
||||||
* name, which is for instance prepended to port names. By default this name is "PortAudio". The
|
|
||||||
* JACK server may append a suffix to the client name, in order to avoid clashes among clients that
|
|
||||||
* try to connect with the same name (e.g., different PA JACK clients).
|
|
||||||
*
|
|
||||||
* This function must be called before Pa_Initialize, otherwise it won't have any effect. Note that
|
|
||||||
* the string is not copied, but instead referenced directly, so it must not be freed for as long as
|
|
||||||
* PA might need it.
|
|
||||||
* @sa PaJack_GetClientName
|
|
||||||
*/
|
|
||||||
PaError PaJack_SetClientName( const char* name );
|
|
||||||
|
|
||||||
/** Get the JACK client name used by PA JACK.
|
|
||||||
*
|
|
||||||
* The caller is responsible for freeing the returned pointer.
|
|
||||||
*/
|
|
||||||
PaError PaJack_GetClientName(const char** clientName);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -1,107 +0,0 @@
|
||||||
#ifndef PA_LINUX_ALSA_H
|
|
||||||
#define PA_LINUX_ALSA_H
|
|
||||||
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* ALSA-specific extensions
|
|
||||||
*
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
* @ingroup public_header
|
|
||||||
* @brief ALSA-specific PortAudio API extension header file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef struct PaAlsaStreamInfo
|
|
||||||
{
|
|
||||||
unsigned long size;
|
|
||||||
PaHostApiTypeId hostApiType;
|
|
||||||
unsigned long version;
|
|
||||||
|
|
||||||
const char *deviceString;
|
|
||||||
}
|
|
||||||
PaAlsaStreamInfo;
|
|
||||||
|
|
||||||
/** Initialize host API specific structure, call this before setting relevant attributes. */
|
|
||||||
void PaAlsa_InitializeStreamInfo( PaAlsaStreamInfo *info );
|
|
||||||
|
|
||||||
/** Instruct whether to enable real-time priority when starting the audio thread.
|
|
||||||
*
|
|
||||||
* If this is turned on by the stream is started, the audio callback thread will be created
|
|
||||||
* with the FIFO scheduling policy, which is suitable for realtime operation.
|
|
||||||
**/
|
|
||||||
void PaAlsa_EnableRealtimeScheduling( PaStream *s, int enable );
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
void PaAlsa_EnableWatchdog( PaStream *s, int enable );
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/** Get the ALSA-lib card index of this stream's input device. */
|
|
||||||
PaError PaAlsa_GetStreamInputCard( PaStream *s, int *card );
|
|
||||||
|
|
||||||
/** Get the ALSA-lib card index of this stream's output device. */
|
|
||||||
PaError PaAlsa_GetStreamOutputCard( PaStream *s, int *card );
|
|
||||||
|
|
||||||
/** Set the number of periods (buffer fragments) to configure devices with.
|
|
||||||
*
|
|
||||||
* By default the number of periods is 4, this is the lowest number of periods that works well on
|
|
||||||
* the author's soundcard.
|
|
||||||
* @param numPeriods The number of periods.
|
|
||||||
*/
|
|
||||||
PaError PaAlsa_SetNumPeriods( int numPeriods );
|
|
||||||
|
|
||||||
/** Set the maximum number of times to retry opening busy device (sleeping for a
|
|
||||||
* short interval inbetween).
|
|
||||||
*/
|
|
||||||
PaError PaAlsa_SetRetriesBusy( int retries );
|
|
||||||
|
|
||||||
/** Set the path and name of ALSA library file if PortAudio is configured to load it dynamically (see
|
|
||||||
* PA_ALSA_DYNAMIC). This setting will overwrite the default name set by PA_ALSA_PATHNAME define.
|
|
||||||
* @param pathName Full path with filename. Only filename can be used, but dlopen() will lookup default
|
|
||||||
* searchable directories (/usr/lib;/usr/local/lib) then.
|
|
||||||
*/
|
|
||||||
void PaAlsa_SetLibraryPathName( const char *pathName );
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -1,191 +0,0 @@
|
||||||
#ifndef PA_MAC_CORE_H
|
|
||||||
#define PA_MAC_CORE_H
|
|
||||||
/*
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* Macintosh Core Audio specific extensions
|
|
||||||
* portaudio.h should be included before this file.
|
|
||||||
*
|
|
||||||
* Copyright (c) 2005-2006 Bjorn Roche
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
* @ingroup public_header
|
|
||||||
* @brief CoreAudio-specific PortAudio API extension header file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
|
|
||||||
#include <AudioUnit/AudioUnit.h>
|
|
||||||
#include <AudioToolbox/AudioToolbox.h>
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A pointer to a paMacCoreStreamInfo may be passed as
|
|
||||||
* the hostApiSpecificStreamInfo in the PaStreamParameters struct
|
|
||||||
* when opening a stream or querying the format. Use NULL, for the
|
|
||||||
* defaults. Note that for duplex streams, flags for input and output
|
|
||||||
* should be the same or behaviour is undefined.
|
|
||||||
*/
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
unsigned long size; /**size of whole structure including this header */
|
|
||||||
PaHostApiTypeId hostApiType; /**host API for which this data is intended */
|
|
||||||
unsigned long version; /**structure version */
|
|
||||||
unsigned long flags; /** flags to modify behaviour */
|
|
||||||
SInt32 const * channelMap; /** Channel map for HAL channel mapping , if not needed, use NULL;*/
|
|
||||||
unsigned long channelMapSize; /** Channel map size for HAL channel mapping , if not needed, use 0;*/
|
|
||||||
} PaMacCoreStreamInfo;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Functions
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/** Use this function to initialize a paMacCoreStreamInfo struct
|
|
||||||
* using the requested flags. Note that channel mapping is turned
|
|
||||||
* off after a call to this function.
|
|
||||||
* @param data The datastructure to initialize
|
|
||||||
* @param flags The flags to initialize the datastructure with.
|
|
||||||
*/
|
|
||||||
void PaMacCore_SetupStreamInfo( PaMacCoreStreamInfo *data, unsigned long flags );
|
|
||||||
|
|
||||||
/** call this after pa_SetupMacCoreStreamInfo to use channel mapping as described in notes.txt.
|
|
||||||
* @param data The stream info structure to assign a channel mapping to
|
|
||||||
* @param channelMap The channel map array, as described in notes.txt. This array pointer will be used directly (ie the underlying data will not be copied), so the caller should not free the array until after the stream has been opened.
|
|
||||||
* @param channelMapSize The size of the channel map array.
|
|
||||||
*/
|
|
||||||
void PaMacCore_SetupChannelMap( PaMacCoreStreamInfo *data, const SInt32 * const channelMap, unsigned long channelMapSize );
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Retrieve the AudioDeviceID of the input device assigned to an open stream
|
|
||||||
*
|
|
||||||
* @param s The stream to query.
|
|
||||||
*
|
|
||||||
* @return A valid AudioDeviceID, or NULL if an error occurred.
|
|
||||||
*/
|
|
||||||
AudioDeviceID PaMacCore_GetStreamInputDevice( PaStream* s );
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Retrieve the AudioDeviceID of the output device assigned to an open stream
|
|
||||||
*
|
|
||||||
* @param s The stream to query.
|
|
||||||
*
|
|
||||||
* @return A valid AudioDeviceID, or NULL if an error occurred.
|
|
||||||
*/
|
|
||||||
AudioDeviceID PaMacCore_GetStreamOutputDevice( PaStream* s );
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns a statically allocated string with the device's name
|
|
||||||
* for the given channel. NULL will be returned on failure.
|
|
||||||
*
|
|
||||||
* This function's implementation is not complete!
|
|
||||||
*
|
|
||||||
* @param device The PortAudio device index.
|
|
||||||
* @param channel The channel number who's name is requested.
|
|
||||||
* @return a statically allocated string with the name of the device.
|
|
||||||
* Because this string is statically allocated, it must be
|
|
||||||
* copied if it is to be saved and used by the user after
|
|
||||||
* another call to this function.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
const char *PaMacCore_GetChannelName( int device, int channelIndex, bool input );
|
|
||||||
|
|
||||||
|
|
||||||
/** Retrieve the range of legal native buffer sizes for the specified device, in sample frames.
|
|
||||||
|
|
||||||
@param device The global index of the PortAudio device about which the query is being made.
|
|
||||||
@param minBufferSizeFrames A pointer to the location which will receive the minimum buffer size value.
|
|
||||||
@param maxBufferSizeFrames A pointer to the location which will receive the maximum buffer size value.
|
|
||||||
|
|
||||||
@see kAudioDevicePropertyBufferFrameSizeRange in the CoreAudio SDK.
|
|
||||||
*/
|
|
||||||
PaError PaMacCore_GetBufferSizeRange( PaDeviceIndex device,
|
|
||||||
long *minBufferSizeFrames, long *maxBufferSizeFrames );
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Flags
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The following flags alter the behaviour of PA on the mac platform.
|
|
||||||
* they can be ORed together. These should work both for opening and
|
|
||||||
* checking a device.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Allows PortAudio to change things like the device's frame size,
|
|
||||||
* which allows for much lower latency, but might disrupt the device
|
|
||||||
* if other programs are using it, even when you are just Querying
|
|
||||||
* the device. */
|
|
||||||
#define paMacCoreChangeDeviceParameters (0x01)
|
|
||||||
|
|
||||||
/** In combination with the above flag,
|
|
||||||
* causes the stream opening to fail, unless the exact sample rates
|
|
||||||
* are supported by the device. */
|
|
||||||
#define paMacCoreFailIfConversionRequired (0x02)
|
|
||||||
|
|
||||||
/** These flags set the SR conversion quality, if required. The weird ordering
|
|
||||||
* allows Maximum Quality to be the default.*/
|
|
||||||
#define paMacCoreConversionQualityMin (0x0100)
|
|
||||||
#define paMacCoreConversionQualityMedium (0x0200)
|
|
||||||
#define paMacCoreConversionQualityLow (0x0300)
|
|
||||||
#define paMacCoreConversionQualityHigh (0x0400)
|
|
||||||
#define paMacCoreConversionQualityMax (0x0000)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Here are some "preset" combinations of flags (above) to get to some
|
|
||||||
* common configurations. THIS IS OVERKILL, but if more flags are added
|
|
||||||
* it won't be.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**This is the default setting: do as much sample rate conversion as possible
|
|
||||||
* and as little mucking with the device as possible. */
|
|
||||||
#define paMacCorePlayNice (0x00)
|
|
||||||
/**This setting is tuned for pro audio apps. It allows SR conversion on input
|
|
||||||
and output, but it tries to set the appropriate SR on the device.*/
|
|
||||||
#define paMacCorePro (0x01)
|
|
||||||
/**This is a setting to minimize CPU usage and still play nice.*/
|
|
||||||
#define paMacCoreMinimizeCPUButPlayNice (0x0100)
|
|
||||||
/**This is a setting to minimize CPU usage, even if that means interrupting the device. */
|
|
||||||
#define paMacCoreMinimizeCPU (0x0101)
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /** __cplusplus */
|
|
||||||
|
|
||||||
#endif /** PA_MAC_CORE_H */
|
|
|
@ -1,95 +0,0 @@
|
||||||
#ifndef PA_WIN_DS_H
|
|
||||||
#define PA_WIN_DS_H
|
|
||||||
/*
|
|
||||||
* $Id: $
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* DirectSound specific extensions
|
|
||||||
*
|
|
||||||
* Copyright (c) 1999-2007 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup public_header
|
|
||||||
@brief DirectSound-specific PortAudio API extension header file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
#include "pa_win_waveformat.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
#define paWinDirectSoundUseLowLevelLatencyParameters (0x01)
|
|
||||||
#define paWinDirectSoundUseChannelMask (0x04)
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct PaWinDirectSoundStreamInfo{
|
|
||||||
unsigned long size; /**< sizeof(PaWinDirectSoundStreamInfo) */
|
|
||||||
PaHostApiTypeId hostApiType; /**< paDirectSound */
|
|
||||||
unsigned long version; /**< 2 */
|
|
||||||
|
|
||||||
unsigned long flags; /**< enable other features of this struct */
|
|
||||||
|
|
||||||
/**
|
|
||||||
low-level latency setting support
|
|
||||||
Sets the size of the DirectSound host buffer.
|
|
||||||
When flags contains the paWinDirectSoundUseLowLevelLatencyParameters
|
|
||||||
this size will be used instead of interpreting the generic latency
|
|
||||||
parameters to Pa_OpenStream(). If the flag is not set this value is ignored.
|
|
||||||
|
|
||||||
If the stream is a full duplex stream the implementation requires that
|
|
||||||
the values of framesPerBuffer for input and output match (if both are specified).
|
|
||||||
*/
|
|
||||||
unsigned long framesPerBuffer;
|
|
||||||
|
|
||||||
/**
|
|
||||||
support for WAVEFORMATEXTENSIBLE channel masks. If flags contains
|
|
||||||
paWinDirectSoundUseChannelMask this allows you to specify which speakers
|
|
||||||
to address in a multichannel stream. Constants for channelMask
|
|
||||||
are specified in pa_win_waveformat.h
|
|
||||||
|
|
||||||
*/
|
|
||||||
PaWinWaveFormatChannelMask channelMask;
|
|
||||||
|
|
||||||
}PaWinDirectSoundStreamInfo;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
#endif /* PA_WIN_DS_H */
|
|
|
@ -1,719 +0,0 @@
|
||||||
#ifndef PA_WIN_WASAPI_H
|
|
||||||
#define PA_WIN_WASAPI_H
|
|
||||||
/*
|
|
||||||
* $Id: $
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* WASAPI specific extensions
|
|
||||||
*
|
|
||||||
* Copyright (c) 1999-2018 Ross Bencina and Phil Burk
|
|
||||||
* Copyright (c) 2006-2010 David Viens
|
|
||||||
* Copyright (c) 2010-2018 Dmitry Kostjuchenko
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup public_header
|
|
||||||
@brief WASAPI-specific PortAudio API extension header file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
#include "pa_win_waveformat.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
/* Stream setup flags. */
|
|
||||||
typedef enum PaWasapiFlags
|
|
||||||
{
|
|
||||||
/* put WASAPI into exclusive mode */
|
|
||||||
paWinWasapiExclusive = (1 << 0),
|
|
||||||
|
|
||||||
/* allow to skip internal PA processing completely */
|
|
||||||
paWinWasapiRedirectHostProcessor = (1 << 1),
|
|
||||||
|
|
||||||
/* assign custom channel mask */
|
|
||||||
paWinWasapiUseChannelMask = (1 << 2),
|
|
||||||
|
|
||||||
/* select non-Event driven method of data read/write
|
|
||||||
Note: WASAPI Event driven core is capable of 2ms latency!!!, but Polling
|
|
||||||
method can only provide 15-20ms latency. */
|
|
||||||
paWinWasapiPolling = (1 << 3),
|
|
||||||
|
|
||||||
/* force custom thread priority setting, must be used if PaWasapiStreamInfo::threadPriority
|
|
||||||
is set to a custom value */
|
|
||||||
paWinWasapiThreadPriority = (1 << 4),
|
|
||||||
|
|
||||||
/* force explicit sample format and do not allow PA to select suitable working format, API will
|
|
||||||
fail if provided sample format is not supported by audio hardware in Exclusive mode
|
|
||||||
or system mixer in Shared mode */
|
|
||||||
paWinWasapiExplicitSampleFormat = (1 << 5),
|
|
||||||
|
|
||||||
/* allow API to insert system-level channel matrix mixer and sample rate converter to allow
|
|
||||||
playback formats that do not match the current configured system settings.
|
|
||||||
this is in particular required for streams not matching the system mixer sample rate.
|
|
||||||
only applies in Shared mode. */
|
|
||||||
paWinWasapiAutoConvert = (1 << 6)
|
|
||||||
}
|
|
||||||
PaWasapiFlags;
|
|
||||||
#define paWinWasapiExclusive (paWinWasapiExclusive)
|
|
||||||
#define paWinWasapiRedirectHostProcessor (paWinWasapiRedirectHostProcessor)
|
|
||||||
#define paWinWasapiUseChannelMask (paWinWasapiUseChannelMask)
|
|
||||||
#define paWinWasapiPolling (paWinWasapiPolling)
|
|
||||||
#define paWinWasapiThreadPriority (paWinWasapiThreadPriority)
|
|
||||||
#define paWinWasapiExplicitSampleFormat (paWinWasapiExplicitSampleFormat)
|
|
||||||
#define paWinWasapiAutoConvert (paWinWasapiAutoConvert)
|
|
||||||
|
|
||||||
|
|
||||||
/* Stream state.
|
|
||||||
|
|
||||||
@note Multiple states can be united into a bitmask.
|
|
||||||
@see PaWasapiStreamStateCallback, PaWasapi_SetStreamStateHandler
|
|
||||||
*/
|
|
||||||
typedef enum PaWasapiStreamState
|
|
||||||
{
|
|
||||||
/* state change was caused by the error:
|
|
||||||
|
|
||||||
Example:
|
|
||||||
1) If thread execution stopped due to AUDCLNT_E_RESOURCES_INVALIDATED then state
|
|
||||||
value will contain paWasapiStreamStateError|paWasapiStreamStateThreadStop.
|
|
||||||
*/
|
|
||||||
paWasapiStreamStateError = (1 << 0),
|
|
||||||
|
|
||||||
/* processing thread is preparing to start execution */
|
|
||||||
paWasapiStreamStateThreadPrepare = (1 << 1),
|
|
||||||
|
|
||||||
/* processing thread started execution (enters its loop) */
|
|
||||||
paWasapiStreamStateThreadStart = (1 << 2),
|
|
||||||
|
|
||||||
/* processing thread stopped execution */
|
|
||||||
paWasapiStreamStateThreadStop = (1 << 3)
|
|
||||||
}
|
|
||||||
PaWasapiStreamState;
|
|
||||||
#define paWasapiStreamStateError (paWasapiStreamStateError)
|
|
||||||
#define paWasapiStreamStateThreadPrepare (paWasapiStreamStateThreadPrepare)
|
|
||||||
#define paWasapiStreamStateThreadStart (paWasapiStreamStateThreadStart)
|
|
||||||
#define paWasapiStreamStateThreadStop (paWasapiStreamStateThreadStop)
|
|
||||||
|
|
||||||
|
|
||||||
/* Host processor.
|
|
||||||
|
|
||||||
Allows to skip internal PA processing completely. paWinWasapiRedirectHostProcessor flag
|
|
||||||
must be set to the PaWasapiStreamInfo::flags member in order to have host processor
|
|
||||||
redirected to this callback.
|
|
||||||
|
|
||||||
Use with caution! inputFrames and outputFrames depend solely on final device setup.
|
|
||||||
To query max values of inputFrames/outputFrames use PaWasapi_GetFramesPerHostBuffer.
|
|
||||||
*/
|
|
||||||
typedef void (*PaWasapiHostProcessorCallback) (void *inputBuffer, long inputFrames,
|
|
||||||
void *outputBuffer, long outputFrames, void *userData);
|
|
||||||
|
|
||||||
|
|
||||||
/* Stream state handler.
|
|
||||||
|
|
||||||
@param pStream Pointer to PaStream object.
|
|
||||||
@param stateFlags State flags, a collection of values from PaWasapiStreamState enum.
|
|
||||||
@param errorId Error id provided by system API (HRESULT).
|
|
||||||
@param userData Pointer to user data.
|
|
||||||
|
|
||||||
@see PaWasapiStreamState
|
|
||||||
*/
|
|
||||||
typedef void (*PaWasapiStreamStateCallback) (PaStream *pStream, unsigned int stateFlags,
|
|
||||||
unsigned int errorId, void *pUserData);
|
|
||||||
|
|
||||||
|
|
||||||
/* Device role. */
|
|
||||||
typedef enum PaWasapiDeviceRole
|
|
||||||
{
|
|
||||||
eRoleRemoteNetworkDevice = 0,
|
|
||||||
eRoleSpeakers,
|
|
||||||
eRoleLineLevel,
|
|
||||||
eRoleHeadphones,
|
|
||||||
eRoleMicrophone,
|
|
||||||
eRoleHeadset,
|
|
||||||
eRoleHandset,
|
|
||||||
eRoleUnknownDigitalPassthrough,
|
|
||||||
eRoleSPDIF,
|
|
||||||
eRoleHDMI,
|
|
||||||
eRoleUnknownFormFactor
|
|
||||||
}
|
|
||||||
PaWasapiDeviceRole;
|
|
||||||
|
|
||||||
|
|
||||||
/* Jack connection type. */
|
|
||||||
typedef enum PaWasapiJackConnectionType
|
|
||||||
{
|
|
||||||
eJackConnTypeUnknown,
|
|
||||||
eJackConnType3Point5mm,
|
|
||||||
eJackConnTypeQuarter,
|
|
||||||
eJackConnTypeAtapiInternal,
|
|
||||||
eJackConnTypeRCA,
|
|
||||||
eJackConnTypeOptical,
|
|
||||||
eJackConnTypeOtherDigital,
|
|
||||||
eJackConnTypeOtherAnalog,
|
|
||||||
eJackConnTypeMultichannelAnalogDIN,
|
|
||||||
eJackConnTypeXlrProfessional,
|
|
||||||
eJackConnTypeRJ11Modem,
|
|
||||||
eJackConnTypeCombination
|
|
||||||
}
|
|
||||||
PaWasapiJackConnectionType;
|
|
||||||
|
|
||||||
|
|
||||||
/* Jack geometric location. */
|
|
||||||
typedef enum PaWasapiJackGeoLocation
|
|
||||||
{
|
|
||||||
eJackGeoLocUnk = 0,
|
|
||||||
eJackGeoLocRear = 0x1, /* matches EPcxGeoLocation::eGeoLocRear */
|
|
||||||
eJackGeoLocFront,
|
|
||||||
eJackGeoLocLeft,
|
|
||||||
eJackGeoLocRight,
|
|
||||||
eJackGeoLocTop,
|
|
||||||
eJackGeoLocBottom,
|
|
||||||
eJackGeoLocRearPanel,
|
|
||||||
eJackGeoLocRiser,
|
|
||||||
eJackGeoLocInsideMobileLid,
|
|
||||||
eJackGeoLocDrivebay,
|
|
||||||
eJackGeoLocHDMI,
|
|
||||||
eJackGeoLocOutsideMobileLid,
|
|
||||||
eJackGeoLocATAPI,
|
|
||||||
eJackGeoLocReserved5,
|
|
||||||
eJackGeoLocReserved6,
|
|
||||||
}
|
|
||||||
PaWasapiJackGeoLocation;
|
|
||||||
|
|
||||||
|
|
||||||
/* Jack general location. */
|
|
||||||
typedef enum PaWasapiJackGenLocation
|
|
||||||
{
|
|
||||||
eJackGenLocPrimaryBox = 0,
|
|
||||||
eJackGenLocInternal,
|
|
||||||
eJackGenLocSeparate,
|
|
||||||
eJackGenLocOther
|
|
||||||
}
|
|
||||||
PaWasapiJackGenLocation;
|
|
||||||
|
|
||||||
|
|
||||||
/* Jack's type of port. */
|
|
||||||
typedef enum PaWasapiJackPortConnection
|
|
||||||
{
|
|
||||||
eJackPortConnJack = 0,
|
|
||||||
eJackPortConnIntegratedDevice,
|
|
||||||
eJackPortConnBothIntegratedAndJack,
|
|
||||||
eJackPortConnUnknown
|
|
||||||
}
|
|
||||||
PaWasapiJackPortConnection;
|
|
||||||
|
|
||||||
|
|
||||||
/* Thread priority. */
|
|
||||||
typedef enum PaWasapiThreadPriority
|
|
||||||
{
|
|
||||||
eThreadPriorityNone = 0,
|
|
||||||
eThreadPriorityAudio, //!< Default for Shared mode.
|
|
||||||
eThreadPriorityCapture,
|
|
||||||
eThreadPriorityDistribution,
|
|
||||||
eThreadPriorityGames,
|
|
||||||
eThreadPriorityPlayback,
|
|
||||||
eThreadPriorityProAudio, //!< Default for Exclusive mode.
|
|
||||||
eThreadPriorityWindowManager
|
|
||||||
}
|
|
||||||
PaWasapiThreadPriority;
|
|
||||||
|
|
||||||
|
|
||||||
/* Stream descriptor. */
|
|
||||||
typedef struct PaWasapiJackDescription
|
|
||||||
{
|
|
||||||
unsigned long channelMapping;
|
|
||||||
unsigned long color; /* derived from macro: #define RGB(r,g,b) ((COLORREF)(((BYTE)(r)|((WORD)((BYTE)(g))<<8))|(((DWORD)(BYTE)(b))<<16))) */
|
|
||||||
PaWasapiJackConnectionType connectionType;
|
|
||||||
PaWasapiJackGeoLocation geoLocation;
|
|
||||||
PaWasapiJackGenLocation genLocation;
|
|
||||||
PaWasapiJackPortConnection portConnection;
|
|
||||||
unsigned int isConnected;
|
|
||||||
}
|
|
||||||
PaWasapiJackDescription;
|
|
||||||
|
|
||||||
|
|
||||||
/** Stream category.
|
|
||||||
Note:
|
|
||||||
- values are equal to WASAPI AUDIO_STREAM_CATEGORY enum
|
|
||||||
- supported since Windows 8.0, noop on earlier versions
|
|
||||||
- values 1,2 are deprecated on Windows 10 and not included into enumeration
|
|
||||||
|
|
||||||
@version Available as of 19.6.0
|
|
||||||
*/
|
|
||||||
typedef enum PaWasapiStreamCategory
|
|
||||||
{
|
|
||||||
eAudioCategoryOther = 0,
|
|
||||||
eAudioCategoryCommunications = 3,
|
|
||||||
eAudioCategoryAlerts = 4,
|
|
||||||
eAudioCategorySoundEffects = 5,
|
|
||||||
eAudioCategoryGameEffects = 6,
|
|
||||||
eAudioCategoryGameMedia = 7,
|
|
||||||
eAudioCategoryGameChat = 8,
|
|
||||||
eAudioCategorySpeech = 9,
|
|
||||||
eAudioCategoryMovie = 10,
|
|
||||||
eAudioCategoryMedia = 11
|
|
||||||
}
|
|
||||||
PaWasapiStreamCategory;
|
|
||||||
|
|
||||||
|
|
||||||
/** Stream option.
|
|
||||||
Note:
|
|
||||||
- values are equal to WASAPI AUDCLNT_STREAMOPTIONS enum
|
|
||||||
- supported since Windows 8.1, noop on earlier versions
|
|
||||||
|
|
||||||
@version Available as of 19.6.0
|
|
||||||
*/
|
|
||||||
typedef enum PaWasapiStreamOption
|
|
||||||
{
|
|
||||||
eStreamOptionNone = 0, //!< default
|
|
||||||
eStreamOptionRaw = 1, //!< bypass WASAPI Audio Engine DSP effects, supported since Windows 8.1
|
|
||||||
eStreamOptionMatchFormat = 2 //!< force WASAPI Audio Engine into a stream format, supported since Windows 10
|
|
||||||
}
|
|
||||||
PaWasapiStreamOption;
|
|
||||||
|
|
||||||
|
|
||||||
/* Stream descriptor. */
|
|
||||||
typedef struct PaWasapiStreamInfo
|
|
||||||
{
|
|
||||||
unsigned long size; /**< sizeof(PaWasapiStreamInfo) */
|
|
||||||
PaHostApiTypeId hostApiType; /**< paWASAPI */
|
|
||||||
unsigned long version; /**< 1 */
|
|
||||||
|
|
||||||
unsigned long flags; /**< collection of PaWasapiFlags */
|
|
||||||
|
|
||||||
/** Support for WAVEFORMATEXTENSIBLE channel masks. If flags contains
|
|
||||||
paWinWasapiUseChannelMask this allows you to specify which speakers
|
|
||||||
to address in a multichannel stream. Constants for channelMask
|
|
||||||
are specified in pa_win_waveformat.h. Will be used only if
|
|
||||||
paWinWasapiUseChannelMask flag is specified.
|
|
||||||
*/
|
|
||||||
PaWinWaveFormatChannelMask channelMask;
|
|
||||||
|
|
||||||
/** Delivers raw data to callback obtained from GetBuffer() methods skipping
|
|
||||||
internal PortAudio processing inventory completely. userData parameter will
|
|
||||||
be the same that was passed to Pa_OpenStream method. Will be used only if
|
|
||||||
paWinWasapiRedirectHostProcessor flag is specified.
|
|
||||||
*/
|
|
||||||
PaWasapiHostProcessorCallback hostProcessorOutput;
|
|
||||||
PaWasapiHostProcessorCallback hostProcessorInput;
|
|
||||||
|
|
||||||
/** Specifies thread priority explicitly. Will be used only if paWinWasapiThreadPriority flag
|
|
||||||
is specified.
|
|
||||||
|
|
||||||
Please note, if Input/Output streams are opened simultaniously (Full-Duplex mode)
|
|
||||||
you shall specify same value for threadPriority or othervise one of the values will be used
|
|
||||||
to setup thread priority.
|
|
||||||
*/
|
|
||||||
PaWasapiThreadPriority threadPriority;
|
|
||||||
|
|
||||||
/** Stream category.
|
|
||||||
@see PaWasapiStreamCategory
|
|
||||||
@version Available as of 19.6.0
|
|
||||||
*/
|
|
||||||
PaWasapiStreamCategory streamCategory;
|
|
||||||
|
|
||||||
/** Stream option.
|
|
||||||
@see PaWasapiStreamOption
|
|
||||||
@version Available as of 19.6.0
|
|
||||||
*/
|
|
||||||
PaWasapiStreamOption streamOption;
|
|
||||||
}
|
|
||||||
PaWasapiStreamInfo;
|
|
||||||
|
|
||||||
|
|
||||||
/** Returns pointer to WASAPI's IAudioClient object of the stream.
|
|
||||||
|
|
||||||
@param pStream Pointer to PaStream object.
|
|
||||||
@param pAudioClient Pointer to pointer of IAudioClient.
|
|
||||||
@param bOutput TRUE (1) for output stream, FALSE (0) for input stream.
|
|
||||||
|
|
||||||
@return Error code indicating success or failure.
|
|
||||||
*/
|
|
||||||
PaError PaWasapi_GetAudioClient( PaStream *pStream, void **pAudioClient, int bOutput );
|
|
||||||
|
|
||||||
|
|
||||||
/** Update device list.
|
|
||||||
|
|
||||||
This function is available if PA_WASAPI_MAX_CONST_DEVICE_COUNT is defined during compile time
|
|
||||||
with maximum constant WASAPI device count (recommended value - 32).
|
|
||||||
If PA_WASAPI_MAX_CONST_DEVICE_COUNT is set to 0 (or not defined) during compile time the implementation
|
|
||||||
will not define PaWasapi_UpdateDeviceList() and thus updating device list can only be possible by calling
|
|
||||||
Pa_Terminate() and then Pa_Initialize().
|
|
||||||
|
|
||||||
@return Error code indicating success or failure.
|
|
||||||
*/
|
|
||||||
PaError PaWasapi_UpdateDeviceList();
|
|
||||||
|
|
||||||
|
|
||||||
/** Get current audio format of the device assigned to the opened stream.
|
|
||||||
|
|
||||||
Format is represented by PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure.
|
|
||||||
Use this function to reconfirm format if PA's processor is overridden and
|
|
||||||
paWinWasapiRedirectHostProcessor flag is specified.
|
|
||||||
|
|
||||||
@param pStream Pointer to PaStream object.
|
|
||||||
@param pFormat Pointer to PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure.
|
|
||||||
@param formatSize Size of PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure in bytes.
|
|
||||||
@param bOutput TRUE (1) for output stream, FALSE (0) for input stream.
|
|
||||||
|
|
||||||
@return Non-negative value indicating the number of bytes copied into format descriptor
|
|
||||||
or, a PaErrorCode (which is always negative) if PortAudio is not initialized
|
|
||||||
or an error is encountered.
|
|
||||||
*/
|
|
||||||
int PaWasapi_GetDeviceCurrentFormat( PaStream *pStream, void *pFormat, unsigned int formatSize, int bOutput );
|
|
||||||
|
|
||||||
|
|
||||||
/** Get default audio format for the device in Shared Mode.
|
|
||||||
|
|
||||||
Format is represented by PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure and obtained
|
|
||||||
by getting the device property with a PKEY_AudioEngine_DeviceFormat key.
|
|
||||||
|
|
||||||
@param pFormat Pointer to PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure.
|
|
||||||
@param formatSize Size of PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure in bytes.
|
|
||||||
@param device Device index.
|
|
||||||
|
|
||||||
@return Non-negative value indicating the number of bytes copied into format descriptor
|
|
||||||
or, a PaErrorCode (which is always negative) if PortAudio is not initialized
|
|
||||||
or an error is encountered.
|
|
||||||
*/
|
|
||||||
int PaWasapi_GetDeviceDefaultFormat( void *pFormat, unsigned int formatSize, PaDeviceIndex device );
|
|
||||||
|
|
||||||
|
|
||||||
/** Get mix audio format for the device in Shared Mode.
|
|
||||||
|
|
||||||
Format is represented by PaWinWaveFormat or WAVEFORMATEXTENSIBLE structureand obtained by
|
|
||||||
IAudioClient::GetMixFormat.
|
|
||||||
|
|
||||||
@param pFormat Pointer to PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure.
|
|
||||||
@param formatSize Size of PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure in bytes.
|
|
||||||
@param device Device index.
|
|
||||||
|
|
||||||
@return Non-negative value indicating the number of bytes copied into format descriptor
|
|
||||||
or, a PaErrorCode (which is always negative) if PortAudio is not initialized
|
|
||||||
or an error is encountered.
|
|
||||||
*/
|
|
||||||
int PaWasapi_GetDeviceMixFormat( void *pFormat, unsigned int formatSize, PaDeviceIndex device );
|
|
||||||
|
|
||||||
|
|
||||||
/** Get device role (PaWasapiDeviceRole enum).
|
|
||||||
|
|
||||||
@param device Device index.
|
|
||||||
|
|
||||||
@return Non-negative value indicating device role or, a PaErrorCode (which is always negative)
|
|
||||||
if PortAudio is not initialized or an error is encountered.
|
|
||||||
*/
|
|
||||||
int/*PaWasapiDeviceRole*/ PaWasapi_GetDeviceRole( PaDeviceIndex device );
|
|
||||||
|
|
||||||
|
|
||||||
/** Boost thread priority of calling thread (MMCSS).
|
|
||||||
|
|
||||||
Use it for Blocking Interface only inside the thread which makes calls to Pa_WriteStream/Pa_ReadStream.
|
|
||||||
|
|
||||||
@param pTask Handle to pointer to priority task. Must be used with PaWasapi_RevertThreadPriority
|
|
||||||
method to revert thread priority to initial state.
|
|
||||||
|
|
||||||
@param priorityClass Id of thread priority of PaWasapiThreadPriority type. Specifying
|
|
||||||
eThreadPriorityNone does nothing.
|
|
||||||
|
|
||||||
@return Error code indicating success or failure.
|
|
||||||
@see PaWasapi_RevertThreadPriority
|
|
||||||
*/
|
|
||||||
PaError PaWasapi_ThreadPriorityBoost( void **pTask, PaWasapiThreadPriority priorityClass );
|
|
||||||
|
|
||||||
|
|
||||||
/** Boost thread priority of calling thread (MMCSS).
|
|
||||||
|
|
||||||
Use it for Blocking Interface only inside the thread which makes calls to Pa_WriteStream/Pa_ReadStream.
|
|
||||||
|
|
||||||
@param pTask Task handle obtained by PaWasapi_BoostThreadPriority method.
|
|
||||||
|
|
||||||
@return Error code indicating success or failure.
|
|
||||||
@see PaWasapi_BoostThreadPriority
|
|
||||||
*/
|
|
||||||
PaError PaWasapi_ThreadPriorityRevert( void *pTask );
|
|
||||||
|
|
||||||
|
|
||||||
/** Get number of frames per host buffer.
|
|
||||||
|
|
||||||
It is max value of frames of WASAPI buffer which can be locked for operations.
|
|
||||||
Use this method as helper to find out max values of inputFrames/outputFrames
|
|
||||||
of PaWasapiHostProcessorCallback.
|
|
||||||
|
|
||||||
@param pStream Pointer to PaStream object.
|
|
||||||
@param pInput Pointer to variable to receive number of input frames. Can be NULL.
|
|
||||||
@param pOutput Pointer to variable to receive number of output frames. Can be NULL.
|
|
||||||
|
|
||||||
@return Error code indicating success or failure.
|
|
||||||
@see PaWasapiHostProcessorCallback
|
|
||||||
*/
|
|
||||||
PaError PaWasapi_GetFramesPerHostBuffer( PaStream *pStream, unsigned int *pInput, unsigned int *pOutput );
|
|
||||||
|
|
||||||
|
|
||||||
/** Get number of jacks associated with a WASAPI device.
|
|
||||||
|
|
||||||
Use this method to determine if there are any jacks associated with the provided WASAPI device.
|
|
||||||
Not all audio devices will support this capability. This is valid for both input and output devices.
|
|
||||||
|
|
||||||
@note Not available on UWP platform.
|
|
||||||
|
|
||||||
@param device Device index.
|
|
||||||
@param pJackCount Pointer to variable to receive number of jacks.
|
|
||||||
|
|
||||||
@return Error code indicating success or failure.
|
|
||||||
@see PaWasapi_GetJackDescription
|
|
||||||
*/
|
|
||||||
PaError PaWasapi_GetJackCount( PaDeviceIndex device, int *pJackCount );
|
|
||||||
|
|
||||||
|
|
||||||
/** Get the jack description associated with a WASAPI device and jack number.
|
|
||||||
|
|
||||||
Before this function is called, use PaWasapi_GetJackCount to determine the
|
|
||||||
number of jacks associated with device. If jcount is greater than zero, then
|
|
||||||
each jack from 0 to jcount can be queried with this function to get the jack
|
|
||||||
description.
|
|
||||||
|
|
||||||
@note Not available on UWP platform.
|
|
||||||
|
|
||||||
@param device Device index.
|
|
||||||
@param jackIndex Jack index.
|
|
||||||
@param pJackDescription Pointer to PaWasapiJackDescription.
|
|
||||||
|
|
||||||
@return Error code indicating success or failure.
|
|
||||||
@see PaWasapi_GetJackCount
|
|
||||||
*/
|
|
||||||
PaError PaWasapi_GetJackDescription( PaDeviceIndex device, int jackIndex, PaWasapiJackDescription *pJackDescription );
|
|
||||||
|
|
||||||
|
|
||||||
/** Set stream state handler.
|
|
||||||
|
|
||||||
@param pStream Pointer to PaStream object.
|
|
||||||
@param fnStateHandler Pointer to state handling function.
|
|
||||||
@param pUserData Pointer to user data.
|
|
||||||
|
|
||||||
@return Error code indicating success or failure.
|
|
||||||
*/
|
|
||||||
PaError PaWasapi_SetStreamStateHandler( PaStream *pStream, PaWasapiStreamStateCallback fnStateHandler, void *pUserData );
|
|
||||||
|
|
||||||
|
|
||||||
/** Set default device Id.
|
|
||||||
|
|
||||||
By default implementation will use the DEVINTERFACE_AUDIO_RENDER and
|
|
||||||
DEVINTERFACE_AUDIO_CAPTURE Ids if device Id is not provided explicitly. These default Ids
|
|
||||||
will not allow to use Exclusive mode on UWP/WinRT platform and thus you must provide
|
|
||||||
device Id explicitly via this API before calling the Pa_OpenStream().
|
|
||||||
|
|
||||||
Device Ids on UWP platform are obtainable via:
|
|
||||||
Windows::Media::Devices::MediaDevice::GetDefaultAudioRenderId() or
|
|
||||||
Windows::Media::Devices::MediaDevice::GetDefaultAudioCaptureId() API.
|
|
||||||
|
|
||||||
After the call completes, memory referenced by pointers can be freed, as implementation keeps its own copy.
|
|
||||||
|
|
||||||
Call this function before calling Pa_IsFormatSupported() when Exclusive mode is requested.
|
|
||||||
|
|
||||||
See an example in the IMPORTANT notes.
|
|
||||||
|
|
||||||
@note UWP/WinRT platform only.
|
|
||||||
|
|
||||||
@param pId Device Id, pointer to the 16-bit Unicode string (WCHAR). If NULL then device Id
|
|
||||||
will be reset to the default, e.g. DEVINTERFACE_AUDIO_RENDER or DEVINTERFACE_AUDIO_CAPTURE.
|
|
||||||
@param bOutput TRUE (1) for output (render), FALSE (0) for input (capture).
|
|
||||||
|
|
||||||
@return Error code indicating success or failure. Will return paIncompatibleStreamHostApi if library is not compiled
|
|
||||||
for UWP/WinRT platform. If Id is longer than PA_WASAPI_DEVICE_ID_LEN characters paBufferTooBig will
|
|
||||||
be returned.
|
|
||||||
*/
|
|
||||||
PaError PaWasapiWinrt_SetDefaultDeviceId( const unsigned short *pId, int bOutput );
|
|
||||||
|
|
||||||
|
|
||||||
/** Populate the device list.
|
|
||||||
|
|
||||||
By default the implementation will rely on DEVINTERFACE_AUDIO_RENDER and DEVINTERFACE_AUDIO_CAPTURE as
|
|
||||||
default devices. If device Id is provided by PaWasapiWinrt_SetDefaultDeviceId() then those
|
|
||||||
device Ids will be used as default and only devices for the device list.
|
|
||||||
|
|
||||||
By populating the device list you can provide an additional available audio devices of the system to PA
|
|
||||||
which are obtainable by:
|
|
||||||
Windows::Devices::Enumeration::DeviceInformation::FindAllAsync(selector) where selector is obtainable by
|
|
||||||
Windows::Media::Devices::MediaDevice::GetAudioRenderSelector() or
|
|
||||||
Windows::Media::Devices::MediaDevice::GetAudioCaptureSelector() API.
|
|
||||||
|
|
||||||
After the call completes, memory referenced by pointers can be freed, as implementation keeps its own copy.
|
|
||||||
|
|
||||||
You must call PaWasapi_UpdateDeviceList() to update the internal device list of the implementation after
|
|
||||||
calling this function.
|
|
||||||
|
|
||||||
See an example in the IMPORTANT notes.
|
|
||||||
|
|
||||||
@note UWP/WinRT platform only.
|
|
||||||
|
|
||||||
@param pId Array of device Ids, pointer to the array of pointers of 16-bit Unicode string (WCHAR). If NULL
|
|
||||||
and count is also 0 then device Ids will be reset to the default. Required.
|
|
||||||
@param pName Array of device Names, pointer to the array of pointers of 16-bit Unicode string (WCHAR). Optional.
|
|
||||||
@param pRole Array of device Roles, see PaWasapiDeviceRole and PaWasapi_GetDeviceRole() for more details. Optional.
|
|
||||||
@param count Number of devices, the number of array elements (pId, pName, pRole). Maximum count of devices
|
|
||||||
is limited by PA_WASAPI_DEVICE_MAX_COUNT.
|
|
||||||
@param bOutput TRUE (1) for output (render), FALSE (0) for input (capture).
|
|
||||||
|
|
||||||
@return Error code indicating success or failure. Will return paIncompatibleStreamHostApi if library is not compiled
|
|
||||||
for UWP/WinRT platform. If Id is longer than PA_WASAPI_DEVICE_ID_LEN characters paBufferTooBig will
|
|
||||||
be returned. If Name is longer than PA_WASAPI_DEVICE_NAME_LEN characters paBufferTooBig will
|
|
||||||
be returned.
|
|
||||||
*/
|
|
||||||
PaError PaWasapiWinrt_PopulateDeviceList( const unsigned short **pId, const unsigned short **pName,
|
|
||||||
const PaWasapiDeviceRole *pRole, unsigned int count, int bOutput );
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
IMPORTANT:
|
|
||||||
|
|
||||||
WASAPI is implemented for Callback and Blocking interfaces. It supports Shared and Exclusive
|
|
||||||
share modes.
|
|
||||||
|
|
||||||
Exclusive Mode:
|
|
||||||
|
|
||||||
Exclusive mode allows to deliver audio data directly to hardware bypassing
|
|
||||||
software mixing.
|
|
||||||
Exclusive mode is specified by 'paWinWasapiExclusive' flag.
|
|
||||||
|
|
||||||
Callback Interface:
|
|
||||||
|
|
||||||
Provides best audio quality with low latency. Callback interface is implemented in
|
|
||||||
two versions:
|
|
||||||
|
|
||||||
1) Event-Driven:
|
|
||||||
This is the most powerful WASAPI implementation which provides glitch-free
|
|
||||||
audio at around 3ms latency in Exclusive mode. Lowest possible latency for this mode is
|
|
||||||
3 ms for HD Audio class audio chips. For the Shared mode latency can not be
|
|
||||||
lower than 20 ms.
|
|
||||||
|
|
||||||
2) Poll-Driven:
|
|
||||||
Polling is another 2-nd method to operate with WASAPI. It is less efficient than Event-Driven
|
|
||||||
and provides latency at around 10-13ms. Polling must be used to overcome a system bug
|
|
||||||
under Windows Vista x64 when application is WOW64(32-bit) and Event-Driven method simply
|
|
||||||
times out (event handle is never signalled on buffer completion). Please note, such WOW64 bug
|
|
||||||
does not exist in Vista x86 or Windows 7.
|
|
||||||
Polling can be setup by specifying 'paWinWasapiPolling' flag. Our WASAPI implementation detects
|
|
||||||
WOW64 bug and sets 'paWinWasapiPolling' automatically.
|
|
||||||
|
|
||||||
Thread priority:
|
|
||||||
|
|
||||||
Normally thread priority is set automatically and does not require modification. Although
|
|
||||||
if user wants some tweaking thread priority can be modified by setting 'paWinWasapiThreadPriority'
|
|
||||||
flag and specifying 'PaWasapiStreamInfo::threadPriority' with value from PaWasapiThreadPriority
|
|
||||||
enum.
|
|
||||||
|
|
||||||
Blocking Interface:
|
|
||||||
|
|
||||||
Blocking interface is implemented but due to above described Poll-Driven method can not
|
|
||||||
deliver lowest possible latency. Specifying too low latency in Shared mode will result in
|
|
||||||
distorted audio although Exclusive mode adds stability.
|
|
||||||
|
|
||||||
8.24 format:
|
|
||||||
|
|
||||||
If paCustomFormat is specified as sample format then the implementation will understand it
|
|
||||||
as valid 24-bits inside 32-bit container (e.g. wBitsPerSample = 32, Samples.wValidBitsPerSample = 24).
|
|
||||||
|
|
||||||
By using paCustomFormat there will be small optimization when samples are be copied
|
|
||||||
with Copy_24_To_24 by PA processor instead of conversion from packed 3-byte (24-bit) data
|
|
||||||
with Int24_To_Int32.
|
|
||||||
|
|
||||||
Pa_IsFormatSupported:
|
|
||||||
|
|
||||||
To check format with correct Share Mode (Exclusive/Shared) you must supply PaWasapiStreamInfo
|
|
||||||
with flags paWinWasapiExclusive set through member of PaStreamParameters::hostApiSpecificStreamInfo
|
|
||||||
structure.
|
|
||||||
|
|
||||||
If paWinWasapiExplicitSampleFormat flag is provided then implementation will not try to select
|
|
||||||
suitable close format and will return an error instead of paFormatIsSupported. By specifying
|
|
||||||
paWinWasapiExplicitSampleFormat flag it is possible to find out what sample formats are
|
|
||||||
supported by Exclusive or Shared modes.
|
|
||||||
|
|
||||||
Pa_OpenStream:
|
|
||||||
|
|
||||||
To set desired Share Mode (Exclusive/Shared) you must supply
|
|
||||||
PaWasapiStreamInfo with flags paWinWasapiExclusive set through member of
|
|
||||||
PaStreamParameters::hostApiSpecificStreamInfo structure.
|
|
||||||
|
|
||||||
Coding style for parameters and structure members of the public API:
|
|
||||||
|
|
||||||
1) bXXX - boolean, [1 (TRUE), 0 (FALSE)]
|
|
||||||
2) pXXX - pointer
|
|
||||||
3) fnXXX - pointer to function
|
|
||||||
4) structure members are never prefixed with a type distinguisher
|
|
||||||
|
|
||||||
|
|
||||||
UWP/WinRT:
|
|
||||||
|
|
||||||
This platform has number of limitations which do not allow to enumerate audio devices without
|
|
||||||
an additional external help. Enumeration is possible though from C++/CX, check the related API
|
|
||||||
Windows::Devices::Enumeration::DeviceInformation::FindAllAsync().
|
|
||||||
|
|
||||||
The main limitation is an absence of the device enumeration from inside the PA's implementation.
|
|
||||||
This problem can be solved by using the following functions:
|
|
||||||
|
|
||||||
PaWasapiWinrt_SetDefaultDeviceId() - to set default input/output device,
|
|
||||||
PaWasapiWinrt_PopulateDeviceList() - to populate device list with devices.
|
|
||||||
|
|
||||||
Here is an example of populating the device list which can also be updated dynamically depending on
|
|
||||||
whether device was removed from or added to the system:
|
|
||||||
|
|
||||||
----------------
|
|
||||||
|
|
||||||
std::vector<const UINT16 *> ids, names;
|
|
||||||
std::vector<PaWasapiDeviceRole> role;
|
|
||||||
|
|
||||||
ids.resize(count);
|
|
||||||
names.resize(count);
|
|
||||||
role.resize(count);
|
|
||||||
|
|
||||||
for (UINT32 i = 0; i < count; ++i)
|
|
||||||
{
|
|
||||||
ids[i] = (const UINT16 *)device_ids[i].c_str();
|
|
||||||
names[i] = (const UINT16 *)device_names[i].c_str();
|
|
||||||
role[i] = eRoleUnknownFormFactor;
|
|
||||||
}
|
|
||||||
|
|
||||||
PaWasapiWinrt_SetDefaultDeviceId((const UINT16 *)default_device_id.c_str(), !capture);
|
|
||||||
PaWasapiWinrt_PopulateDeviceList(ids.data(), names.data(), role.data(), count, !capture);
|
|
||||||
PaWasapi_UpdateDeviceList();
|
|
||||||
|
|
||||||
----------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
#endif /* PA_WIN_WASAPI_H */
|
|
|
@ -1,199 +0,0 @@
|
||||||
#ifndef PA_WIN_WAVEFORMAT_H
|
|
||||||
#define PA_WIN_WAVEFORMAT_H
|
|
||||||
|
|
||||||
/*
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* Windows WAVEFORMAT* data structure utilities
|
|
||||||
* portaudio.h should be included before this file.
|
|
||||||
*
|
|
||||||
* Copyright (c) 2007 Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup public_header
|
|
||||||
@brief Windows specific PortAudio API extension and utilities header file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
The following #defines for speaker channel masks are the same
|
|
||||||
as those in ksmedia.h, except with PAWIN_ prepended, KSAUDIO_ removed
|
|
||||||
in some cases, and casts to PaWinWaveFormatChannelMask added.
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef unsigned long PaWinWaveFormatChannelMask;
|
|
||||||
|
|
||||||
/* Speaker Positions: */
|
|
||||||
#define PAWIN_SPEAKER_FRONT_LEFT ((PaWinWaveFormatChannelMask)0x1)
|
|
||||||
#define PAWIN_SPEAKER_FRONT_RIGHT ((PaWinWaveFormatChannelMask)0x2)
|
|
||||||
#define PAWIN_SPEAKER_FRONT_CENTER ((PaWinWaveFormatChannelMask)0x4)
|
|
||||||
#define PAWIN_SPEAKER_LOW_FREQUENCY ((PaWinWaveFormatChannelMask)0x8)
|
|
||||||
#define PAWIN_SPEAKER_BACK_LEFT ((PaWinWaveFormatChannelMask)0x10)
|
|
||||||
#define PAWIN_SPEAKER_BACK_RIGHT ((PaWinWaveFormatChannelMask)0x20)
|
|
||||||
#define PAWIN_SPEAKER_FRONT_LEFT_OF_CENTER ((PaWinWaveFormatChannelMask)0x40)
|
|
||||||
#define PAWIN_SPEAKER_FRONT_RIGHT_OF_CENTER ((PaWinWaveFormatChannelMask)0x80)
|
|
||||||
#define PAWIN_SPEAKER_BACK_CENTER ((PaWinWaveFormatChannelMask)0x100)
|
|
||||||
#define PAWIN_SPEAKER_SIDE_LEFT ((PaWinWaveFormatChannelMask)0x200)
|
|
||||||
#define PAWIN_SPEAKER_SIDE_RIGHT ((PaWinWaveFormatChannelMask)0x400)
|
|
||||||
#define PAWIN_SPEAKER_TOP_CENTER ((PaWinWaveFormatChannelMask)0x800)
|
|
||||||
#define PAWIN_SPEAKER_TOP_FRONT_LEFT ((PaWinWaveFormatChannelMask)0x1000)
|
|
||||||
#define PAWIN_SPEAKER_TOP_FRONT_CENTER ((PaWinWaveFormatChannelMask)0x2000)
|
|
||||||
#define PAWIN_SPEAKER_TOP_FRONT_RIGHT ((PaWinWaveFormatChannelMask)0x4000)
|
|
||||||
#define PAWIN_SPEAKER_TOP_BACK_LEFT ((PaWinWaveFormatChannelMask)0x8000)
|
|
||||||
#define PAWIN_SPEAKER_TOP_BACK_CENTER ((PaWinWaveFormatChannelMask)0x10000)
|
|
||||||
#define PAWIN_SPEAKER_TOP_BACK_RIGHT ((PaWinWaveFormatChannelMask)0x20000)
|
|
||||||
|
|
||||||
/* Bit mask locations reserved for future use */
|
|
||||||
#define PAWIN_SPEAKER_RESERVED ((PaWinWaveFormatChannelMask)0x7FFC0000)
|
|
||||||
|
|
||||||
/* Used to specify that any possible permutation of speaker configurations */
|
|
||||||
#define PAWIN_SPEAKER_ALL ((PaWinWaveFormatChannelMask)0x80000000)
|
|
||||||
|
|
||||||
/* DirectSound Speaker Config */
|
|
||||||
#define PAWIN_SPEAKER_DIRECTOUT 0
|
|
||||||
#define PAWIN_SPEAKER_MONO (PAWIN_SPEAKER_FRONT_CENTER)
|
|
||||||
#define PAWIN_SPEAKER_STEREO (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT)
|
|
||||||
#define PAWIN_SPEAKER_QUAD (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \
|
|
||||||
PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT)
|
|
||||||
#define PAWIN_SPEAKER_SURROUND (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \
|
|
||||||
PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_BACK_CENTER)
|
|
||||||
#define PAWIN_SPEAKER_5POINT1 (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \
|
|
||||||
PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \
|
|
||||||
PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT)
|
|
||||||
#define PAWIN_SPEAKER_7POINT1 (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \
|
|
||||||
PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \
|
|
||||||
PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT | \
|
|
||||||
PAWIN_SPEAKER_FRONT_LEFT_OF_CENTER | PAWIN_SPEAKER_FRONT_RIGHT_OF_CENTER)
|
|
||||||
#define PAWIN_SPEAKER_5POINT1_SURROUND (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \
|
|
||||||
PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \
|
|
||||||
PAWIN_SPEAKER_SIDE_LEFT | PAWIN_SPEAKER_SIDE_RIGHT)
|
|
||||||
#define PAWIN_SPEAKER_7POINT1_SURROUND (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \
|
|
||||||
PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \
|
|
||||||
PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT | \
|
|
||||||
PAWIN_SPEAKER_SIDE_LEFT | PAWIN_SPEAKER_SIDE_RIGHT)
|
|
||||||
/*
|
|
||||||
According to the Microsoft documentation:
|
|
||||||
The following are obsolete 5.1 and 7.1 settings (they lack side speakers). Note this means
|
|
||||||
that the default 5.1 and 7.1 settings (KSAUDIO_SPEAKER_5POINT1 and KSAUDIO_SPEAKER_7POINT1 are
|
|
||||||
similarly obsolete but are unchanged for compatibility reasons).
|
|
||||||
*/
|
|
||||||
#define PAWIN_SPEAKER_5POINT1_BACK PAWIN_SPEAKER_5POINT1
|
|
||||||
#define PAWIN_SPEAKER_7POINT1_WIDE PAWIN_SPEAKER_7POINT1
|
|
||||||
|
|
||||||
/* DVD Speaker Positions */
|
|
||||||
#define PAWIN_SPEAKER_GROUND_FRONT_LEFT PAWIN_SPEAKER_FRONT_LEFT
|
|
||||||
#define PAWIN_SPEAKER_GROUND_FRONT_CENTER PAWIN_SPEAKER_FRONT_CENTER
|
|
||||||
#define PAWIN_SPEAKER_GROUND_FRONT_RIGHT PAWIN_SPEAKER_FRONT_RIGHT
|
|
||||||
#define PAWIN_SPEAKER_GROUND_REAR_LEFT PAWIN_SPEAKER_BACK_LEFT
|
|
||||||
#define PAWIN_SPEAKER_GROUND_REAR_RIGHT PAWIN_SPEAKER_BACK_RIGHT
|
|
||||||
#define PAWIN_SPEAKER_TOP_MIDDLE PAWIN_SPEAKER_TOP_CENTER
|
|
||||||
#define PAWIN_SPEAKER_SUPER_WOOFER PAWIN_SPEAKER_LOW_FREQUENCY
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
PaWinWaveFormat is defined here to provide compatibility with
|
|
||||||
compilation environments which don't have headers defining
|
|
||||||
WAVEFORMATEXTENSIBLE (e.g. older versions of MSVC, Borland C++ etc.
|
|
||||||
|
|
||||||
The fields for WAVEFORMATEX and WAVEFORMATEXTENSIBLE are declared as an
|
|
||||||
unsigned char array here to avoid clients who include this file having
|
|
||||||
a dependency on windows.h and mmsystem.h, and also to to avoid having
|
|
||||||
to write separate packing pragmas for each compiler.
|
|
||||||
*/
|
|
||||||
#define PAWIN_SIZEOF_WAVEFORMATEX 18
|
|
||||||
#define PAWIN_SIZEOF_WAVEFORMATEXTENSIBLE (PAWIN_SIZEOF_WAVEFORMATEX + 22)
|
|
||||||
|
|
||||||
typedef struct{
|
|
||||||
unsigned char fields[ PAWIN_SIZEOF_WAVEFORMATEXTENSIBLE ];
|
|
||||||
unsigned long extraLongForAlignment; /* ensure that compiler aligns struct to DWORD */
|
|
||||||
} PaWinWaveFormat;
|
|
||||||
|
|
||||||
/*
|
|
||||||
WAVEFORMATEXTENSIBLE fields:
|
|
||||||
|
|
||||||
union {
|
|
||||||
WORD wValidBitsPerSample;
|
|
||||||
WORD wSamplesPerBlock;
|
|
||||||
WORD wReserved;
|
|
||||||
} Samples;
|
|
||||||
DWORD dwChannelMask;
|
|
||||||
GUID SubFormat;
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define PAWIN_INDEXOF_WVALIDBITSPERSAMPLE (PAWIN_SIZEOF_WAVEFORMATEX+0)
|
|
||||||
#define PAWIN_INDEXOF_DWCHANNELMASK (PAWIN_SIZEOF_WAVEFORMATEX+2)
|
|
||||||
#define PAWIN_INDEXOF_SUBFORMAT (PAWIN_SIZEOF_WAVEFORMATEX+6)
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
Valid values to pass for the waveFormatTag PaWin_InitializeWaveFormatEx and
|
|
||||||
PaWin_InitializeWaveFormatExtensible functions below. These must match
|
|
||||||
the standard Windows WAVE_FORMAT_* values.
|
|
||||||
*/
|
|
||||||
#define PAWIN_WAVE_FORMAT_PCM (1)
|
|
||||||
#define PAWIN_WAVE_FORMAT_IEEE_FLOAT (3)
|
|
||||||
#define PAWIN_WAVE_FORMAT_DOLBY_AC3_SPDIF (0x0092)
|
|
||||||
#define PAWIN_WAVE_FORMAT_WMA_SPDIF (0x0164)
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
returns PAWIN_WAVE_FORMAT_PCM or PAWIN_WAVE_FORMAT_IEEE_FLOAT
|
|
||||||
depending on the sampleFormat parameter.
|
|
||||||
*/
|
|
||||||
int PaWin_SampleFormatToLinearWaveFormatTag( PaSampleFormat sampleFormat );
|
|
||||||
|
|
||||||
/*
|
|
||||||
Use the following two functions to initialize the waveformat structure.
|
|
||||||
*/
|
|
||||||
|
|
||||||
void PaWin_InitializeWaveFormatEx( PaWinWaveFormat *waveFormat,
|
|
||||||
int numChannels, PaSampleFormat sampleFormat, int waveFormatTag, double sampleRate );
|
|
||||||
|
|
||||||
|
|
||||||
void PaWin_InitializeWaveFormatExtensible( PaWinWaveFormat *waveFormat,
|
|
||||||
int numChannels, PaSampleFormat sampleFormat, int waveFormatTag, double sampleRate,
|
|
||||||
PaWinWaveFormatChannelMask channelMask );
|
|
||||||
|
|
||||||
|
|
||||||
/* Map a channel count to a speaker channel mask */
|
|
||||||
PaWinWaveFormatChannelMask PaWin_DefaultChannelMask( int numChannels );
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
#endif /* PA_WIN_WAVEFORMAT_H */
|
|
|
@ -1,137 +0,0 @@
|
||||||
#ifndef PA_WIN_WDMKS_H
|
|
||||||
#define PA_WIN_WDMKS_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* WDM/KS specific extensions
|
|
||||||
*
|
|
||||||
* Copyright (c) 1999-2007 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup public_header
|
|
||||||
@brief WDM Kernel Streaming-specific PortAudio API extension header file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
|
|
||||||
#include <windows.h>
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
/** Flags to indicate valid fields in PaWinWDMKSInfo.
|
|
||||||
@see PaWinWDMKSInfo
|
|
||||||
@version Available as of 19.5.0.
|
|
||||||
*/
|
|
||||||
typedef enum PaWinWDMKSFlags
|
|
||||||
{
|
|
||||||
/** Makes WDMKS use the supplied latency figures instead of relying on the frame size reported
|
|
||||||
by the WaveCyclic device. Use at own risk!
|
|
||||||
*/
|
|
||||||
paWinWDMKSOverrideFramesize = (1 << 0),
|
|
||||||
|
|
||||||
/** Makes WDMKS (output stream) use the given channelMask instead of the default.
|
|
||||||
@version Available as of 19.5.0.
|
|
||||||
*/
|
|
||||||
paWinWDMKSUseGivenChannelMask = (1 << 1),
|
|
||||||
|
|
||||||
} PaWinWDMKSFlags;
|
|
||||||
|
|
||||||
typedef struct PaWinWDMKSInfo{
|
|
||||||
unsigned long size; /**< sizeof(PaWinWDMKSInfo) */
|
|
||||||
PaHostApiTypeId hostApiType; /**< paWDMKS */
|
|
||||||
unsigned long version; /**< 1 */
|
|
||||||
|
|
||||||
/** Flags indicate which fields are valid.
|
|
||||||
@see PaWinWDMKSFlags
|
|
||||||
@version Available as of 19.5.0.
|
|
||||||
*/
|
|
||||||
unsigned long flags;
|
|
||||||
|
|
||||||
/** The number of packets to use for WaveCyclic devices, range is [2, 8]. Set to zero for default value of 2. */
|
|
||||||
unsigned noOfPackets;
|
|
||||||
|
|
||||||
/** If paWinWDMKSUseGivenChannelMask bit is set in flags, use this as channelMask instead of default.
|
|
||||||
@see PaWinWDMKSFlags
|
|
||||||
@version Available as of 19.5.0.
|
|
||||||
*/
|
|
||||||
unsigned channelMask;
|
|
||||||
} PaWinWDMKSInfo;
|
|
||||||
|
|
||||||
typedef enum PaWDMKSType
|
|
||||||
{
|
|
||||||
Type_kNotUsed,
|
|
||||||
Type_kWaveCyclic,
|
|
||||||
Type_kWaveRT,
|
|
||||||
Type_kCnt,
|
|
||||||
} PaWDMKSType;
|
|
||||||
|
|
||||||
typedef enum PaWDMKSSubType
|
|
||||||
{
|
|
||||||
SubType_kUnknown,
|
|
||||||
SubType_kNotification,
|
|
||||||
SubType_kPolled,
|
|
||||||
SubType_kCnt,
|
|
||||||
} PaWDMKSSubType;
|
|
||||||
|
|
||||||
typedef struct PaWinWDMKSDeviceInfo {
|
|
||||||
wchar_t filterPath[MAX_PATH]; /**< KS filter path in Unicode! */
|
|
||||||
wchar_t topologyPath[MAX_PATH]; /**< Topology filter path in Unicode! */
|
|
||||||
PaWDMKSType streamingType;
|
|
||||||
GUID deviceProductGuid; /**< The product GUID of the device (if supported) */
|
|
||||||
} PaWinWDMKSDeviceInfo;
|
|
||||||
|
|
||||||
typedef struct PaWDMKSDirectionSpecificStreamInfo
|
|
||||||
{
|
|
||||||
PaDeviceIndex device;
|
|
||||||
unsigned channels; /**< No of channels the device is opened with */
|
|
||||||
unsigned framesPerHostBuffer; /**< No of frames of the device buffer */
|
|
||||||
int endpointPinId; /**< Endpoint pin ID (on topology filter if topologyName is not empty) */
|
|
||||||
int muxNodeId; /**< Only valid for input */
|
|
||||||
PaWDMKSSubType streamingSubType; /**< Not known until device is opened for streaming */
|
|
||||||
} PaWDMKSDirectionSpecificStreamInfo;
|
|
||||||
|
|
||||||
typedef struct PaWDMKSSpecificStreamInfo {
|
|
||||||
PaWDMKSDirectionSpecificStreamInfo input;
|
|
||||||
PaWDMKSDirectionSpecificStreamInfo output;
|
|
||||||
} PaWDMKSSpecificStreamInfo;
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
#endif /* PA_WIN_DS_H */
|
|
|
@ -1,185 +0,0 @@
|
||||||
#ifndef PA_WIN_WMME_H
|
|
||||||
#define PA_WIN_WMME_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* PortAudio Portable Real-Time Audio Library
|
|
||||||
* MME specific extensions
|
|
||||||
*
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup public_header
|
|
||||||
@brief WMME-specific PortAudio API extension header file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
#include "pa_win_waveformat.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
/* The following are flags which can be set in
|
|
||||||
PaWinMmeStreamInfo's flags field.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define paWinMmeUseLowLevelLatencyParameters (0x01)
|
|
||||||
#define paWinMmeUseMultipleDevices (0x02) /* use mme specific multiple device feature */
|
|
||||||
#define paWinMmeUseChannelMask (0x04)
|
|
||||||
|
|
||||||
/* By default, the mme implementation drops the processing thread's priority
|
|
||||||
to THREAD_PRIORITY_NORMAL and sleeps the thread if the CPU load exceeds 100%
|
|
||||||
This flag disables any priority throttling. The processing thread will always
|
|
||||||
run at THREAD_PRIORITY_TIME_CRITICAL.
|
|
||||||
*/
|
|
||||||
#define paWinMmeDontThrottleOverloadedProcessingThread (0x08)
|
|
||||||
|
|
||||||
/* Flags for non-PCM spdif passthrough.
|
|
||||||
*/
|
|
||||||
#define paWinMmeWaveFormatDolbyAc3Spdif (0x10)
|
|
||||||
#define paWinMmeWaveFormatWmaSpdif (0x20)
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct PaWinMmeDeviceAndChannelCount{
|
|
||||||
PaDeviceIndex device;
|
|
||||||
int channelCount;
|
|
||||||
}PaWinMmeDeviceAndChannelCount;
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct PaWinMmeStreamInfo{
|
|
||||||
unsigned long size; /**< sizeof(PaWinMmeStreamInfo) */
|
|
||||||
PaHostApiTypeId hostApiType; /**< paMME */
|
|
||||||
unsigned long version; /**< 1 */
|
|
||||||
|
|
||||||
unsigned long flags;
|
|
||||||
|
|
||||||
/* low-level latency setting support
|
|
||||||
These settings control the number and size of host buffers in order
|
|
||||||
to set latency. They will be used instead of the generic parameters
|
|
||||||
to Pa_OpenStream() if flags contains the PaWinMmeUseLowLevelLatencyParameters
|
|
||||||
flag.
|
|
||||||
|
|
||||||
If PaWinMmeStreamInfo structures with PaWinMmeUseLowLevelLatencyParameters
|
|
||||||
are supplied for both input and output in a full duplex stream, then the
|
|
||||||
input and output framesPerBuffer must be the same, or the larger of the
|
|
||||||
two must be a multiple of the smaller, otherwise a
|
|
||||||
paIncompatibleHostApiSpecificStreamInfo error will be returned from
|
|
||||||
Pa_OpenStream().
|
|
||||||
*/
|
|
||||||
unsigned long framesPerBuffer;
|
|
||||||
unsigned long bufferCount; /* formerly numBuffers */
|
|
||||||
|
|
||||||
/* multiple devices per direction support
|
|
||||||
If flags contains the PaWinMmeUseMultipleDevices flag,
|
|
||||||
this functionality will be used, otherwise the device parameter to
|
|
||||||
Pa_OpenStream() will be used instead.
|
|
||||||
If devices are specified here, the corresponding device parameter
|
|
||||||
to Pa_OpenStream() should be set to paUseHostApiSpecificDeviceSpecification,
|
|
||||||
otherwise an paInvalidDevice error will result.
|
|
||||||
The total number of channels across all specified devices
|
|
||||||
must agree with the corresponding channelCount parameter to
|
|
||||||
Pa_OpenStream() otherwise a paInvalidChannelCount error will result.
|
|
||||||
*/
|
|
||||||
PaWinMmeDeviceAndChannelCount *devices;
|
|
||||||
unsigned long deviceCount;
|
|
||||||
|
|
||||||
/*
|
|
||||||
support for WAVEFORMATEXTENSIBLE channel masks. If flags contains
|
|
||||||
paWinMmeUseChannelMask this allows you to specify which speakers
|
|
||||||
to address in a multichannel stream. Constants for channelMask
|
|
||||||
are specified in pa_win_waveformat.h
|
|
||||||
|
|
||||||
*/
|
|
||||||
PaWinWaveFormatChannelMask channelMask;
|
|
||||||
|
|
||||||
}PaWinMmeStreamInfo;
|
|
||||||
|
|
||||||
|
|
||||||
/** Retrieve the number of wave in handles used by a PortAudio WinMME stream.
|
|
||||||
Returns zero if the stream is output only.
|
|
||||||
|
|
||||||
@return A non-negative value indicating the number of wave in handles
|
|
||||||
or, a PaErrorCode (which are always negative) if PortAudio is not initialized
|
|
||||||
or an error is encountered.
|
|
||||||
|
|
||||||
@see PaWinMME_GetStreamInputHandle
|
|
||||||
*/
|
|
||||||
int PaWinMME_GetStreamInputHandleCount( PaStream* stream );
|
|
||||||
|
|
||||||
|
|
||||||
/** Retrieve a wave in handle used by a PortAudio WinMME stream.
|
|
||||||
|
|
||||||
@param stream The stream to query.
|
|
||||||
@param handleIndex The zero based index of the wave in handle to retrieve. This
|
|
||||||
should be in the range [0, PaWinMME_GetStreamInputHandleCount(stream)-1].
|
|
||||||
|
|
||||||
@return A valid wave in handle, or NULL if an error occurred.
|
|
||||||
|
|
||||||
@see PaWinMME_GetStreamInputHandle
|
|
||||||
*/
|
|
||||||
HWAVEIN PaWinMME_GetStreamInputHandle( PaStream* stream, int handleIndex );
|
|
||||||
|
|
||||||
|
|
||||||
/** Retrieve the number of wave out handles used by a PortAudio WinMME stream.
|
|
||||||
Returns zero if the stream is input only.
|
|
||||||
|
|
||||||
@return A non-negative value indicating the number of wave out handles
|
|
||||||
or, a PaErrorCode (which are always negative) if PortAudio is not initialized
|
|
||||||
or an error is encountered.
|
|
||||||
|
|
||||||
@see PaWinMME_GetStreamOutputHandle
|
|
||||||
*/
|
|
||||||
int PaWinMME_GetStreamOutputHandleCount( PaStream* stream );
|
|
||||||
|
|
||||||
|
|
||||||
/** Retrieve a wave out handle used by a PortAudio WinMME stream.
|
|
||||||
|
|
||||||
@param stream The stream to query.
|
|
||||||
@param handleIndex The zero based index of the wave out handle to retrieve.
|
|
||||||
This should be in the range [0, PaWinMME_GetStreamOutputHandleCount(stream)-1].
|
|
||||||
|
|
||||||
@return A valid wave out handle, or NULL if an error occurred.
|
|
||||||
|
|
||||||
@see PaWinMME_GetStreamOutputHandleCount
|
|
||||||
*/
|
|
||||||
HWAVEOUT PaWinMME_GetStreamOutputHandle( PaStream* stream, int handleIndex );
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
#endif /* PA_WIN_WMME_H */
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,105 +0,0 @@
|
||||||
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
|
|
||||||
<meta name="GENERATOR" content="Mozilla/4.79 [en] (Windows NT 5.0; U) [Netscape]">
|
|
||||||
<meta name="Author" content="Phil Burk">
|
|
||||||
<meta name="Description" content="PortAudio is a cross platform, open-source, audio I/O library.It provides a very simple API for recording and/or playing sound using a simple callback function.">
|
|
||||||
<meta name="KeyWords" content="audio, library, portable, open-source, DirectSound,sound, music, JSyn, synthesis,">
|
|
||||||
<title>PortAudio Implementations for DirectSound</title>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<center><table COLS=1 WIDTH="100%" BGCOLOR="#FADA7A" >
|
|
||||||
<tr>
|
|
||||||
<td>
|
|
||||||
<center>
|
|
||||||
<h1>
|
|
||||||
PortAudio - Portable Audio Library</h1></center>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</table></center>
|
|
||||||
|
|
||||||
<p>PortAudio is a cross platform, <a href="#License">open-source</a>, audio
|
|
||||||
I/O library proposed by <b>Ross Bencina</b> to the <a href="http://shoko.calarts.edu/~glmrboy/musicdsp/music-dsp.html">music-dsp</a>
|
|
||||||
mailing list. It lets you write simple audio programs in 'C' that will
|
|
||||||
compile and run on <b>Windows, Macintosh, Unix, BeOS</b>. PortAudio is
|
|
||||||
intended to promote the exchange of audio synthesis software between developers
|
|
||||||
on different platforms.
|
|
||||||
<p>For complete information on PortAudio and to download the latest releases,
|
|
||||||
please visit "<b><font size=+2><a href="http://www.portaudio.com">http://www.portaudio.com</a></font></b>".
|
|
||||||
<br>
|
|
||||||
<br>
|
|
||||||
<center>
|
|
||||||
<h2>
|
|
||||||
<b><a href="doc/html/index.html">Click here for Documentation</a></b></h2></center>
|
|
||||||
|
|
||||||
<h2>
|
|
||||||
<b><font size=+2></font></b></h2>
|
|
||||||
|
|
||||||
<h2>
|
|
||||||
<b><font size=+2>Contacts and E-Mail List</font></b></h2>
|
|
||||||
|
|
||||||
<ul>
|
|
||||||
<li>
|
|
||||||
If you are using or implementing PortAudio then please join the <b><font size=+1><a href="http://techweb.rfa.org/mailman/listinfo/portaudio">PortAudio
|
|
||||||
mail list</a></font><font size=+2> </font></b>.</li>
|
|
||||||
|
|
||||||
<li>
|
|
||||||
If you find bugs in one of these implementations, or have suggestions,
|
|
||||||
please e-mail them to <a href="mailto:philburk@softsynth.com">Phil Burk</a>.</li>
|
|
||||||
|
|
||||||
<li>
|
|
||||||
If you make improvements to the library, please send them to us so we can
|
|
||||||
incorporate the improvements.</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
<h2>
|
|
||||||
<a NAME="License"></a>License</h2>
|
|
||||||
|
|
||||||
<table width="600">
|
|
||||||
<tr><td>
|
|
||||||
<p>
|
|
||||||
PortAudio Portable Real-Time Audio Library
|
|
||||||
<br>Copyright © 1999-2006 Ross Bencina and Phil Burk
|
|
||||||
</p>
|
|
||||||
<p>Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
a copy of this software and associated documentation files (the "Software"),
|
|
||||||
to deal in the Software without restriction, including without limitation
|
|
||||||
the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
||||||
and/or sell copies of the Software, and to permit persons to whom the Software
|
|
||||||
is furnished to do so, subject to the following conditions:
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
The above copyright notice and this permission notice shall be included
|
|
||||||
in all copies or substantial portions of the Software.
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
||||||
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND ON INFRINGEMENT.
|
|
||||||
<br>IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
||||||
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT
|
|
||||||
OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR
|
|
||||||
THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p><i>
|
|
||||||
The text above constitutes the entire PortAudio license; however,
|
|
||||||
the PortAudio community also makes the following non-binding requests:
|
|
||||||
</i></p>
|
|
||||||
<p><i>
|
|
||||||
Any person wishing to distribute modifications to the Software is
|
|
||||||
requested to send the modifications to the original developer so that
|
|
||||||
they can be incorporated into the canonical version. It is also
|
|
||||||
requested that these non-binding requests be included along with the
|
|
||||||
license above.
|
|
||||||
</i></p>
|
|
||||||
|
|
||||||
</td></tr></table>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
|
@ -1,527 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
# install - install a program, script, or datafile
|
|
||||||
|
|
||||||
scriptversion=2011-11-20.07; # UTC
|
|
||||||
|
|
||||||
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
|
||||||
# later released in X11R6 (xc/config/util/install.sh) with the
|
|
||||||
# following copyright and license.
|
|
||||||
#
|
|
||||||
# Copyright (C) 1994 X Consortium
|
|
||||||
#
|
|
||||||
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
# of this software and associated documentation files (the "Software"), to
|
|
||||||
# deal in the Software without restriction, including without limitation the
|
|
||||||
# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
||||||
# sell copies of the Software, and to permit persons to whom the Software is
|
|
||||||
# furnished to do so, subject to the following conditions:
|
|
||||||
#
|
|
||||||
# The above copyright notice and this permission notice shall be included in
|
|
||||||
# all copies or substantial portions of the Software.
|
|
||||||
#
|
|
||||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
|
||||||
# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
|
|
||||||
# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
#
|
|
||||||
# Except as contained in this notice, the name of the X Consortium shall not
|
|
||||||
# be used in advertising or otherwise to promote the sale, use or other deal-
|
|
||||||
# ings in this Software without prior written authorization from the X Consor-
|
|
||||||
# tium.
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# FSF changes to this file are in the public domain.
|
|
||||||
#
|
|
||||||
# Calling this script install-sh is preferred over install.sh, to prevent
|
|
||||||
# 'make' implicit rules from creating a file called install from it
|
|
||||||
# when there is no Makefile.
|
|
||||||
#
|
|
||||||
# This script is compatible with the BSD install script, but was written
|
|
||||||
# from scratch.
|
|
||||||
|
|
||||||
nl='
|
|
||||||
'
|
|
||||||
IFS=" "" $nl"
|
|
||||||
|
|
||||||
# set DOITPROG to echo to test this script
|
|
||||||
|
|
||||||
# Don't use :- since 4.3BSD and earlier shells don't like it.
|
|
||||||
doit=${DOITPROG-}
|
|
||||||
if test -z "$doit"; then
|
|
||||||
doit_exec=exec
|
|
||||||
else
|
|
||||||
doit_exec=$doit
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Put in absolute file names if you don't have them in your path;
|
|
||||||
# or use environment vars.
|
|
||||||
|
|
||||||
chgrpprog=${CHGRPPROG-chgrp}
|
|
||||||
chmodprog=${CHMODPROG-chmod}
|
|
||||||
chownprog=${CHOWNPROG-chown}
|
|
||||||
cmpprog=${CMPPROG-cmp}
|
|
||||||
cpprog=${CPPROG-cp}
|
|
||||||
mkdirprog=${MKDIRPROG-mkdir}
|
|
||||||
mvprog=${MVPROG-mv}
|
|
||||||
rmprog=${RMPROG-rm}
|
|
||||||
stripprog=${STRIPPROG-strip}
|
|
||||||
|
|
||||||
posix_glob='?'
|
|
||||||
initialize_posix_glob='
|
|
||||||
test "$posix_glob" != "?" || {
|
|
||||||
if (set -f) 2>/dev/null; then
|
|
||||||
posix_glob=
|
|
||||||
else
|
|
||||||
posix_glob=:
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
'
|
|
||||||
|
|
||||||
posix_mkdir=
|
|
||||||
|
|
||||||
# Desired mode of installed file.
|
|
||||||
mode=0755
|
|
||||||
|
|
||||||
chgrpcmd=
|
|
||||||
chmodcmd=$chmodprog
|
|
||||||
chowncmd=
|
|
||||||
mvcmd=$mvprog
|
|
||||||
rmcmd="$rmprog -f"
|
|
||||||
stripcmd=
|
|
||||||
|
|
||||||
src=
|
|
||||||
dst=
|
|
||||||
dir_arg=
|
|
||||||
dst_arg=
|
|
||||||
|
|
||||||
copy_on_change=false
|
|
||||||
no_target_directory=
|
|
||||||
|
|
||||||
usage="\
|
|
||||||
Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE
|
|
||||||
or: $0 [OPTION]... SRCFILES... DIRECTORY
|
|
||||||
or: $0 [OPTION]... -t DIRECTORY SRCFILES...
|
|
||||||
or: $0 [OPTION]... -d DIRECTORIES...
|
|
||||||
|
|
||||||
In the 1st form, copy SRCFILE to DSTFILE.
|
|
||||||
In the 2nd and 3rd, copy all SRCFILES to DIRECTORY.
|
|
||||||
In the 4th, create DIRECTORIES.
|
|
||||||
|
|
||||||
Options:
|
|
||||||
--help display this help and exit.
|
|
||||||
--version display version info and exit.
|
|
||||||
|
|
||||||
-c (ignored)
|
|
||||||
-C install only if different (preserve the last data modification time)
|
|
||||||
-d create directories instead of installing files.
|
|
||||||
-g GROUP $chgrpprog installed files to GROUP.
|
|
||||||
-m MODE $chmodprog installed files to MODE.
|
|
||||||
-o USER $chownprog installed files to USER.
|
|
||||||
-s $stripprog installed files.
|
|
||||||
-t DIRECTORY install into DIRECTORY.
|
|
||||||
-T report an error if DSTFILE is a directory.
|
|
||||||
|
|
||||||
Environment variables override the default commands:
|
|
||||||
CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG
|
|
||||||
RMPROG STRIPPROG
|
|
||||||
"
|
|
||||||
|
|
||||||
while test $# -ne 0; do
|
|
||||||
case $1 in
|
|
||||||
-c) ;;
|
|
||||||
|
|
||||||
-C) copy_on_change=true;;
|
|
||||||
|
|
||||||
-d) dir_arg=true;;
|
|
||||||
|
|
||||||
-g) chgrpcmd="$chgrpprog $2"
|
|
||||||
shift;;
|
|
||||||
|
|
||||||
--help) echo "$usage"; exit $?;;
|
|
||||||
|
|
||||||
-m) mode=$2
|
|
||||||
case $mode in
|
|
||||||
*' '* | *' '* | *'
|
|
||||||
'* | *'*'* | *'?'* | *'['*)
|
|
||||||
echo "$0: invalid mode: $mode" >&2
|
|
||||||
exit 1;;
|
|
||||||
esac
|
|
||||||
shift;;
|
|
||||||
|
|
||||||
-o) chowncmd="$chownprog $2"
|
|
||||||
shift;;
|
|
||||||
|
|
||||||
-s) stripcmd=$stripprog;;
|
|
||||||
|
|
||||||
-t) dst_arg=$2
|
|
||||||
# Protect names problematic for 'test' and other utilities.
|
|
||||||
case $dst_arg in
|
|
||||||
-* | [=\(\)!]) dst_arg=./$dst_arg;;
|
|
||||||
esac
|
|
||||||
shift;;
|
|
||||||
|
|
||||||
-T) no_target_directory=true;;
|
|
||||||
|
|
||||||
--version) echo "$0 $scriptversion"; exit $?;;
|
|
||||||
|
|
||||||
--) shift
|
|
||||||
break;;
|
|
||||||
|
|
||||||
-*) echo "$0: invalid option: $1" >&2
|
|
||||||
exit 1;;
|
|
||||||
|
|
||||||
*) break;;
|
|
||||||
esac
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
|
|
||||||
if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then
|
|
||||||
# When -d is used, all remaining arguments are directories to create.
|
|
||||||
# When -t is used, the destination is already specified.
|
|
||||||
# Otherwise, the last argument is the destination. Remove it from $@.
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
if test -n "$dst_arg"; then
|
|
||||||
# $@ is not empty: it contains at least $arg.
|
|
||||||
set fnord "$@" "$dst_arg"
|
|
||||||
shift # fnord
|
|
||||||
fi
|
|
||||||
shift # arg
|
|
||||||
dst_arg=$arg
|
|
||||||
# Protect names problematic for 'test' and other utilities.
|
|
||||||
case $dst_arg in
|
|
||||||
-* | [=\(\)!]) dst_arg=./$dst_arg;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test $# -eq 0; then
|
|
||||||
if test -z "$dir_arg"; then
|
|
||||||
echo "$0: no input file specified." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
# It's OK to call 'install-sh -d' without argument.
|
|
||||||
# This can happen when creating conditional directories.
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -z "$dir_arg"; then
|
|
||||||
do_exit='(exit $ret); exit $ret'
|
|
||||||
trap "ret=129; $do_exit" 1
|
|
||||||
trap "ret=130; $do_exit" 2
|
|
||||||
trap "ret=141; $do_exit" 13
|
|
||||||
trap "ret=143; $do_exit" 15
|
|
||||||
|
|
||||||
# Set umask so as not to create temps with too-generous modes.
|
|
||||||
# However, 'strip' requires both read and write access to temps.
|
|
||||||
case $mode in
|
|
||||||
# Optimize common cases.
|
|
||||||
*644) cp_umask=133;;
|
|
||||||
*755) cp_umask=22;;
|
|
||||||
|
|
||||||
*[0-7])
|
|
||||||
if test -z "$stripcmd"; then
|
|
||||||
u_plus_rw=
|
|
||||||
else
|
|
||||||
u_plus_rw='% 200'
|
|
||||||
fi
|
|
||||||
cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;;
|
|
||||||
*)
|
|
||||||
if test -z "$stripcmd"; then
|
|
||||||
u_plus_rw=
|
|
||||||
else
|
|
||||||
u_plus_rw=,u+rw
|
|
||||||
fi
|
|
||||||
cp_umask=$mode$u_plus_rw;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
for src
|
|
||||||
do
|
|
||||||
# Protect names problematic for 'test' and other utilities.
|
|
||||||
case $src in
|
|
||||||
-* | [=\(\)!]) src=./$src;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
dst=$src
|
|
||||||
dstdir=$dst
|
|
||||||
test -d "$dstdir"
|
|
||||||
dstdir_status=$?
|
|
||||||
else
|
|
||||||
|
|
||||||
# Waiting for this to be detected by the "$cpprog $src $dsttmp" command
|
|
||||||
# might cause directories to be created, which would be especially bad
|
|
||||||
# if $src (and thus $dsttmp) contains '*'.
|
|
||||||
if test ! -f "$src" && test ! -d "$src"; then
|
|
||||||
echo "$0: $src does not exist." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -z "$dst_arg"; then
|
|
||||||
echo "$0: no destination specified." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
dst=$dst_arg
|
|
||||||
|
|
||||||
# If destination is a directory, append the input filename; won't work
|
|
||||||
# if double slashes aren't ignored.
|
|
||||||
if test -d "$dst"; then
|
|
||||||
if test -n "$no_target_directory"; then
|
|
||||||
echo "$0: $dst_arg: Is a directory" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
dstdir=$dst
|
|
||||||
dst=$dstdir/`basename "$src"`
|
|
||||||
dstdir_status=0
|
|
||||||
else
|
|
||||||
# Prefer dirname, but fall back on a substitute if dirname fails.
|
|
||||||
dstdir=`
|
|
||||||
(dirname "$dst") 2>/dev/null ||
|
|
||||||
expr X"$dst" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
|
||||||
X"$dst" : 'X\(//\)[^/]' \| \
|
|
||||||
X"$dst" : 'X\(//\)$' \| \
|
|
||||||
X"$dst" : 'X\(/\)' \| . 2>/dev/null ||
|
|
||||||
echo X"$dst" |
|
|
||||||
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
|
|
||||||
s//\1/
|
|
||||||
q
|
|
||||||
}
|
|
||||||
/^X\(\/\/\)[^/].*/{
|
|
||||||
s//\1/
|
|
||||||
q
|
|
||||||
}
|
|
||||||
/^X\(\/\/\)$/{
|
|
||||||
s//\1/
|
|
||||||
q
|
|
||||||
}
|
|
||||||
/^X\(\/\).*/{
|
|
||||||
s//\1/
|
|
||||||
q
|
|
||||||
}
|
|
||||||
s/.*/./; q'
|
|
||||||
`
|
|
||||||
|
|
||||||
test -d "$dstdir"
|
|
||||||
dstdir_status=$?
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
obsolete_mkdir_used=false
|
|
||||||
|
|
||||||
if test $dstdir_status != 0; then
|
|
||||||
case $posix_mkdir in
|
|
||||||
'')
|
|
||||||
# Create intermediate dirs using mode 755 as modified by the umask.
|
|
||||||
# This is like FreeBSD 'install' as of 1997-10-28.
|
|
||||||
umask=`umask`
|
|
||||||
case $stripcmd.$umask in
|
|
||||||
# Optimize common cases.
|
|
||||||
*[2367][2367]) mkdir_umask=$umask;;
|
|
||||||
.*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;;
|
|
||||||
|
|
||||||
*[0-7])
|
|
||||||
mkdir_umask=`expr $umask + 22 \
|
|
||||||
- $umask % 100 % 40 + $umask % 20 \
|
|
||||||
- $umask % 10 % 4 + $umask % 2
|
|
||||||
`;;
|
|
||||||
*) mkdir_umask=$umask,go-w;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# With -d, create the new directory with the user-specified mode.
|
|
||||||
# Otherwise, rely on $mkdir_umask.
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
mkdir_mode=-m$mode
|
|
||||||
else
|
|
||||||
mkdir_mode=
|
|
||||||
fi
|
|
||||||
|
|
||||||
posix_mkdir=false
|
|
||||||
case $umask in
|
|
||||||
*[123567][0-7][0-7])
|
|
||||||
# POSIX mkdir -p sets u+wx bits regardless of umask, which
|
|
||||||
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
|
|
||||||
trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0
|
|
||||||
|
|
||||||
if (umask $mkdir_umask &&
|
|
||||||
exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1
|
|
||||||
then
|
|
||||||
if test -z "$dir_arg" || {
|
|
||||||
# Check for POSIX incompatibilities with -m.
|
|
||||||
# HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
|
|
||||||
# other-writable bit of parent directory when it shouldn't.
|
|
||||||
# FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
|
|
||||||
ls_ld_tmpdir=`ls -ld "$tmpdir"`
|
|
||||||
case $ls_ld_tmpdir in
|
|
||||||
d????-?r-*) different_mode=700;;
|
|
||||||
d????-?--*) different_mode=755;;
|
|
||||||
*) false;;
|
|
||||||
esac &&
|
|
||||||
$mkdirprog -m$different_mode -p -- "$tmpdir" && {
|
|
||||||
ls_ld_tmpdir_1=`ls -ld "$tmpdir"`
|
|
||||||
test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
then posix_mkdir=:
|
|
||||||
fi
|
|
||||||
rmdir "$tmpdir/d" "$tmpdir"
|
|
||||||
else
|
|
||||||
# Remove any dirs left behind by ancient mkdir implementations.
|
|
||||||
rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null
|
|
||||||
fi
|
|
||||||
trap '' 0;;
|
|
||||||
esac;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if
|
|
||||||
$posix_mkdir && (
|
|
||||||
umask $mkdir_umask &&
|
|
||||||
$doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir"
|
|
||||||
)
|
|
||||||
then :
|
|
||||||
else
|
|
||||||
|
|
||||||
# The umask is ridiculous, or mkdir does not conform to POSIX,
|
|
||||||
# or it failed possibly due to a race condition. Create the
|
|
||||||
# directory the slow way, step by step, checking for races as we go.
|
|
||||||
|
|
||||||
case $dstdir in
|
|
||||||
/*) prefix='/';;
|
|
||||||
[-=\(\)!]*) prefix='./';;
|
|
||||||
*) prefix='';;
|
|
||||||
esac
|
|
||||||
|
|
||||||
eval "$initialize_posix_glob"
|
|
||||||
|
|
||||||
oIFS=$IFS
|
|
||||||
IFS=/
|
|
||||||
$posix_glob set -f
|
|
||||||
set fnord $dstdir
|
|
||||||
shift
|
|
||||||
$posix_glob set +f
|
|
||||||
IFS=$oIFS
|
|
||||||
|
|
||||||
prefixes=
|
|
||||||
|
|
||||||
for d
|
|
||||||
do
|
|
||||||
test X"$d" = X && continue
|
|
||||||
|
|
||||||
prefix=$prefix$d
|
|
||||||
if test -d "$prefix"; then
|
|
||||||
prefixes=
|
|
||||||
else
|
|
||||||
if $posix_mkdir; then
|
|
||||||
(umask=$mkdir_umask &&
|
|
||||||
$doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break
|
|
||||||
# Don't fail if two instances are running concurrently.
|
|
||||||
test -d "$prefix" || exit 1
|
|
||||||
else
|
|
||||||
case $prefix in
|
|
||||||
*\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;;
|
|
||||||
*) qprefix=$prefix;;
|
|
||||||
esac
|
|
||||||
prefixes="$prefixes '$qprefix'"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
prefix=$prefix/
|
|
||||||
done
|
|
||||||
|
|
||||||
if test -n "$prefixes"; then
|
|
||||||
# Don't fail if two instances are running concurrently.
|
|
||||||
(umask $mkdir_umask &&
|
|
||||||
eval "\$doit_exec \$mkdirprog $prefixes") ||
|
|
||||||
test -d "$dstdir" || exit 1
|
|
||||||
obsolete_mkdir_used=true
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
{ test -z "$chowncmd" || $doit $chowncmd "$dst"; } &&
|
|
||||||
{ test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } &&
|
|
||||||
{ test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false ||
|
|
||||||
test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1
|
|
||||||
else
|
|
||||||
|
|
||||||
# Make a couple of temp file names in the proper directory.
|
|
||||||
dsttmp=$dstdir/_inst.$$_
|
|
||||||
rmtmp=$dstdir/_rm.$$_
|
|
||||||
|
|
||||||
# Trap to clean up those temp files at exit.
|
|
||||||
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
|
|
||||||
|
|
||||||
# Copy the file name to the temp name.
|
|
||||||
(umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") &&
|
|
||||||
|
|
||||||
# and set any options; do chmod last to preserve setuid bits.
|
|
||||||
#
|
|
||||||
# If any of these fail, we abort the whole thing. If we want to
|
|
||||||
# ignore errors from any of these, just make sure not to ignore
|
|
||||||
# errors from the above "$doit $cpprog $src $dsttmp" command.
|
|
||||||
#
|
|
||||||
{ test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } &&
|
|
||||||
{ test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } &&
|
|
||||||
{ test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } &&
|
|
||||||
{ test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } &&
|
|
||||||
|
|
||||||
# If -C, don't bother to copy if it wouldn't change the file.
|
|
||||||
if $copy_on_change &&
|
|
||||||
old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` &&
|
|
||||||
new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` &&
|
|
||||||
|
|
||||||
eval "$initialize_posix_glob" &&
|
|
||||||
$posix_glob set -f &&
|
|
||||||
set X $old && old=:$2:$4:$5:$6 &&
|
|
||||||
set X $new && new=:$2:$4:$5:$6 &&
|
|
||||||
$posix_glob set +f &&
|
|
||||||
|
|
||||||
test "$old" = "$new" &&
|
|
||||||
$cmpprog "$dst" "$dsttmp" >/dev/null 2>&1
|
|
||||||
then
|
|
||||||
rm -f "$dsttmp"
|
|
||||||
else
|
|
||||||
# Rename the file to the real destination.
|
|
||||||
$doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null ||
|
|
||||||
|
|
||||||
# The rename failed, perhaps because mv can't rename something else
|
|
||||||
# to itself, or perhaps because mv is so ancient that it does not
|
|
||||||
# support -f.
|
|
||||||
{
|
|
||||||
# Now remove or move aside any old file at destination location.
|
|
||||||
# We try this two ways since rm can't unlink itself on some
|
|
||||||
# systems and the destination file might be busy for other
|
|
||||||
# reasons. In this case, the final cleanup might fail but the new
|
|
||||||
# file should still install successfully.
|
|
||||||
{
|
|
||||||
test ! -f "$dst" ||
|
|
||||||
$doit $rmcmd -f "$dst" 2>/dev/null ||
|
|
||||||
{ $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null &&
|
|
||||||
{ $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; }
|
|
||||||
} ||
|
|
||||||
{ echo "$0: cannot unlink or rename $dst" >&2
|
|
||||||
(exit 1); exit 1
|
|
||||||
}
|
|
||||||
} &&
|
|
||||||
|
|
||||||
# Now rename the file to the real destination.
|
|
||||||
$doit $mvcmd "$dsttmp" "$dst"
|
|
||||||
}
|
|
||||||
fi || exit 1
|
|
||||||
|
|
||||||
trap '' 0
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Local variables:
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,215 +0,0 @@
|
||||||
#! /bin/sh
|
|
||||||
# Common wrapper for a few potentially missing GNU programs.
|
|
||||||
|
|
||||||
scriptversion=2013-10-28.13; # UTC
|
|
||||||
|
|
||||||
# Copyright (C) 1996-2013 Free Software Foundation, Inc.
|
|
||||||
# Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
|
|
||||||
# This program 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 General Public License for more details.
|
|
||||||
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
if test $# -eq 0; then
|
|
||||||
echo 1>&2 "Try '$0 --help' for more information"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
case $1 in
|
|
||||||
|
|
||||||
--is-lightweight)
|
|
||||||
# Used by our autoconf macros to check whether the available missing
|
|
||||||
# script is modern enough.
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
|
|
||||||
--run)
|
|
||||||
# Back-compat with the calling convention used by older automake.
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
|
|
||||||
-h|--h|--he|--hel|--help)
|
|
||||||
echo "\
|
|
||||||
$0 [OPTION]... PROGRAM [ARGUMENT]...
|
|
||||||
|
|
||||||
Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due
|
|
||||||
to PROGRAM being missing or too old.
|
|
||||||
|
|
||||||
Options:
|
|
||||||
-h, --help display this help and exit
|
|
||||||
-v, --version output version information and exit
|
|
||||||
|
|
||||||
Supported PROGRAM values:
|
|
||||||
aclocal autoconf autoheader autom4te automake makeinfo
|
|
||||||
bison yacc flex lex help2man
|
|
||||||
|
|
||||||
Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and
|
|
||||||
'g' are ignored when checking the name.
|
|
||||||
|
|
||||||
Send bug reports to <bug-automake@gnu.org>."
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
|
|
||||||
-v|--v|--ve|--ver|--vers|--versi|--versio|--version)
|
|
||||||
echo "missing $scriptversion (GNU Automake)"
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
|
|
||||||
-*)
|
|
||||||
echo 1>&2 "$0: unknown '$1' option"
|
|
||||||
echo 1>&2 "Try '$0 --help' for more information"
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Run the given program, remember its exit status.
|
|
||||||
"$@"; st=$?
|
|
||||||
|
|
||||||
# If it succeeded, we are done.
|
|
||||||
test $st -eq 0 && exit 0
|
|
||||||
|
|
||||||
# Also exit now if we it failed (or wasn't found), and '--version' was
|
|
||||||
# passed; such an option is passed most likely to detect whether the
|
|
||||||
# program is present and works.
|
|
||||||
case $2 in --version|--help) exit $st;; esac
|
|
||||||
|
|
||||||
# Exit code 63 means version mismatch. This often happens when the user
|
|
||||||
# tries to use an ancient version of a tool on a file that requires a
|
|
||||||
# minimum version.
|
|
||||||
if test $st -eq 63; then
|
|
||||||
msg="probably too old"
|
|
||||||
elif test $st -eq 127; then
|
|
||||||
# Program was missing.
|
|
||||||
msg="missing on your system"
|
|
||||||
else
|
|
||||||
# Program was found and executed, but failed. Give up.
|
|
||||||
exit $st
|
|
||||||
fi
|
|
||||||
|
|
||||||
perl_URL=http://www.perl.org/
|
|
||||||
flex_URL=http://flex.sourceforge.net/
|
|
||||||
gnu_software_URL=http://www.gnu.org/software
|
|
||||||
|
|
||||||
program_details ()
|
|
||||||
{
|
|
||||||
case $1 in
|
|
||||||
aclocal|automake)
|
|
||||||
echo "The '$1' program is part of the GNU Automake package:"
|
|
||||||
echo "<$gnu_software_URL/automake>"
|
|
||||||
echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:"
|
|
||||||
echo "<$gnu_software_URL/autoconf>"
|
|
||||||
echo "<$gnu_software_URL/m4/>"
|
|
||||||
echo "<$perl_URL>"
|
|
||||||
;;
|
|
||||||
autoconf|autom4te|autoheader)
|
|
||||||
echo "The '$1' program is part of the GNU Autoconf package:"
|
|
||||||
echo "<$gnu_software_URL/autoconf/>"
|
|
||||||
echo "It also requires GNU m4 and Perl in order to run:"
|
|
||||||
echo "<$gnu_software_URL/m4/>"
|
|
||||||
echo "<$perl_URL>"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
give_advice ()
|
|
||||||
{
|
|
||||||
# Normalize program name to check for.
|
|
||||||
normalized_program=`echo "$1" | sed '
|
|
||||||
s/^gnu-//; t
|
|
||||||
s/^gnu//; t
|
|
||||||
s/^g//; t'`
|
|
||||||
|
|
||||||
printf '%s\n' "'$1' is $msg."
|
|
||||||
|
|
||||||
configure_deps="'configure.ac' or m4 files included by 'configure.ac'"
|
|
||||||
case $normalized_program in
|
|
||||||
autoconf*)
|
|
||||||
echo "You should only need it if you modified 'configure.ac',"
|
|
||||||
echo "or m4 files included by it."
|
|
||||||
program_details 'autoconf'
|
|
||||||
;;
|
|
||||||
autoheader*)
|
|
||||||
echo "You should only need it if you modified 'acconfig.h' or"
|
|
||||||
echo "$configure_deps."
|
|
||||||
program_details 'autoheader'
|
|
||||||
;;
|
|
||||||
automake*)
|
|
||||||
echo "You should only need it if you modified 'Makefile.am' or"
|
|
||||||
echo "$configure_deps."
|
|
||||||
program_details 'automake'
|
|
||||||
;;
|
|
||||||
aclocal*)
|
|
||||||
echo "You should only need it if you modified 'acinclude.m4' or"
|
|
||||||
echo "$configure_deps."
|
|
||||||
program_details 'aclocal'
|
|
||||||
;;
|
|
||||||
autom4te*)
|
|
||||||
echo "You might have modified some maintainer files that require"
|
|
||||||
echo "the 'autom4te' program to be rebuilt."
|
|
||||||
program_details 'autom4te'
|
|
||||||
;;
|
|
||||||
bison*|yacc*)
|
|
||||||
echo "You should only need it if you modified a '.y' file."
|
|
||||||
echo "You may want to install the GNU Bison package:"
|
|
||||||
echo "<$gnu_software_URL/bison/>"
|
|
||||||
;;
|
|
||||||
lex*|flex*)
|
|
||||||
echo "You should only need it if you modified a '.l' file."
|
|
||||||
echo "You may want to install the Fast Lexical Analyzer package:"
|
|
||||||
echo "<$flex_URL>"
|
|
||||||
;;
|
|
||||||
help2man*)
|
|
||||||
echo "You should only need it if you modified a dependency" \
|
|
||||||
"of a man page."
|
|
||||||
echo "You may want to install the GNU Help2man package:"
|
|
||||||
echo "<$gnu_software_URL/help2man/>"
|
|
||||||
;;
|
|
||||||
makeinfo*)
|
|
||||||
echo "You should only need it if you modified a '.texi' file, or"
|
|
||||||
echo "any other file indirectly affecting the aspect of the manual."
|
|
||||||
echo "You might want to install the Texinfo package:"
|
|
||||||
echo "<$gnu_software_URL/texinfo/>"
|
|
||||||
echo "The spurious makeinfo call might also be the consequence of"
|
|
||||||
echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might"
|
|
||||||
echo "want to install GNU make:"
|
|
||||||
echo "<$gnu_software_URL/make/>"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "You might have modified some files without having the proper"
|
|
||||||
echo "tools for further handling them. Check the 'README' file, it"
|
|
||||||
echo "often tells you about the needed prerequisites for installing"
|
|
||||||
echo "this package. You may also peek at any GNU archive site, in"
|
|
||||||
echo "case some other package contains this missing '$1' program."
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
give_advice "$1" | sed -e '1s/^/WARNING: /' \
|
|
||||||
-e '2,$s/^/ /' >&2
|
|
||||||
|
|
||||||
# Propagate the correct exit status (expected to be 127 for a program
|
|
||||||
# not found, 63 for a program that failed due to version mismatch).
|
|
||||||
exit $st
|
|
||||||
|
|
||||||
# Local variables:
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
|
@ -1,49 +0,0 @@
|
||||||
README for PABLIO
|
|
||||||
Portable Audio Blocking I/O Library
|
|
||||||
Author: Phil Burk
|
|
||||||
|
|
||||||
PABLIO is a simplified interface to PortAudio that provides
|
|
||||||
read/write style blocking I/O.
|
|
||||||
|
|
||||||
PABLIO is DEPRECATED. We recommend that people use the blocking I/O calls
|
|
||||||
that are now part of the PortAudio API. These are Pa_ReadStream() and
|
|
||||||
Pa_WriteStream().
|
|
||||||
|
|
||||||
http://portaudio.com/docs/v19-doxydocs/blocking_read_write.html
|
|
||||||
|
|
||||||
/*
|
|
||||||
* More information on PortAudio at: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
|
@ -1,314 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* pablio.c
|
|
||||||
* Portable Audio Blocking Input/Output utility.
|
|
||||||
*
|
|
||||||
* Author: Phil Burk, http://www.softsynth.com
|
|
||||||
*
|
|
||||||
* This program uses the PortAudio Portable Audio Library.
|
|
||||||
* For more information see: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <math.h>
|
|
||||||
#include "portaudio.h"
|
|
||||||
#include "pa_ringbuffer.h"
|
|
||||||
#include "pablio.h"
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
/************************************************************************/
|
|
||||||
/******** Constants *****************************************************/
|
|
||||||
/************************************************************************/
|
|
||||||
|
|
||||||
#define FRAMES_PER_BUFFER (256)
|
|
||||||
|
|
||||||
/************************************************************************/
|
|
||||||
/******** Prototypes ****************************************************/
|
|
||||||
/************************************************************************/
|
|
||||||
|
|
||||||
static int blockingIOCallback( void *inputBuffer, void *outputBuffer,
|
|
||||||
unsigned long framesPerBuffer,
|
|
||||||
PaTimestamp outTime, void *userData );
|
|
||||||
static PaError PABLIO_InitFIFO( RingBuffer *rbuf, long numFrames, long bytesPerFrame );
|
|
||||||
static PaError PABLIO_TermFIFO( RingBuffer *rbuf );
|
|
||||||
|
|
||||||
/************************************************************************/
|
|
||||||
/******** Functions *****************************************************/
|
|
||||||
/************************************************************************/
|
|
||||||
|
|
||||||
/* Called from PortAudio.
|
|
||||||
* Read and write data only if there is room in FIFOs.
|
|
||||||
*/
|
|
||||||
static int blockingIOCallback( void *inputBuffer, void *outputBuffer,
|
|
||||||
unsigned long framesPerBuffer,
|
|
||||||
PaTimestamp outTime, void *userData )
|
|
||||||
{
|
|
||||||
PABLIO_Stream *data = (PABLIO_Stream*)userData;
|
|
||||||
long numBytes = data->bytesPerFrame * framesPerBuffer;
|
|
||||||
(void) outTime;
|
|
||||||
|
|
||||||
/* This may get called with NULL inputBuffer during initial setup. */
|
|
||||||
if( inputBuffer != NULL )
|
|
||||||
{
|
|
||||||
PaUtil_WriteRingBuffer( &data->inFIFO, inputBuffer, numBytes );
|
|
||||||
}
|
|
||||||
if( outputBuffer != NULL )
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
int numRead = PaUtil_ReadRingBuffer( &data->outFIFO, outputBuffer, numBytes );
|
|
||||||
/* Zero out remainder of buffer if we run out of data. */
|
|
||||||
for( i=numRead; i<numBytes; i++ )
|
|
||||||
{
|
|
||||||
((char *)outputBuffer)[i] = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Allocate buffer. */
|
|
||||||
static PaError PABLIO_InitFIFO( RingBuffer *rbuf, long numFrames, long bytesPerFrame )
|
|
||||||
{
|
|
||||||
long numBytes = numFrames * bytesPerFrame;
|
|
||||||
char *buffer = (char *) malloc( numBytes );
|
|
||||||
if( buffer == NULL ) return paInsufficientMemory;
|
|
||||||
memset( buffer, 0, numBytes );
|
|
||||||
return (PaError) PaUtil_InitializeRingBuffer( rbuf, numBytes, buffer );
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Free buffer. */
|
|
||||||
static PaError PABLIO_TermFIFO( RingBuffer *rbuf )
|
|
||||||
{
|
|
||||||
if( rbuf->buffer ) free( rbuf->buffer );
|
|
||||||
rbuf->buffer = NULL;
|
|
||||||
return paNoError;
|
|
||||||
}
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Write data to ring buffer.
|
|
||||||
* Will not return until all the data has been written.
|
|
||||||
*/
|
|
||||||
long WriteAudioStream( PABLIO_Stream *aStream, void *data, long numFrames )
|
|
||||||
{
|
|
||||||
long bytesWritten;
|
|
||||||
char *p = (char *) data;
|
|
||||||
long numBytes = aStream->bytesPerFrame * numFrames;
|
|
||||||
while( numBytes > 0)
|
|
||||||
{
|
|
||||||
bytesWritten = PaUtil_WriteRingBuffer( &aStream->outFIFO, p, numBytes );
|
|
||||||
numBytes -= bytesWritten;
|
|
||||||
p += bytesWritten;
|
|
||||||
if( numBytes > 0) Pa_Sleep(10);
|
|
||||||
}
|
|
||||||
return numFrames;
|
|
||||||
}
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Read data from ring buffer.
|
|
||||||
* Will not return until all the data has been read.
|
|
||||||
*/
|
|
||||||
long ReadAudioStream( PABLIO_Stream *aStream, void *data, long numFrames )
|
|
||||||
{
|
|
||||||
long bytesRead;
|
|
||||||
char *p = (char *) data;
|
|
||||||
long numBytes = aStream->bytesPerFrame * numFrames;
|
|
||||||
while( numBytes > 0)
|
|
||||||
{
|
|
||||||
bytesRead = PaUtil_ReadRingBuffer( &aStream->inFIFO, p, numBytes );
|
|
||||||
numBytes -= bytesRead;
|
|
||||||
p += bytesRead;
|
|
||||||
if( numBytes > 0) Pa_Sleep(10);
|
|
||||||
}
|
|
||||||
return numFrames;
|
|
||||||
}
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Return the number of frames that could be written to the stream without
|
|
||||||
* having to wait.
|
|
||||||
*/
|
|
||||||
long GetAudioStreamWriteable( PABLIO_Stream *aStream )
|
|
||||||
{
|
|
||||||
int bytesEmpty = PaUtil_GetRingBufferWriteAvailable( &aStream->outFIFO );
|
|
||||||
return bytesEmpty / aStream->bytesPerFrame;
|
|
||||||
}
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Return the number of frames that are available to be read from the
|
|
||||||
* stream without having to wait.
|
|
||||||
*/
|
|
||||||
long GetAudioStreamReadable( PABLIO_Stream *aStream )
|
|
||||||
{
|
|
||||||
int bytesFull = PaUtil_GetRingBufferReadAvailable( &aStream->inFIFO );
|
|
||||||
return bytesFull / aStream->bytesPerFrame;
|
|
||||||
}
|
|
||||||
|
|
||||||
/************************************************************/
|
|
||||||
static unsigned long RoundUpToNextPowerOf2( unsigned long n )
|
|
||||||
{
|
|
||||||
long numBits = 0;
|
|
||||||
if( ((n-1) & n) == 0) return n; /* Already Power of two. */
|
|
||||||
while( n > 0 )
|
|
||||||
{
|
|
||||||
n= n>>1;
|
|
||||||
numBits++;
|
|
||||||
}
|
|
||||||
return (1<<numBits);
|
|
||||||
}
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Opens a PortAudio stream with default characteristics.
|
|
||||||
* Allocates PABLIO_Stream structure.
|
|
||||||
*
|
|
||||||
* flags parameter can be an ORed combination of:
|
|
||||||
* PABLIO_READ, PABLIO_WRITE, or PABLIO_READ_WRITE,
|
|
||||||
* and either PABLIO_MONO or PABLIO_STEREO
|
|
||||||
*/
|
|
||||||
PaError OpenAudioStream( PABLIO_Stream **rwblPtr, double sampleRate,
|
|
||||||
PaSampleFormat format, long flags )
|
|
||||||
{
|
|
||||||
long bytesPerSample;
|
|
||||||
long doRead = 0;
|
|
||||||
long doWrite = 0;
|
|
||||||
PaError err;
|
|
||||||
PABLIO_Stream *aStream;
|
|
||||||
long minNumBuffers;
|
|
||||||
long numFrames;
|
|
||||||
|
|
||||||
/* Allocate PABLIO_Stream structure for caller. */
|
|
||||||
aStream = (PABLIO_Stream *) malloc( sizeof(PABLIO_Stream) );
|
|
||||||
if( aStream == NULL ) return paInsufficientMemory;
|
|
||||||
memset( aStream, 0, sizeof(PABLIO_Stream) );
|
|
||||||
|
|
||||||
/* Determine size of a sample. */
|
|
||||||
bytesPerSample = Pa_GetSampleSize( format );
|
|
||||||
if( bytesPerSample < 0 )
|
|
||||||
{
|
|
||||||
err = (PaError) bytesPerSample;
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
aStream->samplesPerFrame = ((flags&PABLIO_MONO) != 0) ? 1 : 2;
|
|
||||||
aStream->bytesPerFrame = bytesPerSample * aStream->samplesPerFrame;
|
|
||||||
|
|
||||||
/* Initialize PortAudio */
|
|
||||||
err = Pa_Initialize();
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
/* Warning: numFrames must be larger than amount of data processed per interrupt
|
|
||||||
* inside PA to prevent glitches. Just to be safe, adjust size upwards.
|
|
||||||
*/
|
|
||||||
minNumBuffers = 2 * Pa_GetMinNumBuffers( FRAMES_PER_BUFFER, sampleRate );
|
|
||||||
numFrames = minNumBuffers * FRAMES_PER_BUFFER;
|
|
||||||
numFrames = RoundUpToNextPowerOf2( numFrames );
|
|
||||||
|
|
||||||
/* Initialize Ring Buffers */
|
|
||||||
doRead = ((flags & PABLIO_READ) != 0);
|
|
||||||
doWrite = ((flags & PABLIO_WRITE) != 0);
|
|
||||||
if(doRead)
|
|
||||||
{
|
|
||||||
err = PABLIO_InitFIFO( &aStream->inFIFO, numFrames, aStream->bytesPerFrame );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
}
|
|
||||||
if(doWrite)
|
|
||||||
{
|
|
||||||
long numBytes;
|
|
||||||
err = PABLIO_InitFIFO( &aStream->outFIFO, numFrames, aStream->bytesPerFrame );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
/* Make Write FIFO appear full initially. */
|
|
||||||
numBytes = PaUtil_GetRingBufferWriteAvailable( &aStream->outFIFO );
|
|
||||||
PaUtil_AdvanceRingBufferWriteIndex( &aStream->outFIFO, numBytes );
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Open a PortAudio stream that we will use to communicate with the underlying
|
|
||||||
* audio drivers. */
|
|
||||||
err = Pa_OpenStream(
|
|
||||||
&aStream->stream,
|
|
||||||
(doRead ? Pa_GetDefaultInputDeviceID() : paNoDevice),
|
|
||||||
(doRead ? aStream->samplesPerFrame : 0 ),
|
|
||||||
format,
|
|
||||||
NULL,
|
|
||||||
(doWrite ? Pa_GetDefaultOutputDeviceID() : paNoDevice),
|
|
||||||
(doWrite ? aStream->samplesPerFrame : 0 ),
|
|
||||||
format,
|
|
||||||
NULL,
|
|
||||||
sampleRate,
|
|
||||||
FRAMES_PER_BUFFER,
|
|
||||||
minNumBuffers,
|
|
||||||
paClipOff, /* we won't output out of range samples so don't bother clipping them */
|
|
||||||
blockingIOCallback,
|
|
||||||
aStream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
err = Pa_StartStream( aStream->stream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
*rwblPtr = aStream;
|
|
||||||
return paNoError;
|
|
||||||
|
|
||||||
error:
|
|
||||||
CloseAudioStream( aStream );
|
|
||||||
*rwblPtr = NULL;
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
/************************************************************/
|
|
||||||
PaError CloseAudioStream( PABLIO_Stream *aStream )
|
|
||||||
{
|
|
||||||
PaError err;
|
|
||||||
int bytesEmpty;
|
|
||||||
int byteSize = aStream->outFIFO.bufferSize;
|
|
||||||
|
|
||||||
/* If we are writing data, make sure we play everything written. */
|
|
||||||
if( byteSize > 0 )
|
|
||||||
{
|
|
||||||
bytesEmpty = PaUtil_GetRingBufferWriteAvailable( &aStream->outFIFO );
|
|
||||||
while( bytesEmpty < byteSize )
|
|
||||||
{
|
|
||||||
Pa_Sleep( 10 );
|
|
||||||
bytesEmpty = PaUtil_GetRingBufferWriteAvailable( &aStream->outFIFO );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
err = Pa_StopStream( aStream->stream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
err = Pa_CloseStream( aStream->stream );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
Pa_Terminate();
|
|
||||||
|
|
||||||
error:
|
|
||||||
PABLIO_TermFIFO( &aStream->inFIFO );
|
|
||||||
PABLIO_TermFIFO( &aStream->outFIFO );
|
|
||||||
free( aStream );
|
|
||||||
return err;
|
|
||||||
}
|
|
|
@ -1,35 +0,0 @@
|
||||||
LIBRARY PABLIO
|
|
||||||
DESCRIPTION 'PABLIO Portable Audio Blocking I/O'
|
|
||||||
|
|
||||||
EXPORTS
|
|
||||||
; Explicit exports can go here
|
|
||||||
Pa_Initialize @1
|
|
||||||
Pa_Terminate @2
|
|
||||||
Pa_GetHostError @3
|
|
||||||
Pa_GetErrorText @4
|
|
||||||
Pa_CountDevices @5
|
|
||||||
Pa_GetDefaultInputDeviceID @6
|
|
||||||
Pa_GetDefaultOutputDeviceID @7
|
|
||||||
Pa_GetDeviceInfo @8
|
|
||||||
Pa_OpenStream @9
|
|
||||||
Pa_OpenDefaultStream @10
|
|
||||||
Pa_CloseStream @11
|
|
||||||
Pa_StartStream @12
|
|
||||||
Pa_StopStream @13
|
|
||||||
Pa_StreamActive @14
|
|
||||||
Pa_StreamTime @15
|
|
||||||
Pa_GetCPULoad @16
|
|
||||||
Pa_GetMinNumBuffers @17
|
|
||||||
Pa_Sleep @18
|
|
||||||
|
|
||||||
OpenAudioStream @19
|
|
||||||
CloseAudioStream @20
|
|
||||||
WriteAudioStream @21
|
|
||||||
ReadAudioStream @22
|
|
||||||
|
|
||||||
Pa_GetSampleSize @23
|
|
||||||
|
|
||||||
;123456789012345678901234567890123456
|
|
||||||
;000000000111111111122222222223333333
|
|
||||||
|
|
||||||
|
|
|
@ -1,116 +0,0 @@
|
||||||
#ifndef _PABLIO_H
|
|
||||||
#define _PABLIO_H
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* PABLIO.h
|
|
||||||
* Portable Audio Blocking read/write utility.
|
|
||||||
*
|
|
||||||
* Author: Phil Burk, http://www.softsynth.com/portaudio/
|
|
||||||
*
|
|
||||||
* Include file for PABLIO, the Portable Audio Blocking I/O Library.
|
|
||||||
* PABLIO is built on top of PortAudio, the Portable Audio Library.
|
|
||||||
* For more information see: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <math.h>
|
|
||||||
#include "portaudio.h"
|
|
||||||
#include "pa_ringbuffer.h"
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
RingBuffer inFIFO;
|
|
||||||
RingBuffer outFIFO;
|
|
||||||
PortAudioStream *stream;
|
|
||||||
int bytesPerFrame;
|
|
||||||
int samplesPerFrame;
|
|
||||||
}
|
|
||||||
PABLIO_Stream;
|
|
||||||
|
|
||||||
/* Values for flags for OpenAudioStream(). */
|
|
||||||
#define PABLIO_READ (1<<0)
|
|
||||||
#define PABLIO_WRITE (1<<1)
|
|
||||||
#define PABLIO_READ_WRITE (PABLIO_READ|PABLIO_WRITE)
|
|
||||||
#define PABLIO_MONO (1<<2)
|
|
||||||
#define PABLIO_STEREO (1<<3)
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Write data to ring buffer.
|
|
||||||
* Will not return until all the data has been written.
|
|
||||||
*/
|
|
||||||
long WriteAudioStream( PABLIO_Stream *aStream, void *data, long numFrames );
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Read data from ring buffer.
|
|
||||||
* Will not return until all the data has been read.
|
|
||||||
*/
|
|
||||||
long ReadAudioStream( PABLIO_Stream *aStream, void *data, long numFrames );
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Return the number of frames that could be written to the stream without
|
|
||||||
* having to wait.
|
|
||||||
*/
|
|
||||||
long GetAudioStreamWriteable( PABLIO_Stream *aStream );
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Return the number of frames that are available to be read from the
|
|
||||||
* stream without having to wait.
|
|
||||||
*/
|
|
||||||
long GetAudioStreamReadable( PABLIO_Stream *aStream );
|
|
||||||
|
|
||||||
/************************************************************
|
|
||||||
* Opens a PortAudio stream with default characteristics.
|
|
||||||
* Allocates PABLIO_Stream structure.
|
|
||||||
*
|
|
||||||
* flags parameter can be an ORed combination of:
|
|
||||||
* PABLIO_READ, PABLIO_WRITE, or PABLIO_READ_WRITE,
|
|
||||||
* and either PABLIO_MONO or PABLIO_STEREO
|
|
||||||
*/
|
|
||||||
PaError OpenAudioStream( PABLIO_Stream **aStreamPtr, double sampleRate,
|
|
||||||
PaSampleFormat format, long flags );
|
|
||||||
|
|
||||||
PaError CloseAudioStream( PABLIO_Stream *aStream );
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* _PABLIO_H */
|
|
|
@ -1,105 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* test_rw.c
|
|
||||||
* Read input from one stream and write it to another.
|
|
||||||
*
|
|
||||||
* Author: Phil Burk, http://www.softsynth.com/portaudio/
|
|
||||||
*
|
|
||||||
* This program uses PABLIO, the Portable Audio Blocking I/O Library.
|
|
||||||
* PABLIO is built on top of PortAudio, the Portable Audio Library.
|
|
||||||
* For more information see: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include "pablio.h"
|
|
||||||
|
|
||||||
/*
|
|
||||||
** Note that many of the older ISA sound cards on PCs do NOT support
|
|
||||||
** full duplex audio (simultaneous record and playback).
|
|
||||||
** And some only support full duplex at lower sample rates.
|
|
||||||
*/
|
|
||||||
#define SAMPLE_RATE (44100)
|
|
||||||
#define NUM_SECONDS (5)
|
|
||||||
#define SAMPLES_PER_FRAME (2)
|
|
||||||
#define FRAMES_PER_BLOCK (64)
|
|
||||||
|
|
||||||
/* Select whether we will use floats or shorts. */
|
|
||||||
#if 1
|
|
||||||
#define SAMPLE_TYPE paFloat32
|
|
||||||
typedef float SAMPLE;
|
|
||||||
#else
|
|
||||||
#define SAMPLE_TYPE paInt16
|
|
||||||
typedef short SAMPLE;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*******************************************************************/
|
|
||||||
int main(void);
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SAMPLE samples[SAMPLES_PER_FRAME * FRAMES_PER_BLOCK];
|
|
||||||
PaError err;
|
|
||||||
PABLIO_Stream *aStream;
|
|
||||||
|
|
||||||
printf("Full duplex sound test using PortAudio and RingBuffers\n");
|
|
||||||
fflush(stdout);
|
|
||||||
|
|
||||||
/* Open simplified blocking I/O layer on top of PortAudio. */
|
|
||||||
err = OpenAudioStream( &aStream, SAMPLE_RATE, SAMPLE_TYPE,
|
|
||||||
(PABLIO_READ_WRITE | PABLIO_STEREO) );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
/* Process samples in the foreground. */
|
|
||||||
for( i=0; i<(NUM_SECONDS * SAMPLE_RATE); i += FRAMES_PER_BLOCK )
|
|
||||||
{
|
|
||||||
/* Read one block of data into sample array from audio input. */
|
|
||||||
ReadAudioStream( aStream, samples, FRAMES_PER_BLOCK );
|
|
||||||
/* Write that same block of data to output. */
|
|
||||||
WriteAudioStream( aStream, samples, FRAMES_PER_BLOCK );
|
|
||||||
}
|
|
||||||
|
|
||||||
CloseAudioStream( aStream );
|
|
||||||
|
|
||||||
printf("Full duplex sound test complete.\n" );
|
|
||||||
fflush(stdout);
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
error:
|
|
||||||
Pa_Terminate();
|
|
||||||
fprintf( stderr, "An error occurred while using the portaudio stream\n" );
|
|
||||||
fprintf( stderr, "Error number: %d\n", err );
|
|
||||||
fprintf( stderr, "Error message: %s\n", Pa_GetErrorText( err ) );
|
|
||||||
return -1;
|
|
||||||
}
|
|
|
@ -1,129 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* test_rw_echo.c
|
|
||||||
* Echo delayed input to output.
|
|
||||||
*
|
|
||||||
* Author: Phil Burk, http://www.softsynth.com/portaudio/
|
|
||||||
*
|
|
||||||
* This program uses PABLIO, the Portable Audio Blocking I/O Library.
|
|
||||||
* PABLIO is built on top of PortAudio, the Portable Audio Library.
|
|
||||||
*
|
|
||||||
* Note that if you need low latency, you should not use PABLIO.
|
|
||||||
* Use the PA_OpenStream callback technique which is lower level
|
|
||||||
* than PABLIO.
|
|
||||||
*
|
|
||||||
* For more information see: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <math.h>
|
|
||||||
#include "pablio.h"
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
** Note that many of the older ISA sound cards on PCs do NOT support
|
|
||||||
** full duplex audio (simultaneous record and playback).
|
|
||||||
** And some only support full duplex at lower sample rates.
|
|
||||||
*/
|
|
||||||
#define SAMPLE_RATE (22050)
|
|
||||||
#define NUM_SECONDS (20)
|
|
||||||
#define SAMPLES_PER_FRAME (2)
|
|
||||||
|
|
||||||
/* Select whether we will use floats or shorts. */
|
|
||||||
#if 1
|
|
||||||
#define SAMPLE_TYPE paFloat32
|
|
||||||
typedef float SAMPLE;
|
|
||||||
#else
|
|
||||||
#define SAMPLE_TYPE paInt16
|
|
||||||
typedef short SAMPLE;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define NUM_ECHO_FRAMES (2*SAMPLE_RATE)
|
|
||||||
SAMPLE samples[NUM_ECHO_FRAMES][SAMPLES_PER_FRAME] = {0.0};
|
|
||||||
|
|
||||||
/*******************************************************************/
|
|
||||||
int main(void);
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
PaError err;
|
|
||||||
PABLIO_Stream *aInStream;
|
|
||||||
PABLIO_Stream *aOutStream;
|
|
||||||
int index;
|
|
||||||
|
|
||||||
printf("Full duplex sound test using PABLIO\n");
|
|
||||||
fflush(stdout);
|
|
||||||
|
|
||||||
/* Open simplified blocking I/O layer on top of PortAudio. */
|
|
||||||
/* Open input first so it can start to fill buffers. */
|
|
||||||
err = OpenAudioStream( &aInStream, SAMPLE_RATE, SAMPLE_TYPE,
|
|
||||||
(PABLIO_READ | PABLIO_STEREO) );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
/* printf("opened input\n"); fflush(stdout); /**/
|
|
||||||
|
|
||||||
err = OpenAudioStream( &aOutStream, SAMPLE_RATE, SAMPLE_TYPE,
|
|
||||||
(PABLIO_WRITE | PABLIO_STEREO) );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
/* printf("opened output\n"); fflush(stdout); /**/
|
|
||||||
|
|
||||||
/* Process samples in the foreground. */
|
|
||||||
index = 0;
|
|
||||||
for( i=0; i<(NUM_SECONDS * SAMPLE_RATE); i++ )
|
|
||||||
{
|
|
||||||
/* Write old frame of data to output. */
|
|
||||||
/* samples[index][1] = (i&256) * (1.0f/256.0f); /* sawtooth */
|
|
||||||
WriteAudioStream( aOutStream, &samples[index][0], 1 );
|
|
||||||
|
|
||||||
/* Read one frame of data into sample array for later output. */
|
|
||||||
ReadAudioStream( aInStream, &samples[index][0], 1 );
|
|
||||||
index += 1;
|
|
||||||
if( index >= NUM_ECHO_FRAMES ) index = 0;
|
|
||||||
|
|
||||||
if( (i & 0xFFFF) == 0 ) printf("i = %d\n", i ); fflush(stdout); /**/
|
|
||||||
}
|
|
||||||
|
|
||||||
CloseAudioStream( aOutStream );
|
|
||||||
CloseAudioStream( aInStream );
|
|
||||||
|
|
||||||
printf("R/W echo sound test complete.\n" );
|
|
||||||
fflush(stdout);
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
error:
|
|
||||||
fprintf( stderr, "An error occurred while using PortAudio\n" );
|
|
||||||
fprintf( stderr, "Error number: %d\n", err );
|
|
||||||
fprintf( stderr, "Error message: %s\n", Pa_GetErrorText( err ) );
|
|
||||||
return -1;
|
|
||||||
}
|
|
|
@ -1,114 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* test_w_saw.c
|
|
||||||
* Generate stereo sawtooth waveforms.
|
|
||||||
*
|
|
||||||
* Author: Phil Burk, http://www.softsynth.com
|
|
||||||
*
|
|
||||||
* This program uses PABLIO, the Portable Audio Blocking I/O Library.
|
|
||||||
* PABLIO is built on top of PortAudio, the Portable Audio Library.
|
|
||||||
*
|
|
||||||
* For more information see: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <math.h>
|
|
||||||
#include "pablio.h"
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#define SAMPLE_RATE (44100)
|
|
||||||
#define NUM_SECONDS (6)
|
|
||||||
#define SAMPLES_PER_FRAME (2)
|
|
||||||
|
|
||||||
#define FREQUENCY (220.0f)
|
|
||||||
#define PHASE_INCREMENT (2.0f * FREQUENCY / SAMPLE_RATE)
|
|
||||||
#define FRAMES_PER_BLOCK (100)
|
|
||||||
|
|
||||||
float samples[FRAMES_PER_BLOCK][SAMPLES_PER_FRAME];
|
|
||||||
float phases[SAMPLES_PER_FRAME];
|
|
||||||
|
|
||||||
/*******************************************************************/
|
|
||||||
int main(void);
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
int i,j;
|
|
||||||
PaError err;
|
|
||||||
PABLIO_Stream *aOutStream;
|
|
||||||
|
|
||||||
printf("Generate sawtooth waves using PABLIO.\n");
|
|
||||||
fflush(stdout);
|
|
||||||
|
|
||||||
/* Open simplified blocking I/O layer on top of PortAudio. */
|
|
||||||
err = OpenAudioStream( &aOutStream, SAMPLE_RATE, paFloat32,
|
|
||||||
(PABLIO_WRITE | PABLIO_STEREO) );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
/* Initialize oscillator phases. */
|
|
||||||
phases[0] = 0.0;
|
|
||||||
phases[1] = 0.0;
|
|
||||||
|
|
||||||
for( i=0; i<(NUM_SECONDS * SAMPLE_RATE); i += FRAMES_PER_BLOCK )
|
|
||||||
{
|
|
||||||
/* Generate sawtooth waveforms in a block for efficiency. */
|
|
||||||
for( j=0; j<FRAMES_PER_BLOCK; j++ )
|
|
||||||
{
|
|
||||||
/* Generate a sawtooth wave by incrementing a variable. */
|
|
||||||
phases[0] += PHASE_INCREMENT;
|
|
||||||
/* The signal range is -1.0 to +1.0 so wrap around if we go over. */
|
|
||||||
if( phases[0] > 1.0f ) phases[0] -= 2.0f;
|
|
||||||
samples[j][0] = phases[0];
|
|
||||||
|
|
||||||
/* On the second channel, generate a sawtooth wave a fifth higher. */
|
|
||||||
phases[1] += PHASE_INCREMENT * (3.0f / 2.0f);
|
|
||||||
if( phases[1] > 1.0f ) phases[1] -= 2.0f;
|
|
||||||
samples[j][1] = phases[1];
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Write samples to output. */
|
|
||||||
WriteAudioStream( aOutStream, samples, FRAMES_PER_BLOCK );
|
|
||||||
}
|
|
||||||
|
|
||||||
CloseAudioStream( aOutStream );
|
|
||||||
|
|
||||||
printf("Sawtooth sound test complete.\n" );
|
|
||||||
fflush(stdout);
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
error:
|
|
||||||
fprintf( stderr, "An error occurred while using PABLIO\n" );
|
|
||||||
fprintf( stderr, "Error number: %d\n", err );
|
|
||||||
fprintf( stderr, "Error message: %s\n", Pa_GetErrorText( err ) );
|
|
||||||
return -1;
|
|
||||||
}
|
|
|
@ -1,112 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* test_w_saw8.c
|
|
||||||
* Generate stereo 8 bit sawtooth waveforms.
|
|
||||||
*
|
|
||||||
* Author: Phil Burk, http://www.softsynth.com
|
|
||||||
*
|
|
||||||
* This program uses PABLIO, the Portable Audio Blocking I/O Library.
|
|
||||||
* PABLIO is built on top of PortAudio, the Portable Audio Library.
|
|
||||||
*
|
|
||||||
* For more information see: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <math.h>
|
|
||||||
#include "pablio.h"
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#define SAMPLE_RATE (22050)
|
|
||||||
#define NUM_SECONDS (6)
|
|
||||||
#define SAMPLES_PER_FRAME (2)
|
|
||||||
|
|
||||||
|
|
||||||
#define FRAMES_PER_BLOCK (100)
|
|
||||||
|
|
||||||
unsigned char samples[FRAMES_PER_BLOCK][SAMPLES_PER_FRAME];
|
|
||||||
unsigned char phases[SAMPLES_PER_FRAME];
|
|
||||||
|
|
||||||
/*******************************************************************/
|
|
||||||
int main(void);
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
int i,j;
|
|
||||||
PaError err;
|
|
||||||
PABLIO_Stream *aOutStream;
|
|
||||||
|
|
||||||
printf("Generate unsigned 8 bit sawtooth waves using PABLIO.\n");
|
|
||||||
fflush(stdout);
|
|
||||||
|
|
||||||
/* Open simplified blocking I/O layer on top of PortAudio. */
|
|
||||||
err = OpenAudioStream( &aOutStream, SAMPLE_RATE, paUInt8,
|
|
||||||
(PABLIO_WRITE | PABLIO_STEREO) );
|
|
||||||
if( err != paNoError ) goto error;
|
|
||||||
|
|
||||||
/* Initialize oscillator phases to "ground" level for paUInt8. */
|
|
||||||
phases[0] = 128;
|
|
||||||
phases[1] = 128;
|
|
||||||
|
|
||||||
for( i=0; i<(NUM_SECONDS * SAMPLE_RATE); i += FRAMES_PER_BLOCK )
|
|
||||||
{
|
|
||||||
/* Generate sawtooth waveforms in a block for efficiency. */
|
|
||||||
for( j=0; j<FRAMES_PER_BLOCK; j++ )
|
|
||||||
{
|
|
||||||
/* Generate a sawtooth wave by incrementing a variable. */
|
|
||||||
phases[0] += 1;
|
|
||||||
/* We don't have to do anything special to wrap when using paUint8 because
|
|
||||||
* 8 bit arithmetic automatically wraps. */
|
|
||||||
samples[j][0] = phases[0];
|
|
||||||
|
|
||||||
/* On the second channel, generate a higher sawtooth wave. */
|
|
||||||
phases[1] += 3;
|
|
||||||
samples[j][1] = phases[1];
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Write samples to output. */
|
|
||||||
WriteAudioStream( aOutStream, samples, FRAMES_PER_BLOCK );
|
|
||||||
}
|
|
||||||
|
|
||||||
CloseAudioStream( aOutStream );
|
|
||||||
|
|
||||||
printf("Sawtooth sound test complete.\n" );
|
|
||||||
fflush(stdout);
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
error:
|
|
||||||
fprintf( stderr, "An error occurred while using PABLIO\n" );
|
|
||||||
fprintf( stderr, "Error number: %d\n", err );
|
|
||||||
fprintf( stderr, "Error message: %s\n", Pa_GetErrorText( err ) );
|
|
||||||
return -1;
|
|
||||||
}
|
|
|
@ -1,12 +0,0 @@
|
||||||
prefix=@prefix@
|
|
||||||
exec_prefix=@exec_prefix@
|
|
||||||
libdir=@libdir@
|
|
||||||
includedir=@includedir@
|
|
||||||
|
|
||||||
Name: PortAudio
|
|
||||||
Description: Portable audio I/O
|
|
||||||
Requires:
|
|
||||||
Version: 19
|
|
||||||
|
|
||||||
Libs: -L${libdir} -lportaudio @LIBS@
|
|
||||||
Cflags: -I${includedir} @THREAD_CFLAGS@
|
|
|
@ -1,220 +0,0 @@
|
||||||
import os.path, copy, sys
|
|
||||||
|
|
||||||
def checkSymbol(conf, header, library=None, symbol=None, autoAdd=True, critical=False, pkgName=None):
|
|
||||||
""" Check for symbol in library, optionally look only for header.
|
|
||||||
@param conf: Configure instance.
|
|
||||||
@param header: The header file where the symbol is declared.
|
|
||||||
@param library: The library in which the symbol exists, if None it is taken to be the standard C library.
|
|
||||||
@param symbol: The symbol to look for, if None only the header will be looked up.
|
|
||||||
@param autoAdd: Automatically link with this library if check is positive.
|
|
||||||
@param critical: Raise on error?
|
|
||||||
@param pkgName: Optional name of pkg-config entry for library, to determine build parameters.
|
|
||||||
@return: True/False
|
|
||||||
"""
|
|
||||||
origEnv = conf.env.Copy() # Copy unmodified environment so we can restore it upon error
|
|
||||||
env = conf.env
|
|
||||||
if library is None:
|
|
||||||
library = "c" # Standard library
|
|
||||||
autoAdd = False
|
|
||||||
|
|
||||||
if pkgName is not None:
|
|
||||||
origLibs = copy.copy(env.get("LIBS", None))
|
|
||||||
|
|
||||||
try: env.ParseConfig("pkg-config --silence-errors %s --cflags --libs" % pkgName)
|
|
||||||
except: pass
|
|
||||||
else:
|
|
||||||
# I see no other way of checking that the parsing succeeded, if it did add no more linking parameters
|
|
||||||
if env.get("LIBS", None) != origLibs:
|
|
||||||
autoAdd = False
|
|
||||||
|
|
||||||
try:
|
|
||||||
if not conf.CheckCHeader(header, include_quotes="<>"):
|
|
||||||
raise ConfigurationError("missing header %s" % header)
|
|
||||||
if symbol is not None and not conf.CheckLib(library, symbol, language="C", autoadd=autoAdd):
|
|
||||||
raise ConfigurationError("missing symbol %s in library %s" % (symbol, library))
|
|
||||||
except ConfigurationError:
|
|
||||||
conf.env = origEnv
|
|
||||||
if not critical:
|
|
||||||
return False
|
|
||||||
raise
|
|
||||||
|
|
||||||
return True
|
|
||||||
|
|
||||||
import SCons.Errors
|
|
||||||
|
|
||||||
# Import common variables
|
|
||||||
|
|
||||||
# Could use '#' to refer to top-level SConstruct directory, but looks like env.SConsignFile doesn't interpret this at least :(
|
|
||||||
sconsDir = os.path.abspath(os.path.join("build", "scons"))
|
|
||||||
|
|
||||||
try:
|
|
||||||
Import("Platform", "Posix", "ConfigurationError", "ApiVer")
|
|
||||||
except SCons.Errors.UserError:
|
|
||||||
# The common objects must be exported first
|
|
||||||
SConscript(os.path.join(sconsDir, "SConscript_common"))
|
|
||||||
Import("Platform", "Posix", "ConfigurationError", "ApiVer")
|
|
||||||
|
|
||||||
Import("env")
|
|
||||||
|
|
||||||
# This will be manipulated
|
|
||||||
env = env.Copy()
|
|
||||||
|
|
||||||
# We operate with a set of needed libraries and optional libraries, the latter stemming from host API implementations.
|
|
||||||
# For libraries of both types we record a set of values that is used to look for the library in question, during
|
|
||||||
# configuration. If the corresponding library for a host API implementation isn't found, the implementation is left out.
|
|
||||||
neededLibs = []
|
|
||||||
optionalImpls = {}
|
|
||||||
if Platform in Posix:
|
|
||||||
env.Append(CPPPATH=os.path.join("os", "unix"))
|
|
||||||
neededLibs += [("pthread", "pthread.h", "pthread_create"), ("m", "math.h", "sin")]
|
|
||||||
if env["useALSA"]:
|
|
||||||
optionalImpls["ALSA"] = ("asound", "alsa/asoundlib.h", "snd_pcm_open")
|
|
||||||
if env["useJACK"]:
|
|
||||||
optionalImpls["JACK"] = ("jack", "jack/jack.h", "jack_client_new")
|
|
||||||
if env["useOSS"]:
|
|
||||||
# TODO: It looks like the prefix for soundcard.h depends on the platform
|
|
||||||
optionalImpls["OSS"] = ("oss", "sys/soundcard.h", None)
|
|
||||||
if Platform == 'netbsd':
|
|
||||||
optionalImpls["OSS"] = ("ossaudio", "sys/soundcard.h", "_oss_ioctl")
|
|
||||||
if env["useASIHPI"]:
|
|
||||||
optionalImpls["ASIHPI"] = ("hpi", "asihpi/hpi.h", "HPI_SubSysCreate")
|
|
||||||
if env["useCOREAUDIO"]:
|
|
||||||
optionalImpls["COREAUDIO"] = ("CoreAudio", "CoreAudio/CoreAudio.h", None)
|
|
||||||
else:
|
|
||||||
raise ConfigurationError("unknown platform %s" % Platform)
|
|
||||||
|
|
||||||
if Platform == "darwin":
|
|
||||||
env.Append(LINKFLAGS="-framework CoreFoundation -framework CoreServices -framework CoreAudio -framework AudioToolBox -framework AudioUnit")
|
|
||||||
elif Platform == "cygwin":
|
|
||||||
env.Append(LIBS=["winmm"])
|
|
||||||
elif Platform == "irix":
|
|
||||||
neededLibs += [("audio", "dmedia/audio.h", "alOpenPort"), ("dmedia", "dmedia/dmedia.h", "dmGetUST")]
|
|
||||||
env.Append(CPPDEFINES=["PA_USE_SGI"])
|
|
||||||
|
|
||||||
def CheckCTypeSize(context, tp):
|
|
||||||
""" Check size of C type.
|
|
||||||
@param context: A configuration context.
|
|
||||||
@param tp: The type to check.
|
|
||||||
@return: Size of type, in bytes.
|
|
||||||
"""
|
|
||||||
context.Message("Checking the size of C type %s..." % tp)
|
|
||||||
ret = context.TryRun("""
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
int main() {
|
|
||||||
printf("%%d", sizeof(%s));
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
""" % tp, ".c")
|
|
||||||
if not ret[0]:
|
|
||||||
context.Result(" Couldn't obtain size of type %s!" % tp)
|
|
||||||
return None
|
|
||||||
|
|
||||||
assert ret[1]
|
|
||||||
sz = int(ret[1])
|
|
||||||
context.Result("%d" % sz)
|
|
||||||
return sz
|
|
||||||
|
|
||||||
"""
|
|
||||||
if sys.byteorder == "little":
|
|
||||||
env.Append(CPPDEFINES=["PA_LITTLE_ENDIAN"])
|
|
||||||
elif sys.byteorder == "big":
|
|
||||||
env.Append(CPPDEFINES=["PA_BIG_ENDIAN"])
|
|
||||||
else:
|
|
||||||
raise ConfigurationError("unknown byte order: %s" % sys.byteorder)
|
|
||||||
"""
|
|
||||||
if env["enableDebugOutput"]:
|
|
||||||
env.Append(CPPDEFINES=["PA_ENABLE_DEBUG_OUTPUT"])
|
|
||||||
|
|
||||||
# Start configuration
|
|
||||||
|
|
||||||
# Use an absolute path for conf_dir, otherwise it gets created both relative to current directory and build directory
|
|
||||||
conf = env.Configure(log_file=os.path.join(sconsDir, "sconf.log"), custom_tests={"CheckCTypeSize": CheckCTypeSize},
|
|
||||||
conf_dir=os.path.join(sconsDir, ".sconf_temp"))
|
|
||||||
conf.env.Append(CPPDEFINES=["SIZEOF_SHORT=%d" % conf.CheckCTypeSize("short")])
|
|
||||||
conf.env.Append(CPPDEFINES=["SIZEOF_INT=%d" % conf.CheckCTypeSize("int")])
|
|
||||||
conf.env.Append(CPPDEFINES=["SIZEOF_LONG=%d" % conf.CheckCTypeSize("long")])
|
|
||||||
if checkSymbol(conf, "time.h", "rt", "clock_gettime"):
|
|
||||||
conf.env.Append(CPPDEFINES=["HAVE_CLOCK_GETTIME"])
|
|
||||||
if checkSymbol(conf, "time.h", symbol="nanosleep"):
|
|
||||||
conf.env.Append(CPPDEFINES=["HAVE_NANOSLEEP"])
|
|
||||||
if conf.CheckCHeader("sys/soundcard.h"):
|
|
||||||
conf.env.Append(CPPDEFINES=["HAVE_SYS_SOUNDCARD_H"])
|
|
||||||
if conf.CheckCHeader("linux/soundcard.h"):
|
|
||||||
conf.env.Append(CPPDEFINES=["HAVE_LINUX_SOUNDCARD_H"])
|
|
||||||
if conf.CheckCHeader("machine/soundcard.h"):
|
|
||||||
conf.env.Append(CPPDEFINES=["HAVE_MACHINE_SOUNDCARD_H"])
|
|
||||||
|
|
||||||
# Look for needed libraries and link with them
|
|
||||||
for lib, hdr, sym in neededLibs:
|
|
||||||
checkSymbol(conf, hdr, lib, sym, critical=True)
|
|
||||||
# Look for host API libraries, if a library isn't found disable corresponding host API implementation.
|
|
||||||
for name, val in optionalImpls.items():
|
|
||||||
lib, hdr, sym = val
|
|
||||||
if checkSymbol(conf, hdr, lib, sym, critical=False, pkgName=name.lower()):
|
|
||||||
conf.env.Append(CPPDEFINES=["PA_USE_%s=1" % name.upper()])
|
|
||||||
else:
|
|
||||||
del optionalImpls[name]
|
|
||||||
|
|
||||||
# Configuration finished
|
|
||||||
env = conf.Finish()
|
|
||||||
|
|
||||||
# PA infrastructure
|
|
||||||
CommonSources = [os.path.join("common", f) for f in "pa_allocation.c pa_converters.c pa_cpuload.c pa_dither.c pa_front.c \
|
|
||||||
pa_process.c pa_stream.c pa_trace.c pa_debugprint.c pa_ringbuffer.c".split()]
|
|
||||||
CommonSources.append(os.path.join("hostapi", "skeleton", "pa_hostapi_skeleton.c"))
|
|
||||||
|
|
||||||
# Host APIs implementations
|
|
||||||
ImplSources = []
|
|
||||||
if Platform in Posix:
|
|
||||||
ImplSources += [os.path.join("os", "unix", f) for f in "pa_unix_hostapis.c pa_unix_util.c".split()]
|
|
||||||
|
|
||||||
if "ALSA" in optionalImpls:
|
|
||||||
ImplSources.append(os.path.join("hostapi", "alsa", "pa_linux_alsa.c"))
|
|
||||||
if "JACK" in optionalImpls:
|
|
||||||
ImplSources.append(os.path.join("hostapi", "jack", "pa_jack.c"))
|
|
||||||
if "OSS" in optionalImpls:
|
|
||||||
ImplSources.append(os.path.join("hostapi", "oss", "pa_unix_oss.c"))
|
|
||||||
if "ASIHPI" in optionalImpls:
|
|
||||||
ImplSources.append(os.path.join("hostapi", "asihpi", "pa_linux_asihpi.c"))
|
|
||||||
if "COREAUDIO" in optionalImpls:
|
|
||||||
ImplSources.append([os.path.join("hostapi", "coreaudio", f) for f in """
|
|
||||||
pa_mac_core.c pa_mac_core_blocking.c pa_mac_core_utilities.c
|
|
||||||
""".split()])
|
|
||||||
|
|
||||||
|
|
||||||
sources = CommonSources + ImplSources
|
|
||||||
|
|
||||||
sharedLibEnv = env.Copy()
|
|
||||||
if Platform in Posix:
|
|
||||||
# Add soname to library, this is so a reference is made to the versioned library in programs linking against libportaudio.so
|
|
||||||
if Platform != 'darwin':
|
|
||||||
sharedLibEnv.AppendUnique(SHLINKFLAGS="-Wl,-soname=libportaudio.so.%d" % int(ApiVer.split(".")[0]))
|
|
||||||
sharedLib = sharedLibEnv.SharedLibrary(target="portaudio", source=sources)
|
|
||||||
|
|
||||||
staticLib = env.StaticLibrary(target="portaudio", source=sources)
|
|
||||||
|
|
||||||
if Platform in Posix:
|
|
||||||
prefix = env["prefix"]
|
|
||||||
includeDir = os.path.join(prefix, "include")
|
|
||||||
libDir = os.path.join(prefix, "lib")
|
|
||||||
|
|
||||||
testNames = ["patest_sine", "paqa_devs", "paqa_errs", "patest1", "patest_buffer", "patest_callbackstop", "patest_clip", \
|
|
||||||
"patest_dither", "patest_hang", "patest_in_overflow", "patest_latency", "patest_leftright", "patest_longsine", \
|
|
||||||
"patest_many", "patest_maxsines", "patest_multi_sine", "patest_out_underflow", "patest_pink", "patest_prime", \
|
|
||||||
"patest_read_record", "patest_record", "patest_ringmix", "patest_saw", "patest_sine8", "patest_sine", \
|
|
||||||
"patest_sine_time", "patest_start_stop", "patest_stop", "patest_sync", "patest_toomanysines", \
|
|
||||||
"patest_underflow", "patest_wire", "patest_write_sine", "pa_devs", "pa_fuzz", "pa_minlat", \
|
|
||||||
"patest_sine_channelmaps",]
|
|
||||||
|
|
||||||
# The test directory ("bin") should be in the top-level PA directory
|
|
||||||
tests = [env.Program(target=os.path.join("#", "bin", name), source=[os.path.join("#", "test", name + ".c"),
|
|
||||||
staticLib]) for name in testNames]
|
|
||||||
|
|
||||||
# Detect host APIs
|
|
||||||
hostApis = []
|
|
||||||
for cppdef in env["CPPDEFINES"]:
|
|
||||||
if cppdef.startswith("PA_USE_"):
|
|
||||||
hostApis.append(cppdef[7:-2])
|
|
||||||
|
|
||||||
Return("sources", "sharedLib", "staticLib", "tests", "env", "hostApis")
|
|
|
@ -1,243 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library allocation group implementation
|
|
||||||
* memory allocation group for tracking allocation groups
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2002 Ross Bencina, Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Allocation Group implementation.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "pa_allocation.h"
|
|
||||||
#include "pa_util.h"
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
Maintain 3 singly linked lists...
|
|
||||||
linkBlocks: the buffers used to allocate the links
|
|
||||||
spareLinks: links available for use in the allocations list
|
|
||||||
allocations: the buffers currently allocated using PaUtil_ContextAllocateMemory()
|
|
||||||
|
|
||||||
Link block size is doubled every time new links are allocated.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#define PA_INITIAL_LINK_COUNT_ 16
|
|
||||||
|
|
||||||
struct PaUtilAllocationGroupLink
|
|
||||||
{
|
|
||||||
struct PaUtilAllocationGroupLink *next;
|
|
||||||
void *buffer;
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
Allocate a block of links. The first link will have it's buffer member
|
|
||||||
pointing to the block, and it's next member set to <nextBlock>. The remaining
|
|
||||||
links will have NULL buffer members, and each link will point to
|
|
||||||
the next link except the last, which will point to <nextSpare>
|
|
||||||
*/
|
|
||||||
static struct PaUtilAllocationGroupLink *AllocateLinks( long count,
|
|
||||||
struct PaUtilAllocationGroupLink *nextBlock,
|
|
||||||
struct PaUtilAllocationGroupLink *nextSpare )
|
|
||||||
{
|
|
||||||
struct PaUtilAllocationGroupLink *result;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
result = (struct PaUtilAllocationGroupLink *)PaUtil_AllocateMemory(
|
|
||||||
sizeof(struct PaUtilAllocationGroupLink) * count );
|
|
||||||
if( result )
|
|
||||||
{
|
|
||||||
/* the block link */
|
|
||||||
result[0].buffer = result;
|
|
||||||
result[0].next = nextBlock;
|
|
||||||
|
|
||||||
/* the spare links */
|
|
||||||
for( i=1; i<count; ++i )
|
|
||||||
{
|
|
||||||
result[i].buffer = 0;
|
|
||||||
result[i].next = &result[i+1];
|
|
||||||
}
|
|
||||||
result[count-1].next = nextSpare;
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
PaUtilAllocationGroup* PaUtil_CreateAllocationGroup( void )
|
|
||||||
{
|
|
||||||
PaUtilAllocationGroup* result = 0;
|
|
||||||
struct PaUtilAllocationGroupLink *links;
|
|
||||||
|
|
||||||
|
|
||||||
links = AllocateLinks( PA_INITIAL_LINK_COUNT_, 0, 0 );
|
|
||||||
if( links != 0 )
|
|
||||||
{
|
|
||||||
result = (PaUtilAllocationGroup*)PaUtil_AllocateMemory( sizeof(PaUtilAllocationGroup) );
|
|
||||||
if( result )
|
|
||||||
{
|
|
||||||
result->linkCount = PA_INITIAL_LINK_COUNT_;
|
|
||||||
result->linkBlocks = &links[0];
|
|
||||||
result->spareLinks = &links[1];
|
|
||||||
result->allocations = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
PaUtil_FreeMemory( links );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_DestroyAllocationGroup( PaUtilAllocationGroup* group )
|
|
||||||
{
|
|
||||||
struct PaUtilAllocationGroupLink *current = group->linkBlocks;
|
|
||||||
struct PaUtilAllocationGroupLink *next;
|
|
||||||
|
|
||||||
while( current )
|
|
||||||
{
|
|
||||||
next = current->next;
|
|
||||||
PaUtil_FreeMemory( current->buffer );
|
|
||||||
current = next;
|
|
||||||
}
|
|
||||||
|
|
||||||
PaUtil_FreeMemory( group );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void* PaUtil_GroupAllocateMemory( PaUtilAllocationGroup* group, long size )
|
|
||||||
{
|
|
||||||
struct PaUtilAllocationGroupLink *links, *link;
|
|
||||||
void *result = 0;
|
|
||||||
|
|
||||||
/* allocate more links if necessary */
|
|
||||||
if( !group->spareLinks )
|
|
||||||
{
|
|
||||||
/* double the link count on each block allocation */
|
|
||||||
links = AllocateLinks( group->linkCount, group->linkBlocks, group->spareLinks );
|
|
||||||
if( links )
|
|
||||||
{
|
|
||||||
group->linkCount += group->linkCount;
|
|
||||||
group->linkBlocks = &links[0];
|
|
||||||
group->spareLinks = &links[1];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if( group->spareLinks )
|
|
||||||
{
|
|
||||||
result = PaUtil_AllocateMemory( size );
|
|
||||||
if( result )
|
|
||||||
{
|
|
||||||
link = group->spareLinks;
|
|
||||||
group->spareLinks = link->next;
|
|
||||||
|
|
||||||
link->buffer = result;
|
|
||||||
link->next = group->allocations;
|
|
||||||
|
|
||||||
group->allocations = link;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_GroupFreeMemory( PaUtilAllocationGroup* group, void *buffer )
|
|
||||||
{
|
|
||||||
struct PaUtilAllocationGroupLink *current = group->allocations;
|
|
||||||
struct PaUtilAllocationGroupLink *previous = 0;
|
|
||||||
|
|
||||||
if( buffer == 0 )
|
|
||||||
return;
|
|
||||||
|
|
||||||
/* find the right link and remove it */
|
|
||||||
while( current )
|
|
||||||
{
|
|
||||||
if( current->buffer == buffer )
|
|
||||||
{
|
|
||||||
if( previous )
|
|
||||||
{
|
|
||||||
previous->next = current->next;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
group->allocations = current->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
current->buffer = 0;
|
|
||||||
current->next = group->spareLinks;
|
|
||||||
group->spareLinks = current;
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
previous = current;
|
|
||||||
current = current->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
PaUtil_FreeMemory( buffer ); /* free the memory whether we found it in the list or not */
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_FreeAllAllocations( PaUtilAllocationGroup* group )
|
|
||||||
{
|
|
||||||
struct PaUtilAllocationGroupLink *current = group->allocations;
|
|
||||||
struct PaUtilAllocationGroupLink *previous = 0;
|
|
||||||
|
|
||||||
/* free all buffers in the allocations list */
|
|
||||||
while( current )
|
|
||||||
{
|
|
||||||
PaUtil_FreeMemory( current->buffer );
|
|
||||||
current->buffer = 0;
|
|
||||||
|
|
||||||
previous = current;
|
|
||||||
current = current->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* link the former allocations list onto the front of the spareLinks list */
|
|
||||||
if( previous )
|
|
||||||
{
|
|
||||||
previous->next = group->spareLinks;
|
|
||||||
group->spareLinks = group->allocations;
|
|
||||||
group->allocations = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,104 +0,0 @@
|
||||||
#ifndef PA_ALLOCATION_H
|
|
||||||
#define PA_ALLOCATION_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library allocation context header
|
|
||||||
* memory allocation context for tracking allocation groups
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2008 Ross Bencina, Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Allocation Group prototypes. An Allocation Group makes it easy to
|
|
||||||
allocate multiple blocks of memory and free them all at once.
|
|
||||||
|
|
||||||
An allocation group is useful for keeping track of multiple blocks
|
|
||||||
of memory which are allocated at the same time (such as during initialization)
|
|
||||||
and need to be deallocated at the same time. The allocation group maintains
|
|
||||||
a list of allocated blocks, and can free all allocations at once. This
|
|
||||||
can be useful for cleaning up after a partially initialized object fails.
|
|
||||||
|
|
||||||
The allocation group implementation is built on top of the lower
|
|
||||||
level allocation functions defined in pa_util.h
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
long linkCount;
|
|
||||||
struct PaUtilAllocationGroupLink *linkBlocks;
|
|
||||||
struct PaUtilAllocationGroupLink *spareLinks;
|
|
||||||
struct PaUtilAllocationGroupLink *allocations;
|
|
||||||
}PaUtilAllocationGroup;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/** Create an allocation group.
|
|
||||||
*/
|
|
||||||
PaUtilAllocationGroup* PaUtil_CreateAllocationGroup( void );
|
|
||||||
|
|
||||||
/** Destroy an allocation group, but not the memory allocated through the group.
|
|
||||||
*/
|
|
||||||
void PaUtil_DestroyAllocationGroup( PaUtilAllocationGroup* group );
|
|
||||||
|
|
||||||
/** Allocate a block of memory though an allocation group.
|
|
||||||
*/
|
|
||||||
void* PaUtil_GroupAllocateMemory( PaUtilAllocationGroup* group, long size );
|
|
||||||
|
|
||||||
/** Free a block of memory that was previously allocated though an allocation
|
|
||||||
group. Calling this function is a relatively time consuming operation.
|
|
||||||
Under normal circumstances clients should call PaUtil_FreeAllAllocations to
|
|
||||||
free all allocated blocks simultaneously.
|
|
||||||
@see PaUtil_FreeAllAllocations
|
|
||||||
*/
|
|
||||||
void PaUtil_GroupFreeMemory( PaUtilAllocationGroup* group, void *buffer );
|
|
||||||
|
|
||||||
/** Free all blocks of memory which have been allocated through the allocation
|
|
||||||
group. This function doesn't destroy the group itself.
|
|
||||||
*/
|
|
||||||
void PaUtil_FreeAllAllocations( PaUtilAllocationGroup* group );
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_ALLOCATION_H */
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,263 +0,0 @@
|
||||||
#ifndef PA_CONVERTERS_H
|
|
||||||
#define PA_CONVERTERS_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library sample conversion mechanism
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2002 Phil Burk, Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Conversion functions used to convert buffers of samples from one
|
|
||||||
format to another.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "portaudio.h" /* for PaSampleFormat */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
struct PaUtilTriangularDitherGenerator;
|
|
||||||
|
|
||||||
|
|
||||||
/** Choose an available sample format which is most appropriate for
|
|
||||||
representing the requested format. If the requested format is not available
|
|
||||||
higher quality formats are considered before lower quality formats.
|
|
||||||
@param availableFormats A variable containing the logical OR of all available
|
|
||||||
formats.
|
|
||||||
@param format The desired format.
|
|
||||||
@return The most appropriate available format for representing the requested
|
|
||||||
format.
|
|
||||||
*/
|
|
||||||
PaSampleFormat PaUtil_SelectClosestAvailableFormat(
|
|
||||||
PaSampleFormat availableFormats, PaSampleFormat format );
|
|
||||||
|
|
||||||
|
|
||||||
/* high level conversions functions for use by implementations */
|
|
||||||
|
|
||||||
|
|
||||||
/** The generic sample converter prototype. Sample converters convert count
|
|
||||||
samples from sourceBuffer to destinationBuffer. The actual type of the data
|
|
||||||
pointed to by these parameters varys for different converter functions.
|
|
||||||
@param destinationBuffer A pointer to the first sample of the destination.
|
|
||||||
@param destinationStride An offset between successive destination samples
|
|
||||||
expressed in samples (not bytes.) It may be negative.
|
|
||||||
@param sourceBuffer A pointer to the first sample of the source.
|
|
||||||
@param sourceStride An offset between successive source samples
|
|
||||||
expressed in samples (not bytes.) It may be negative.
|
|
||||||
@param count The number of samples to convert.
|
|
||||||
@param ditherState State information used to calculate dither. Converters
|
|
||||||
that do not perform dithering will ignore this parameter, in which case
|
|
||||||
NULL or invalid dither state may be passed.
|
|
||||||
*/
|
|
||||||
typedef void PaUtilConverter(
|
|
||||||
void *destinationBuffer, signed int destinationStride,
|
|
||||||
void *sourceBuffer, signed int sourceStride,
|
|
||||||
unsigned int count, struct PaUtilTriangularDitherGenerator *ditherGenerator );
|
|
||||||
|
|
||||||
|
|
||||||
/** Find a sample converter function for the given source and destinations
|
|
||||||
formats and flags (clip and dither.)
|
|
||||||
@return
|
|
||||||
A pointer to a PaUtilConverter which will perform the requested
|
|
||||||
conversion, or NULL if the given format conversion is not supported.
|
|
||||||
For conversions where clipping or dithering is not necessary, the
|
|
||||||
clip and dither flags are ignored and a non-clipping or dithering
|
|
||||||
version is returned.
|
|
||||||
If the source and destination formats are the same, a function which
|
|
||||||
copies data of the appropriate size will be returned.
|
|
||||||
*/
|
|
||||||
PaUtilConverter* PaUtil_SelectConverter( PaSampleFormat sourceFormat,
|
|
||||||
PaSampleFormat destinationFormat, PaStreamFlags flags );
|
|
||||||
|
|
||||||
|
|
||||||
/** The generic buffer zeroer prototype. Buffer zeroers copy count zeros to
|
|
||||||
destinationBuffer. The actual type of the data pointed to varys for
|
|
||||||
different zeroer functions.
|
|
||||||
@param destinationBuffer A pointer to the first sample of the destination.
|
|
||||||
@param destinationStride An offset between successive destination samples
|
|
||||||
expressed in samples (not bytes.) It may be negative.
|
|
||||||
@param count The number of samples to zero.
|
|
||||||
*/
|
|
||||||
typedef void PaUtilZeroer(
|
|
||||||
void *destinationBuffer, signed int destinationStride, unsigned int count );
|
|
||||||
|
|
||||||
|
|
||||||
/** Find a buffer zeroer function for the given destination format.
|
|
||||||
@return
|
|
||||||
A pointer to a PaUtilZeroer which will perform the requested
|
|
||||||
zeroing.
|
|
||||||
*/
|
|
||||||
PaUtilZeroer* PaUtil_SelectZeroer( PaSampleFormat destinationFormat );
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------------------*/
|
|
||||||
/* low level functions and data structures which may be used for
|
|
||||||
substituting conversion functions */
|
|
||||||
|
|
||||||
|
|
||||||
/** The type used to store all sample conversion functions.
|
|
||||||
@see paConverters;
|
|
||||||
*/
|
|
||||||
typedef struct{
|
|
||||||
PaUtilConverter *Float32_To_Int32;
|
|
||||||
PaUtilConverter *Float32_To_Int32_Dither;
|
|
||||||
PaUtilConverter *Float32_To_Int32_Clip;
|
|
||||||
PaUtilConverter *Float32_To_Int32_DitherClip;
|
|
||||||
|
|
||||||
PaUtilConverter *Float32_To_Int24;
|
|
||||||
PaUtilConverter *Float32_To_Int24_Dither;
|
|
||||||
PaUtilConverter *Float32_To_Int24_Clip;
|
|
||||||
PaUtilConverter *Float32_To_Int24_DitherClip;
|
|
||||||
|
|
||||||
PaUtilConverter *Float32_To_Int16;
|
|
||||||
PaUtilConverter *Float32_To_Int16_Dither;
|
|
||||||
PaUtilConverter *Float32_To_Int16_Clip;
|
|
||||||
PaUtilConverter *Float32_To_Int16_DitherClip;
|
|
||||||
|
|
||||||
PaUtilConverter *Float32_To_Int8;
|
|
||||||
PaUtilConverter *Float32_To_Int8_Dither;
|
|
||||||
PaUtilConverter *Float32_To_Int8_Clip;
|
|
||||||
PaUtilConverter *Float32_To_Int8_DitherClip;
|
|
||||||
|
|
||||||
PaUtilConverter *Float32_To_UInt8;
|
|
||||||
PaUtilConverter *Float32_To_UInt8_Dither;
|
|
||||||
PaUtilConverter *Float32_To_UInt8_Clip;
|
|
||||||
PaUtilConverter *Float32_To_UInt8_DitherClip;
|
|
||||||
|
|
||||||
PaUtilConverter *Int32_To_Float32;
|
|
||||||
PaUtilConverter *Int32_To_Int24;
|
|
||||||
PaUtilConverter *Int32_To_Int24_Dither;
|
|
||||||
PaUtilConverter *Int32_To_Int16;
|
|
||||||
PaUtilConverter *Int32_To_Int16_Dither;
|
|
||||||
PaUtilConverter *Int32_To_Int8;
|
|
||||||
PaUtilConverter *Int32_To_Int8_Dither;
|
|
||||||
PaUtilConverter *Int32_To_UInt8;
|
|
||||||
PaUtilConverter *Int32_To_UInt8_Dither;
|
|
||||||
|
|
||||||
PaUtilConverter *Int24_To_Float32;
|
|
||||||
PaUtilConverter *Int24_To_Int32;
|
|
||||||
PaUtilConverter *Int24_To_Int16;
|
|
||||||
PaUtilConverter *Int24_To_Int16_Dither;
|
|
||||||
PaUtilConverter *Int24_To_Int8;
|
|
||||||
PaUtilConverter *Int24_To_Int8_Dither;
|
|
||||||
PaUtilConverter *Int24_To_UInt8;
|
|
||||||
PaUtilConverter *Int24_To_UInt8_Dither;
|
|
||||||
|
|
||||||
PaUtilConverter *Int16_To_Float32;
|
|
||||||
PaUtilConverter *Int16_To_Int32;
|
|
||||||
PaUtilConverter *Int16_To_Int24;
|
|
||||||
PaUtilConverter *Int16_To_Int8;
|
|
||||||
PaUtilConverter *Int16_To_Int8_Dither;
|
|
||||||
PaUtilConverter *Int16_To_UInt8;
|
|
||||||
PaUtilConverter *Int16_To_UInt8_Dither;
|
|
||||||
|
|
||||||
PaUtilConverter *Int8_To_Float32;
|
|
||||||
PaUtilConverter *Int8_To_Int32;
|
|
||||||
PaUtilConverter *Int8_To_Int24;
|
|
||||||
PaUtilConverter *Int8_To_Int16;
|
|
||||||
PaUtilConverter *Int8_To_UInt8;
|
|
||||||
|
|
||||||
PaUtilConverter *UInt8_To_Float32;
|
|
||||||
PaUtilConverter *UInt8_To_Int32;
|
|
||||||
PaUtilConverter *UInt8_To_Int24;
|
|
||||||
PaUtilConverter *UInt8_To_Int16;
|
|
||||||
PaUtilConverter *UInt8_To_Int8;
|
|
||||||
|
|
||||||
PaUtilConverter *Copy_8_To_8; /* copy without any conversion */
|
|
||||||
PaUtilConverter *Copy_16_To_16; /* copy without any conversion */
|
|
||||||
PaUtilConverter *Copy_24_To_24; /* copy without any conversion */
|
|
||||||
PaUtilConverter *Copy_32_To_32; /* copy without any conversion */
|
|
||||||
} PaUtilConverterTable;
|
|
||||||
|
|
||||||
|
|
||||||
/** A table of pointers to all required converter functions.
|
|
||||||
PaUtil_SelectConverter() uses this table to lookup the appropriate
|
|
||||||
conversion functions. The fields of this structure are initialized
|
|
||||||
with default conversion functions. Fields may be NULL, indicating that
|
|
||||||
no conversion function is available. User code may substitute optimised
|
|
||||||
conversion functions by assigning different function pointers to
|
|
||||||
these fields.
|
|
||||||
|
|
||||||
@note
|
|
||||||
If the PA_NO_STANDARD_CONVERTERS preprocessor variable is defined,
|
|
||||||
PortAudio's standard converters will not be compiled, and all fields
|
|
||||||
of this structure will be initialized to NULL. In such cases, users
|
|
||||||
should supply their own conversion functions if the require PortAudio
|
|
||||||
to open a stream that requires sample conversion.
|
|
||||||
|
|
||||||
@see PaUtilConverterTable, PaUtilConverter, PaUtil_SelectConverter
|
|
||||||
*/
|
|
||||||
extern PaUtilConverterTable paConverters;
|
|
||||||
|
|
||||||
|
|
||||||
/** The type used to store all buffer zeroing functions.
|
|
||||||
@see paZeroers;
|
|
||||||
*/
|
|
||||||
typedef struct{
|
|
||||||
PaUtilZeroer *ZeroU8; /* unsigned 8 bit, zero == 128 */
|
|
||||||
PaUtilZeroer *Zero8;
|
|
||||||
PaUtilZeroer *Zero16;
|
|
||||||
PaUtilZeroer *Zero24;
|
|
||||||
PaUtilZeroer *Zero32;
|
|
||||||
} PaUtilZeroerTable;
|
|
||||||
|
|
||||||
|
|
||||||
/** A table of pointers to all required zeroer functions.
|
|
||||||
PaUtil_SelectZeroer() uses this table to lookup the appropriate
|
|
||||||
conversion functions. The fields of this structure are initialized
|
|
||||||
with default conversion functions. User code may substitute optimised
|
|
||||||
conversion functions by assigning different function pointers to
|
|
||||||
these fields.
|
|
||||||
|
|
||||||
@note
|
|
||||||
If the PA_NO_STANDARD_ZEROERS preprocessor variable is defined,
|
|
||||||
PortAudio's standard zeroers will not be compiled, and all fields
|
|
||||||
of this structure will be initialized to NULL. In such cases, users
|
|
||||||
should supply their own zeroing functions for the sample sizes which
|
|
||||||
they intend to use.
|
|
||||||
|
|
||||||
@see PaUtilZeroerTable, PaUtilZeroer, PaUtil_SelectZeroer
|
|
||||||
*/
|
|
||||||
extern PaUtilZeroerTable paZeroers;
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_CONVERTERS_H */
|
|
|
@ -1,105 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library CPU Load measurement functions
|
|
||||||
* Portable CPU load measurement facility.
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 2002 Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Functions to assist in measuring the CPU utilization of a callback
|
|
||||||
stream. Used to implement the Pa_GetStreamCpuLoad() function.
|
|
||||||
|
|
||||||
@todo Dynamically calculate the coefficients used to smooth the CPU Load
|
|
||||||
Measurements over time to provide a uniform characterisation of CPU Load
|
|
||||||
independent of rate at which PaUtil_BeginCpuLoadMeasurement /
|
|
||||||
PaUtil_EndCpuLoadMeasurement are called. see http://www.portaudio.com/trac/ticket/113
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "pa_cpuload.h"
|
|
||||||
|
|
||||||
#include <assert.h>
|
|
||||||
|
|
||||||
#include "pa_util.h" /* for PaUtil_GetTime() */
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_InitializeCpuLoadMeasurer( PaUtilCpuLoadMeasurer* measurer, double sampleRate )
|
|
||||||
{
|
|
||||||
assert( sampleRate > 0 );
|
|
||||||
|
|
||||||
measurer->samplingPeriod = 1. / sampleRate;
|
|
||||||
measurer->averageLoad = 0.;
|
|
||||||
}
|
|
||||||
|
|
||||||
void PaUtil_ResetCpuLoadMeasurer( PaUtilCpuLoadMeasurer* measurer )
|
|
||||||
{
|
|
||||||
measurer->averageLoad = 0.;
|
|
||||||
}
|
|
||||||
|
|
||||||
void PaUtil_BeginCpuLoadMeasurement( PaUtilCpuLoadMeasurer* measurer )
|
|
||||||
{
|
|
||||||
measurer->measurementStartTime = PaUtil_GetTime();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_EndCpuLoadMeasurement( PaUtilCpuLoadMeasurer* measurer, unsigned long framesProcessed )
|
|
||||||
{
|
|
||||||
double measurementEndTime, secondsFor100Percent, measuredLoad;
|
|
||||||
|
|
||||||
if( framesProcessed > 0 ){
|
|
||||||
measurementEndTime = PaUtil_GetTime();
|
|
||||||
|
|
||||||
assert( framesProcessed > 0 );
|
|
||||||
secondsFor100Percent = framesProcessed * measurer->samplingPeriod;
|
|
||||||
|
|
||||||
measuredLoad = (measurementEndTime - measurer->measurementStartTime) / secondsFor100Percent;
|
|
||||||
|
|
||||||
/* Low pass filter the calculated CPU load to reduce jitter using a simple IIR low pass filter. */
|
|
||||||
/** FIXME @todo these coefficients shouldn't be hardwired see: http://www.portaudio.com/trac/ticket/113 */
|
|
||||||
#define LOWPASS_COEFFICIENT_0 (0.9)
|
|
||||||
#define LOWPASS_COEFFICIENT_1 (0.99999 - LOWPASS_COEFFICIENT_0)
|
|
||||||
|
|
||||||
measurer->averageLoad = (LOWPASS_COEFFICIENT_0 * measurer->averageLoad) +
|
|
||||||
(LOWPASS_COEFFICIENT_1 * measuredLoad);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
double PaUtil_GetCpuLoad( PaUtilCpuLoadMeasurer* measurer )
|
|
||||||
{
|
|
||||||
return measurer->averageLoad;
|
|
||||||
}
|
|
|
@ -1,72 +0,0 @@
|
||||||
#ifndef PA_CPULOAD_H
|
|
||||||
#define PA_CPULOAD_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library CPU Load measurement functions
|
|
||||||
* Portable CPU load measurement facility.
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 2002 Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Functions to assist in measuring the CPU utilization of a callback
|
|
||||||
stream. Used to implement the Pa_GetStreamCpuLoad() function.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
double samplingPeriod;
|
|
||||||
double measurementStartTime;
|
|
||||||
double averageLoad;
|
|
||||||
} PaUtilCpuLoadMeasurer; /**< @todo need better name than measurer */
|
|
||||||
|
|
||||||
void PaUtil_InitializeCpuLoadMeasurer( PaUtilCpuLoadMeasurer* measurer, double sampleRate );
|
|
||||||
void PaUtil_BeginCpuLoadMeasurement( PaUtilCpuLoadMeasurer* measurer );
|
|
||||||
void PaUtil_EndCpuLoadMeasurement( PaUtilCpuLoadMeasurer* measurer, unsigned long framesProcessed );
|
|
||||||
void PaUtil_ResetCpuLoadMeasurer( PaUtilCpuLoadMeasurer* measurer );
|
|
||||||
double PaUtil_GetCpuLoad( PaUtilCpuLoadMeasurer* measurer );
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_CPULOAD_H */
|
|
|
@ -1,123 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id: pa_log.c $
|
|
||||||
* Portable Audio I/O Library Multi-Host API front end
|
|
||||||
* Validate function parameters and manage multiple host APIs.
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2006 Ross Bencina, Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Implements log function.
|
|
||||||
|
|
||||||
PaUtil_SetLogPrintFunction can be user called to replace the provided
|
|
||||||
DefaultLogPrint function, which writes to stderr.
|
|
||||||
One can NOT pass var_args across compiler/dll boundaries as it is not
|
|
||||||
"byte code/abi portable". So the technique used here is to allocate a local
|
|
||||||
a static array, write in it, then callback the user with a pointer to its
|
|
||||||
start.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdarg.h>
|
|
||||||
|
|
||||||
#include "pa_debugprint.h"
|
|
||||||
|
|
||||||
// for OutputDebugStringA
|
|
||||||
#if defined(_MSC_VER) && defined(PA_ENABLE_MSVC_DEBUG_OUTPUT)
|
|
||||||
#define WIN32_LEAN_AND_MEAN // exclude rare headers
|
|
||||||
#include "windows.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// User callback
|
|
||||||
static PaUtilLogCallback userCB = NULL;
|
|
||||||
|
|
||||||
// Sets user callback
|
|
||||||
void PaUtil_SetDebugPrintFunction(PaUtilLogCallback cb)
|
|
||||||
{
|
|
||||||
userCB = cb;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
If your platform doesn't have vsnprintf, you are stuck with a
|
|
||||||
VERY dangerous alternative, vsprintf (with no n)
|
|
||||||
*/
|
|
||||||
#if _MSC_VER
|
|
||||||
/* Some Windows Mobile SDKs don't define vsnprintf but all define _vsnprintf (hopefully).
|
|
||||||
According to MSDN "vsnprintf is identical to _vsnprintf". So we use _vsnprintf with MSC.
|
|
||||||
*/
|
|
||||||
#define VSNPRINTF _vsnprintf
|
|
||||||
#else
|
|
||||||
#define VSNPRINTF vsnprintf
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define PA_LOG_BUF_SIZE 2048
|
|
||||||
|
|
||||||
void PaUtil_DebugPrint( const char *format, ... )
|
|
||||||
{
|
|
||||||
// Optional logging into Output console of Visual Studio
|
|
||||||
#if defined(_MSC_VER) && defined(PA_ENABLE_MSVC_DEBUG_OUTPUT)
|
|
||||||
{
|
|
||||||
char buf[PA_LOG_BUF_SIZE];
|
|
||||||
va_list ap;
|
|
||||||
va_start(ap, format);
|
|
||||||
VSNPRINTF(buf, sizeof(buf), format, ap);
|
|
||||||
buf[sizeof(buf)-1] = 0;
|
|
||||||
OutputDebugStringA(buf);
|
|
||||||
va_end(ap);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Output to User-Callback
|
|
||||||
if (userCB != NULL)
|
|
||||||
{
|
|
||||||
char strdump[PA_LOG_BUF_SIZE];
|
|
||||||
va_list ap;
|
|
||||||
va_start(ap, format);
|
|
||||||
VSNPRINTF(strdump, sizeof(strdump), format, ap);
|
|
||||||
strdump[sizeof(strdump)-1] = 0;
|
|
||||||
userCB(strdump);
|
|
||||||
va_end(ap);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
// Standard output to stderr
|
|
||||||
{
|
|
||||||
va_list ap;
|
|
||||||
va_start(ap, format);
|
|
||||||
vfprintf(stderr, format, ap);
|
|
||||||
va_end(ap);
|
|
||||||
fflush(stderr);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,149 +0,0 @@
|
||||||
#ifndef PA_LOG_H
|
|
||||||
#define PA_LOG_H
|
|
||||||
/*
|
|
||||||
* Log file redirector function
|
|
||||||
* Copyright (c) 1999-2006 Ross Bencina, Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_DebugPrint( const char *format, ... );
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
The basic format for log messages is described below. If you need to
|
|
||||||
add any log messages, please follow this format.
|
|
||||||
|
|
||||||
Function entry (void function):
|
|
||||||
|
|
||||||
"FunctionName called.\n"
|
|
||||||
|
|
||||||
Function entry (non void function):
|
|
||||||
|
|
||||||
"FunctionName called:\n"
|
|
||||||
"\tParam1Type param1: param1Value\n"
|
|
||||||
"\tParam2Type param2: param2Value\n" (etc...)
|
|
||||||
|
|
||||||
|
|
||||||
Function exit (no return value):
|
|
||||||
|
|
||||||
"FunctionName returned.\n"
|
|
||||||
|
|
||||||
Function exit (simple return value):
|
|
||||||
|
|
||||||
"FunctionName returned:\n"
|
|
||||||
"\tReturnType: returnValue\n"
|
|
||||||
|
|
||||||
If the return type is an error code, the error text is displayed in ()
|
|
||||||
|
|
||||||
If the return type is not an error code, but has taken a special value
|
|
||||||
because an error occurred, then the reason for the error is shown in []
|
|
||||||
|
|
||||||
If the return type is a struct ptr, the struct is dumped.
|
|
||||||
|
|
||||||
See the code below for examples
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** PA_DEBUG() provides a simple debug message printing facility. The macro
|
|
||||||
passes it's argument to a printf-like function called PaUtil_DebugPrint()
|
|
||||||
which prints to stderr and always flushes the stream after printing.
|
|
||||||
Because preprocessor macros cannot directly accept variable length argument
|
|
||||||
lists, calls to the macro must include an additional set of parenthesis, eg:
|
|
||||||
PA_DEBUG(("errorno: %d", 1001 ));
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef PA_ENABLE_DEBUG_OUTPUT
|
|
||||||
#define PA_DEBUG(x) PaUtil_DebugPrint x ;
|
|
||||||
#else
|
|
||||||
#define PA_DEBUG(x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef PA_LOG_API_CALLS
|
|
||||||
#define PA_LOGAPI(x) PaUtil_DebugPrint x
|
|
||||||
|
|
||||||
#define PA_LOGAPI_ENTER(functionName) PaUtil_DebugPrint( functionName " called.\n" )
|
|
||||||
|
|
||||||
#define PA_LOGAPI_ENTER_PARAMS(functionName) PaUtil_DebugPrint( functionName " called:\n" )
|
|
||||||
|
|
||||||
#define PA_LOGAPI_EXIT(functionName) PaUtil_DebugPrint( functionName " returned.\n" )
|
|
||||||
|
|
||||||
#define PA_LOGAPI_EXIT_PAERROR( functionName, result ) \
|
|
||||||
PaUtil_DebugPrint( functionName " returned:\n" ); \
|
|
||||||
PaUtil_DebugPrint("\tPaError: %d ( %s )\n", result, Pa_GetErrorText( result ) )
|
|
||||||
|
|
||||||
#define PA_LOGAPI_EXIT_T( functionName, resultFormatString, result ) \
|
|
||||||
PaUtil_DebugPrint( functionName " returned:\n" ); \
|
|
||||||
PaUtil_DebugPrint("\t" resultFormatString "\n", result )
|
|
||||||
|
|
||||||
#define PA_LOGAPI_EXIT_PAERROR_OR_T_RESULT( functionName, positiveResultFormatString, result ) \
|
|
||||||
PaUtil_DebugPrint( functionName " returned:\n" ); \
|
|
||||||
if( result > 0 ) \
|
|
||||||
PaUtil_DebugPrint("\t" positiveResultFormatString "\n", result ); \
|
|
||||||
else \
|
|
||||||
PaUtil_DebugPrint("\tPaError: %d ( %s )\n", result, Pa_GetErrorText( result ) )
|
|
||||||
#else
|
|
||||||
#define PA_LOGAPI(x)
|
|
||||||
#define PA_LOGAPI_ENTER(functionName)
|
|
||||||
#define PA_LOGAPI_ENTER_PARAMS(functionName)
|
|
||||||
#define PA_LOGAPI_EXIT(functionName)
|
|
||||||
#define PA_LOGAPI_EXIT_PAERROR( functionName, result )
|
|
||||||
#define PA_LOGAPI_EXIT_T( functionName, resultFormatString, result )
|
|
||||||
#define PA_LOGAPI_EXIT_PAERROR_OR_T_RESULT( functionName, positiveResultFormatString, result )
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
typedef void (*PaUtilLogCallback ) (const char *log);
|
|
||||||
|
|
||||||
/**
|
|
||||||
Install user provided log function
|
|
||||||
*/
|
|
||||||
void PaUtil_SetDebugPrintFunction(PaUtilLogCallback cb);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_LOG_H */
|
|
|
@ -1,218 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library triangular dither generator
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2002 Phil Burk, Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Functions for generating dither noise
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "pa_types.h"
|
|
||||||
#include "pa_dither.h"
|
|
||||||
|
|
||||||
|
|
||||||
/* Note that the linear congruential algorithm requires 32 bit integers
|
|
||||||
* because it uses arithmetic overflow. So use PaUint32 instead of
|
|
||||||
* unsigned long so it will work on 64 bit systems.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define PA_DITHER_BITS_ (15)
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_InitializeTriangularDitherState( PaUtilTriangularDitherGenerator *state )
|
|
||||||
{
|
|
||||||
state->previous = 0;
|
|
||||||
state->randSeed1 = 22222;
|
|
||||||
state->randSeed2 = 5555555;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
PaInt32 PaUtil_Generate16BitTriangularDither( PaUtilTriangularDitherGenerator *state )
|
|
||||||
{
|
|
||||||
PaInt32 current, highPass;
|
|
||||||
|
|
||||||
/* Generate two random numbers. */
|
|
||||||
state->randSeed1 = (state->randSeed1 * 196314165) + 907633515;
|
|
||||||
state->randSeed2 = (state->randSeed2 * 196314165) + 907633515;
|
|
||||||
|
|
||||||
/* Generate triangular distribution about 0.
|
|
||||||
* Shift before adding to prevent overflow which would skew the distribution.
|
|
||||||
* Also shift an extra bit for the high pass filter.
|
|
||||||
*/
|
|
||||||
#define DITHER_SHIFT_ ((sizeof(PaInt32)*8 - PA_DITHER_BITS_) + 1)
|
|
||||||
|
|
||||||
current = (((PaInt32)state->randSeed1)>>DITHER_SHIFT_) +
|
|
||||||
(((PaInt32)state->randSeed2)>>DITHER_SHIFT_);
|
|
||||||
|
|
||||||
/* High pass filter to reduce audibility. */
|
|
||||||
highPass = current - state->previous;
|
|
||||||
state->previous = current;
|
|
||||||
return highPass;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Multiply by PA_FLOAT_DITHER_SCALE_ to get a float between -2.0 and +1.99999 */
|
|
||||||
#define PA_FLOAT_DITHER_SCALE_ (1.0f / ((1<<PA_DITHER_BITS_)-1))
|
|
||||||
static const float const_float_dither_scale_ = PA_FLOAT_DITHER_SCALE_;
|
|
||||||
|
|
||||||
float PaUtil_GenerateFloatTriangularDither( PaUtilTriangularDitherGenerator *state )
|
|
||||||
{
|
|
||||||
PaInt32 current, highPass;
|
|
||||||
|
|
||||||
/* Generate two random numbers. */
|
|
||||||
state->randSeed1 = (state->randSeed1 * 196314165) + 907633515;
|
|
||||||
state->randSeed2 = (state->randSeed2 * 196314165) + 907633515;
|
|
||||||
|
|
||||||
/* Generate triangular distribution about 0.
|
|
||||||
* Shift before adding to prevent overflow which would skew the distribution.
|
|
||||||
* Also shift an extra bit for the high pass filter.
|
|
||||||
*/
|
|
||||||
current = (((PaInt32)state->randSeed1)>>DITHER_SHIFT_) +
|
|
||||||
(((PaInt32)state->randSeed2)>>DITHER_SHIFT_);
|
|
||||||
|
|
||||||
/* High pass filter to reduce audibility. */
|
|
||||||
highPass = current - state->previous;
|
|
||||||
state->previous = current;
|
|
||||||
return ((float)highPass) * const_float_dither_scale_;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
The following alternate dither algorithms (from musicdsp.org) could be
|
|
||||||
considered
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*Noise shaped dither (March 2000)
|
|
||||||
-------------------
|
|
||||||
|
|
||||||
This is a simple implementation of highpass triangular-PDF dither with
|
|
||||||
2nd-order noise shaping, for use when truncating floating point audio
|
|
||||||
data to fixed point.
|
|
||||||
|
|
||||||
The noise shaping lowers the noise floor by 11dB below 5kHz (@ 44100Hz
|
|
||||||
sample rate) compared to triangular-PDF dither. The code below assumes
|
|
||||||
input data is in the range +1 to -1 and doesn't check for overloads!
|
|
||||||
|
|
||||||
To save time when generating dither for multiple channels you can do
|
|
||||||
things like this: r3=(r1 & 0x7F)<<8; instead of calling rand() again.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int r1, r2; //rectangular-PDF random numbers
|
|
||||||
float s1, s2; //error feedback buffers
|
|
||||||
float s = 0.5f; //set to 0.0f for no noise shaping
|
|
||||||
float w = pow(2.0,bits-1); //word length (usually bits=16)
|
|
||||||
float wi= 1.0f/w;
|
|
||||||
float d = wi / RAND_MAX; //dither amplitude (2 lsb)
|
|
||||||
float o = wi * 0.5f; //remove dc offset
|
|
||||||
float in, tmp;
|
|
||||||
int out;
|
|
||||||
|
|
||||||
|
|
||||||
//for each sample...
|
|
||||||
|
|
||||||
r2=r1; //can make HP-TRI dither by
|
|
||||||
r1=rand(); //subtracting previous rand()
|
|
||||||
|
|
||||||
in += s * (s1 + s1 - s2); //error feedback
|
|
||||||
tmp = in + o + d * (float)(r1 - r2); //dc offset and dither
|
|
||||||
|
|
||||||
out = (int)(w * tmp); //truncate downwards
|
|
||||||
if(tmp<0.0f) out--; //this is faster than floor()
|
|
||||||
|
|
||||||
s2 = s1;
|
|
||||||
s1 = in - wi * (float)out; //error
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
paul.kellett@maxim.abel.co.uk
|
|
||||||
http://www.maxim.abel.co.uk
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
16-to-8-bit first-order dither
|
|
||||||
|
|
||||||
Type : First order error feedforward dithering code
|
|
||||||
References : Posted by Jon Watte
|
|
||||||
|
|
||||||
Notes :
|
|
||||||
This is about as simple a dithering algorithm as you can implement, but it's
|
|
||||||
likely to sound better than just truncating to N bits.
|
|
||||||
|
|
||||||
Note that you might not want to carry forward the full difference for infinity.
|
|
||||||
It's probably likely that the worst performance hit comes from the saturation
|
|
||||||
conditionals, which can be avoided with appropriate instructions on many DSPs
|
|
||||||
and integer SIMD type instructions, or CMOV.
|
|
||||||
|
|
||||||
Last, if sound quality is paramount (such as when going from > 16 bits to 16
|
|
||||||
bits) you probably want to use a higher-order dither function found elsewhere
|
|
||||||
on this site.
|
|
||||||
|
|
||||||
|
|
||||||
Code :
|
|
||||||
// This code will down-convert and dither a 16-bit signed short
|
|
||||||
// mono signal into an 8-bit unsigned char signal, using a first
|
|
||||||
// order forward-feeding error term dither.
|
|
||||||
|
|
||||||
#define uchar unsigned char
|
|
||||||
|
|
||||||
void dither_one_channel_16_to_8( short * input, uchar * output, int count, int * memory )
|
|
||||||
{
|
|
||||||
int m = *memory;
|
|
||||||
while( count-- > 0 ) {
|
|
||||||
int i = *input++;
|
|
||||||
i += m;
|
|
||||||
int j = i + 32768 - 128;
|
|
||||||
uchar o;
|
|
||||||
if( j < 0 ) {
|
|
||||||
o = 0;
|
|
||||||
}
|
|
||||||
else if( j > 65535 ) {
|
|
||||||
o = 255;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
o = (uchar)((j>>8)&0xff);
|
|
||||||
}
|
|
||||||
m = ((j-32768+128)-i);
|
|
||||||
*output++ = o;
|
|
||||||
}
|
|
||||||
*memory = m;
|
|
||||||
}
|
|
||||||
*/
|
|
|
@ -1,106 +0,0 @@
|
||||||
#ifndef PA_DITHER_H
|
|
||||||
#define PA_DITHER_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library triangular dither generator
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2002 Phil Burk, Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Functions for generating dither noise
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "pa_types.h"
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
/* Note that the linear congruential algorithm requires 32 bit integers
|
|
||||||
* because it uses arithmetic overflow. So use PaUint32 instead of
|
|
||||||
* unsigned long so it will work on 64 bit systems.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @brief State needed to generate a dither signal */
|
|
||||||
typedef struct PaUtilTriangularDitherGenerator{
|
|
||||||
PaUint32 previous;
|
|
||||||
PaUint32 randSeed1;
|
|
||||||
PaUint32 randSeed2;
|
|
||||||
} PaUtilTriangularDitherGenerator;
|
|
||||||
|
|
||||||
|
|
||||||
/** @brief Initialize dither state */
|
|
||||||
void PaUtil_InitializeTriangularDitherState( PaUtilTriangularDitherGenerator *ditherState );
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
@brief Calculate 2 LSB dither signal with a triangular distribution.
|
|
||||||
Ranged for adding to a 1 bit right-shifted 32 bit integer
|
|
||||||
prior to >>15. eg:
|
|
||||||
<pre>
|
|
||||||
signed long in = *
|
|
||||||
signed long dither = PaUtil_Generate16BitTriangularDither( ditherState );
|
|
||||||
signed short out = (signed short)(((in>>1) + dither) >> 15);
|
|
||||||
</pre>
|
|
||||||
@return
|
|
||||||
A signed 32-bit integer with a range of +32767 to -32768
|
|
||||||
*/
|
|
||||||
PaInt32 PaUtil_Generate16BitTriangularDither( PaUtilTriangularDitherGenerator *ditherState );
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
@brief Calculate 2 LSB dither signal with a triangular distribution.
|
|
||||||
Ranged for adding to a pre-scaled float.
|
|
||||||
<pre>
|
|
||||||
float in = *
|
|
||||||
float dither = PaUtil_GenerateFloatTriangularDither( ditherState );
|
|
||||||
// use smaller scaler to prevent overflow when we add the dither
|
|
||||||
signed short out = (signed short)(in*(32766.0f) + dither );
|
|
||||||
</pre>
|
|
||||||
@return
|
|
||||||
A float with a range of -2.0 to +1.99999.
|
|
||||||
*/
|
|
||||||
float PaUtil_GenerateFloatTriangularDither( PaUtilTriangularDitherGenerator *ditherState );
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_DITHER_H */
|
|
|
@ -1,145 +0,0 @@
|
||||||
#ifndef PA_ENDIANNESS_H
|
|
||||||
#define PA_ENDIANNESS_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library current platform endianness macros
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2002 Phil Burk, Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Configure endianness symbols for the target processor.
|
|
||||||
|
|
||||||
Arrange for either the PA_LITTLE_ENDIAN or PA_BIG_ENDIAN preprocessor symbols
|
|
||||||
to be defined. The one that is defined reflects the endianness of the target
|
|
||||||
platform and may be used to implement conditional compilation of byte-order
|
|
||||||
dependent code.
|
|
||||||
|
|
||||||
If either PA_LITTLE_ENDIAN or PA_BIG_ENDIAN is defined already, then no attempt
|
|
||||||
is made to override that setting. This may be useful if you have a better way
|
|
||||||
of determining the platform's endianness. The autoconf mechanism uses this for
|
|
||||||
example.
|
|
||||||
|
|
||||||
A PA_VALIDATE_ENDIANNESS macro is provided to compare the compile time
|
|
||||||
and runtime endianness and raise an assertion if they don't match.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
/* If this is an apple, we need to do detect endianness this way */
|
|
||||||
#if defined(__APPLE__)
|
|
||||||
/* we need to do some endian detection that is sensitive to hardware arch */
|
|
||||||
#if defined(__LITTLE_ENDIAN__)
|
|
||||||
#if !defined( PA_LITTLE_ENDIAN )
|
|
||||||
#define PA_LITTLE_ENDIAN
|
|
||||||
#endif
|
|
||||||
#if defined( PA_BIG_ENDIAN )
|
|
||||||
#undef PA_BIG_ENDIAN
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
#if !defined( PA_BIG_ENDIAN )
|
|
||||||
#define PA_BIG_ENDIAN
|
|
||||||
#endif
|
|
||||||
#if defined( PA_LITTLE_ENDIAN )
|
|
||||||
#undef PA_LITTLE_ENDIAN
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
/* this is not an apple, so first check the existing defines, and, failing that,
|
|
||||||
detect well-known architectures. */
|
|
||||||
|
|
||||||
#if defined(PA_LITTLE_ENDIAN) || defined(PA_BIG_ENDIAN)
|
|
||||||
/* endianness define has been set externally, such as by autoconf */
|
|
||||||
|
|
||||||
#if defined(PA_LITTLE_ENDIAN) && defined(PA_BIG_ENDIAN)
|
|
||||||
#error both PA_LITTLE_ENDIAN and PA_BIG_ENDIAN have been defined externally to pa_endianness.h - only one endianness at a time please
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#else
|
|
||||||
/* endianness define has not been set externally */
|
|
||||||
|
|
||||||
/* set PA_LITTLE_ENDIAN or PA_BIG_ENDIAN by testing well known platform specific defines */
|
|
||||||
|
|
||||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32__) || defined(__NT__) || defined(LITTLE_ENDIAN) || defined(__i386) || defined(_M_IX86) || defined(__x86_64__)
|
|
||||||
#define PA_LITTLE_ENDIAN /* win32, assume intel byte order */
|
|
||||||
#else
|
|
||||||
#define PA_BIG_ENDIAN
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined(PA_LITTLE_ENDIAN) && !defined(PA_BIG_ENDIAN)
|
|
||||||
/*
|
|
||||||
If the following error is raised, you either need to modify the code above
|
|
||||||
to automatically determine the endianness from other symbols defined on your
|
|
||||||
platform, or define either PA_LITTLE_ENDIAN or PA_BIG_ENDIAN externally.
|
|
||||||
*/
|
|
||||||
#error pa_endianness.h was unable to automatically determine the endianness of the target platform
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* PA_VALIDATE_ENDIANNESS compares the compile time and runtime endianness,
|
|
||||||
and raises an assertion if they don't match. <assert.h> must be included in
|
|
||||||
the context in which this macro is used.
|
|
||||||
*/
|
|
||||||
#if defined(NDEBUG)
|
|
||||||
#define PA_VALIDATE_ENDIANNESS
|
|
||||||
#else
|
|
||||||
#if defined(PA_LITTLE_ENDIAN)
|
|
||||||
#define PA_VALIDATE_ENDIANNESS \
|
|
||||||
{ \
|
|
||||||
const long nativeOne = 1; \
|
|
||||||
assert( "PortAudio: compile time and runtime endianness don't match" && (((char *)&nativeOne)[0]) == 1 ); \
|
|
||||||
}
|
|
||||||
#elif defined(PA_BIG_ENDIAN)
|
|
||||||
#define PA_VALIDATE_ENDIANNESS \
|
|
||||||
{ \
|
|
||||||
const long nativeOne = 1; \
|
|
||||||
assert( "PortAudio: compile time and runtime endianness don't match" && (((char *)&nativeOne)[0]) == 0 ); \
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_ENDIANNESS_H */
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1 +0,0 @@
|
||||||
#define PA_GIT_REVISION unknown
|
|
|
@ -1,362 +0,0 @@
|
||||||
#ifndef PA_HOSTAPI_H
|
|
||||||
#define PA_HOSTAPI_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library
|
|
||||||
* host api representation
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2008 Ross Bencina, Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Interfaces and representation structures used by pa_front.c
|
|
||||||
to manage and communicate with host API implementations.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
|
|
||||||
/**
|
|
||||||
The PA_NO_* host API macros are now deprecated in favor of PA_USE_* macros.
|
|
||||||
PA_USE_* indicates whether a particular host API will be initialized by PortAudio.
|
|
||||||
An undefined or 0 value indicates that the host API will not be used. A value of 1
|
|
||||||
indicates that the host API will be used. PA_USE_* macros should be left undefined
|
|
||||||
or defined to either 0 or 1.
|
|
||||||
|
|
||||||
The code below ensures that PA_USE_* macros are always defined and have value
|
|
||||||
0 or 1. Undefined symbols are defaulted to 0. Symbols that are neither 0 nor 1
|
|
||||||
are defaulted to 1.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef PA_USE_SKELETON
|
|
||||||
#define PA_USE_SKELETON 0
|
|
||||||
#elif (PA_USE_SKELETON != 0) && (PA_USE_SKELETON != 1)
|
|
||||||
#undef PA_USE_SKELETON
|
|
||||||
#define PA_USE_SKELETON 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(PA_NO_ASIO) || defined(PA_NO_DS) || defined(PA_NO_WMME) || defined(PA_NO_WASAPI) || defined(PA_NO_WDMKS)
|
|
||||||
#error "Portaudio: PA_NO_<APINAME> is no longer supported, please remove definition and use PA_USE_<APINAME> instead"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_ASIO
|
|
||||||
#define PA_USE_ASIO 0
|
|
||||||
#elif (PA_USE_ASIO != 0) && (PA_USE_ASIO != 1)
|
|
||||||
#undef PA_USE_ASIO
|
|
||||||
#define PA_USE_ASIO 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_DS
|
|
||||||
#define PA_USE_DS 0
|
|
||||||
#elif (PA_USE_DS != 0) && (PA_USE_DS != 1)
|
|
||||||
#undef PA_USE_DS
|
|
||||||
#define PA_USE_DS 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_WMME
|
|
||||||
#define PA_USE_WMME 0
|
|
||||||
#elif (PA_USE_WMME != 0) && (PA_USE_WMME != 1)
|
|
||||||
#undef PA_USE_WMME
|
|
||||||
#define PA_USE_WMME 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_WASAPI
|
|
||||||
#define PA_USE_WASAPI 0
|
|
||||||
#elif (PA_USE_WASAPI != 0) && (PA_USE_WASAPI != 1)
|
|
||||||
#undef PA_USE_WASAPI
|
|
||||||
#define PA_USE_WASAPI 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_WDMKS
|
|
||||||
#define PA_USE_WDMKS 0
|
|
||||||
#elif (PA_USE_WDMKS != 0) && (PA_USE_WDMKS != 1)
|
|
||||||
#undef PA_USE_WDMKS
|
|
||||||
#define PA_USE_WDMKS 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Set default values for Unix based APIs. */
|
|
||||||
#if defined(PA_NO_OSS) || defined(PA_NO_ALSA) || defined(PA_NO_JACK) || defined(PA_NO_COREAUDIO) || defined(PA_NO_SGI) || defined(PA_NO_ASIHPI)
|
|
||||||
#error "Portaudio: PA_NO_<APINAME> is no longer supported, please remove definition and use PA_USE_<APINAME> instead"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_OSS
|
|
||||||
#define PA_USE_OSS 0
|
|
||||||
#elif (PA_USE_OSS != 0) && (PA_USE_OSS != 1)
|
|
||||||
#undef PA_USE_OSS
|
|
||||||
#define PA_USE_OSS 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_ALSA
|
|
||||||
#define PA_USE_ALSA 0
|
|
||||||
#elif (PA_USE_ALSA != 0) && (PA_USE_ALSA != 1)
|
|
||||||
#undef PA_USE_ALSA
|
|
||||||
#define PA_USE_ALSA 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_JACK
|
|
||||||
#define PA_USE_JACK 0
|
|
||||||
#elif (PA_USE_JACK != 0) && (PA_USE_JACK != 1)
|
|
||||||
#undef PA_USE_JACK
|
|
||||||
#define PA_USE_JACK 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_SGI
|
|
||||||
#define PA_USE_SGI 0
|
|
||||||
#elif (PA_USE_SGI != 0) && (PA_USE_SGI != 1)
|
|
||||||
#undef PA_USE_SGI
|
|
||||||
#define PA_USE_SGI 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_COREAUDIO
|
|
||||||
#define PA_USE_COREAUDIO 0
|
|
||||||
#elif (PA_USE_COREAUDIO != 0) && (PA_USE_COREAUDIO != 1)
|
|
||||||
#undef PA_USE_COREAUDIO
|
|
||||||
#define PA_USE_COREAUDIO 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PA_USE_ASIHPI
|
|
||||||
#define PA_USE_ASIHPI 0
|
|
||||||
#elif (PA_USE_ASIHPI != 0) && (PA_USE_ASIHPI != 1)
|
|
||||||
#undef PA_USE_ASIHPI
|
|
||||||
#define PA_USE_ASIHPI 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
/** **FOR THE USE OF pa_front.c ONLY**
|
|
||||||
Do NOT use fields in this structure, they my change at any time.
|
|
||||||
Use functions defined in pa_util.h if you think you need functionality
|
|
||||||
which can be derived from here.
|
|
||||||
*/
|
|
||||||
typedef struct PaUtilPrivatePaFrontHostApiInfo {
|
|
||||||
|
|
||||||
|
|
||||||
unsigned long baseDeviceIndex;
|
|
||||||
}PaUtilPrivatePaFrontHostApiInfo;
|
|
||||||
|
|
||||||
|
|
||||||
/** The common header for all data structures whose pointers are passed through
|
|
||||||
the hostApiSpecificStreamInfo field of the PaStreamParameters structure.
|
|
||||||
Note that in order to keep the public PortAudio interface clean, this structure
|
|
||||||
is not used explicitly when declaring hostApiSpecificStreamInfo data structures.
|
|
||||||
However, some code in pa_front depends on the first 3 members being equivalent
|
|
||||||
with this structure.
|
|
||||||
@see PaStreamParameters
|
|
||||||
*/
|
|
||||||
typedef struct PaUtilHostApiSpecificStreamInfoHeader
|
|
||||||
{
|
|
||||||
unsigned long size; /**< size of whole structure including this header */
|
|
||||||
PaHostApiTypeId hostApiType; /**< host API for which this data is intended */
|
|
||||||
unsigned long version; /**< structure version */
|
|
||||||
} PaUtilHostApiSpecificStreamInfoHeader;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/** A structure representing the interface to a host API. Contains both
|
|
||||||
concrete data and pointers to functions which implement the interface.
|
|
||||||
*/
|
|
||||||
typedef struct PaUtilHostApiRepresentation {
|
|
||||||
PaUtilPrivatePaFrontHostApiInfo privatePaFrontInfo;
|
|
||||||
|
|
||||||
/** The host api implementation should populate the info field. In the
|
|
||||||
case of info.defaultInputDevice and info.defaultOutputDevice the
|
|
||||||
values stored should be 0 based indices within the host api's own
|
|
||||||
device index range (0 to deviceCount). These values will be converted
|
|
||||||
to global device indices by pa_front after PaUtilHostApiInitializer()
|
|
||||||
returns.
|
|
||||||
*/
|
|
||||||
PaHostApiInfo info;
|
|
||||||
|
|
||||||
PaDeviceInfo** deviceInfos;
|
|
||||||
|
|
||||||
/**
|
|
||||||
(*Terminate)() is guaranteed to be called with a valid <hostApi>
|
|
||||||
parameter, which was previously returned from the same implementation's
|
|
||||||
initializer.
|
|
||||||
*/
|
|
||||||
void (*Terminate)( struct PaUtilHostApiRepresentation *hostApi );
|
|
||||||
|
|
||||||
/**
|
|
||||||
The inputParameters and outputParameters pointers should not be saved
|
|
||||||
as they will not remain valid after OpenStream is called.
|
|
||||||
|
|
||||||
|
|
||||||
The following guarantees are made about parameters to (*OpenStream)():
|
|
||||||
|
|
||||||
[NOTE: the following list up to *END PA FRONT VALIDATIONS* should be
|
|
||||||
kept in sync with the one for ValidateOpenStreamParameters and
|
|
||||||
Pa_OpenStream in pa_front.c]
|
|
||||||
|
|
||||||
PaHostApiRepresentation *hostApi
|
|
||||||
- is valid for this implementation
|
|
||||||
|
|
||||||
PaStream** stream
|
|
||||||
- is non-null
|
|
||||||
|
|
||||||
- at least one of inputParameters & outputParmeters is valid (not NULL)
|
|
||||||
|
|
||||||
- if inputParameters & outputParmeters are both valid, that
|
|
||||||
inputParameters->device & outputParmeters->device both use the same host api
|
|
||||||
|
|
||||||
PaDeviceIndex inputParameters->device
|
|
||||||
- is within range (0 to Pa_CountDevices-1) Or:
|
|
||||||
- is paUseHostApiSpecificDeviceSpecification and
|
|
||||||
inputParameters->hostApiSpecificStreamInfo is non-NULL and refers
|
|
||||||
to a valid host api
|
|
||||||
|
|
||||||
int inputParameters->numChannels
|
|
||||||
- if inputParameters->device is not paUseHostApiSpecificDeviceSpecification, numInputChannels is > 0
|
|
||||||
- upper bound is NOT validated against device capabilities
|
|
||||||
|
|
||||||
PaSampleFormat inputParameters->sampleFormat
|
|
||||||
- is one of the sample formats defined in portaudio.h
|
|
||||||
|
|
||||||
void *inputParameters->hostApiSpecificStreamInfo
|
|
||||||
- if supplied its hostApi field matches the input device's host Api
|
|
||||||
|
|
||||||
PaDeviceIndex outputParmeters->device
|
|
||||||
- is within range (0 to Pa_CountDevices-1)
|
|
||||||
|
|
||||||
int outputParmeters->numChannels
|
|
||||||
- if inputDevice is valid, numInputChannels is > 0
|
|
||||||
- upper bound is NOT validated against device capabilities
|
|
||||||
|
|
||||||
PaSampleFormat outputParmeters->sampleFormat
|
|
||||||
- is one of the sample formats defined in portaudio.h
|
|
||||||
|
|
||||||
void *outputParmeters->hostApiSpecificStreamInfo
|
|
||||||
- if supplied its hostApi field matches the output device's host Api
|
|
||||||
|
|
||||||
double sampleRate
|
|
||||||
- is not an 'absurd' rate (less than 1000. or greater than 384000.)
|
|
||||||
- sampleRate is NOT validated against device capabilities
|
|
||||||
|
|
||||||
PaStreamFlags streamFlags
|
|
||||||
- unused platform neutral flags are zero
|
|
||||||
- paNeverDropInput is only used for full-duplex callback streams
|
|
||||||
with variable buffer size (paFramesPerBufferUnspecified)
|
|
||||||
|
|
||||||
[*END PA FRONT VALIDATIONS*]
|
|
||||||
|
|
||||||
|
|
||||||
The following validations MUST be performed by (*OpenStream)():
|
|
||||||
|
|
||||||
- check that input device can support numInputChannels
|
|
||||||
|
|
||||||
- check that input device can support inputSampleFormat, or that
|
|
||||||
we have the capability to convert from outputSampleFormat to
|
|
||||||
a native format
|
|
||||||
|
|
||||||
- if inputStreamInfo is supplied, validate its contents,
|
|
||||||
or return an error if no inputStreamInfo is expected
|
|
||||||
|
|
||||||
- check that output device can support numOutputChannels
|
|
||||||
|
|
||||||
- check that output device can support outputSampleFormat, or that
|
|
||||||
we have the capability to convert from outputSampleFormat to
|
|
||||||
a native format
|
|
||||||
|
|
||||||
- if outputStreamInfo is supplied, validate its contents,
|
|
||||||
or return an error if no outputStreamInfo is expected
|
|
||||||
|
|
||||||
- if a full duplex stream is requested, check that the combination
|
|
||||||
of input and output parameters is supported
|
|
||||||
|
|
||||||
- check that the device supports sampleRate
|
|
||||||
|
|
||||||
- alter sampleRate to a close allowable rate if necessary
|
|
||||||
|
|
||||||
- validate inputLatency and outputLatency
|
|
||||||
|
|
||||||
- validate any platform specific flags, if flags are supplied they
|
|
||||||
must be valid.
|
|
||||||
*/
|
|
||||||
PaError (*OpenStream)( struct PaUtilHostApiRepresentation *hostApi,
|
|
||||||
PaStream** stream,
|
|
||||||
const PaStreamParameters *inputParameters,
|
|
||||||
const PaStreamParameters *outputParameters,
|
|
||||||
double sampleRate,
|
|
||||||
unsigned long framesPerCallback,
|
|
||||||
PaStreamFlags streamFlags,
|
|
||||||
PaStreamCallback *streamCallback,
|
|
||||||
void *userData );
|
|
||||||
|
|
||||||
|
|
||||||
PaError (*IsFormatSupported)( struct PaUtilHostApiRepresentation *hostApi,
|
|
||||||
const PaStreamParameters *inputParameters,
|
|
||||||
const PaStreamParameters *outputParameters,
|
|
||||||
double sampleRate );
|
|
||||||
} PaUtilHostApiRepresentation;
|
|
||||||
|
|
||||||
|
|
||||||
/** Prototype for the initialization function which must be implemented by every
|
|
||||||
host API.
|
|
||||||
|
|
||||||
This function should only return an error other than paNoError if it encounters
|
|
||||||
an unexpected and fatal error (memory allocation error for example). In general,
|
|
||||||
there may be conditions under which it returns a NULL interface pointer and also
|
|
||||||
returns paNoError. For example, if the ASIO implementation detects that ASIO is
|
|
||||||
not installed, it should return a NULL interface, and paNoError.
|
|
||||||
|
|
||||||
@see paHostApiInitializers
|
|
||||||
*/
|
|
||||||
typedef PaError PaUtilHostApiInitializer( PaUtilHostApiRepresentation**, PaHostApiIndex );
|
|
||||||
|
|
||||||
|
|
||||||
/** paHostApiInitializers is a NULL-terminated array of host API initialization
|
|
||||||
functions. These functions are called by pa_front.c to initialize the host APIs
|
|
||||||
when the client calls Pa_Initialize().
|
|
||||||
|
|
||||||
The initialization functions are invoked in order.
|
|
||||||
|
|
||||||
The first successfully initialized host API that has a default input *or* output
|
|
||||||
device is used as the default PortAudio host API. This is based on the logic that
|
|
||||||
there is only one default host API, and it must contain the default input and output
|
|
||||||
devices (if defined).
|
|
||||||
|
|
||||||
There is a platform specific file that defines paHostApiInitializers for that
|
|
||||||
platform, pa_win/pa_win_hostapis.c contains the Win32 definitions for example.
|
|
||||||
*/
|
|
||||||
extern PaUtilHostApiInitializer *paHostApiInitializers[];
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_HOSTAPI_H */
|
|
|
@ -1,128 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id: pa_memorybarrier.h 1240 2007-07-17 13:05:07Z bjornroche $
|
|
||||||
* Portable Audio I/O Library
|
|
||||||
* Memory barrier utilities
|
|
||||||
*
|
|
||||||
* Author: Bjorn Roche, XO Audio, LLC
|
|
||||||
*
|
|
||||||
* This program uses the PortAudio Portable Audio Library.
|
|
||||||
* For more information see: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@file pa_memorybarrier.h
|
|
||||||
@ingroup common_src
|
|
||||||
*/
|
|
||||||
|
|
||||||
/****************
|
|
||||||
* Some memory barrier primitives based on the system.
|
|
||||||
* right now only OS X, FreeBSD, and Linux are supported. In addition to providing
|
|
||||||
* memory barriers, these functions should ensure that data cached in registers
|
|
||||||
* is written out to cache where it can be snooped by other CPUs. (ie, the volatile
|
|
||||||
* keyword should not be required)
|
|
||||||
*
|
|
||||||
* the primitives that must be defined are:
|
|
||||||
*
|
|
||||||
* PaUtil_FullMemoryBarrier()
|
|
||||||
* PaUtil_ReadMemoryBarrier()
|
|
||||||
* PaUtil_WriteMemoryBarrier()
|
|
||||||
*
|
|
||||||
****************/
|
|
||||||
|
|
||||||
#if defined(__APPLE__)
|
|
||||||
# include <libkern/OSAtomic.h>
|
|
||||||
/* Here are the memory barrier functions. Mac OS X only provides
|
|
||||||
full memory barriers, so the three types of barriers are the same,
|
|
||||||
however, these barriers are superior to compiler-based ones. */
|
|
||||||
# define PaUtil_FullMemoryBarrier() OSMemoryBarrier()
|
|
||||||
# define PaUtil_ReadMemoryBarrier() OSMemoryBarrier()
|
|
||||||
# define PaUtil_WriteMemoryBarrier() OSMemoryBarrier()
|
|
||||||
#elif defined(__GNUC__)
|
|
||||||
/* GCC >= 4.1 has built-in intrinsics. We'll use those */
|
|
||||||
# if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 1)
|
|
||||||
# define PaUtil_FullMemoryBarrier() __sync_synchronize()
|
|
||||||
# define PaUtil_ReadMemoryBarrier() __sync_synchronize()
|
|
||||||
# define PaUtil_WriteMemoryBarrier() __sync_synchronize()
|
|
||||||
/* as a fallback, GCC understands volatile asm and "memory" to mean it
|
|
||||||
* should not reorder memory read/writes */
|
|
||||||
/* Note that it is not clear that any compiler actually defines __PPC__,
|
|
||||||
* it can probably removed safely. */
|
|
||||||
# elif defined( __ppc__ ) || defined( __powerpc__) || defined( __PPC__ )
|
|
||||||
# define PaUtil_FullMemoryBarrier() asm volatile("sync":::"memory")
|
|
||||||
# define PaUtil_ReadMemoryBarrier() asm volatile("sync":::"memory")
|
|
||||||
# define PaUtil_WriteMemoryBarrier() asm volatile("sync":::"memory")
|
|
||||||
# elif defined( __i386__ ) || defined( __i486__ ) || defined( __i586__ ) || \
|
|
||||||
defined( __i686__ ) || defined( __x86_64__ )
|
|
||||||
# define PaUtil_FullMemoryBarrier() asm volatile("mfence":::"memory")
|
|
||||||
# define PaUtil_ReadMemoryBarrier() asm volatile("lfence":::"memory")
|
|
||||||
# define PaUtil_WriteMemoryBarrier() asm volatile("sfence":::"memory")
|
|
||||||
# else
|
|
||||||
# ifdef ALLOW_SMP_DANGERS
|
|
||||||
# warning Memory barriers not defined on this system or system unknown
|
|
||||||
# warning For SMP safety, you should fix this.
|
|
||||||
# define PaUtil_FullMemoryBarrier()
|
|
||||||
# define PaUtil_ReadMemoryBarrier()
|
|
||||||
# define PaUtil_WriteMemoryBarrier()
|
|
||||||
# else
|
|
||||||
# error Memory barriers are not defined on this system. You can still compile by defining ALLOW_SMP_DANGERS, but SMP safety will not be guaranteed.
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
#elif (_MSC_VER >= 1400) && !defined(_WIN32_WCE)
|
|
||||||
# include <intrin.h>
|
|
||||||
# pragma intrinsic(_ReadWriteBarrier)
|
|
||||||
# pragma intrinsic(_ReadBarrier)
|
|
||||||
# pragma intrinsic(_WriteBarrier)
|
|
||||||
/* note that MSVC intrinsics _ReadWriteBarrier(), _ReadBarrier(), _WriteBarrier() are just compiler barriers *not* memory barriers */
|
|
||||||
# define PaUtil_FullMemoryBarrier() _ReadWriteBarrier()
|
|
||||||
# define PaUtil_ReadMemoryBarrier() _ReadBarrier()
|
|
||||||
# define PaUtil_WriteMemoryBarrier() _WriteBarrier()
|
|
||||||
#elif defined(_WIN32_WCE)
|
|
||||||
# define PaUtil_FullMemoryBarrier()
|
|
||||||
# define PaUtil_ReadMemoryBarrier()
|
|
||||||
# define PaUtil_WriteMemoryBarrier()
|
|
||||||
#elif defined(_MSC_VER) || defined(__BORLANDC__)
|
|
||||||
# define PaUtil_FullMemoryBarrier() _asm { lock add [esp], 0 }
|
|
||||||
# define PaUtil_ReadMemoryBarrier() _asm { lock add [esp], 0 }
|
|
||||||
# define PaUtil_WriteMemoryBarrier() _asm { lock add [esp], 0 }
|
|
||||||
#else
|
|
||||||
# ifdef ALLOW_SMP_DANGERS
|
|
||||||
# warning Memory barriers not defined on this system or system unknown
|
|
||||||
# warning For SMP safety, you should fix this.
|
|
||||||
# define PaUtil_FullMemoryBarrier()
|
|
||||||
# define PaUtil_ReadMemoryBarrier()
|
|
||||||
# define PaUtil_WriteMemoryBarrier()
|
|
||||||
# else
|
|
||||||
# error Memory barriers are not defined on this system. You can still compile by defining ALLOW_SMP_DANGERS, but SMP safety will not be guaranteed.
|
|
||||||
# endif
|
|
||||||
#endif
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,754 +0,0 @@
|
||||||
#ifndef PA_PROCESS_H
|
|
||||||
#define PA_PROCESS_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library callback buffer processing adapters
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2002 Phil Burk, Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Buffer Processor prototypes. A Buffer Processor performs buffer length
|
|
||||||
adaption, coordinates sample format conversion, and interleaves/deinterleaves
|
|
||||||
channels.
|
|
||||||
|
|
||||||
<h3>Overview</h3>
|
|
||||||
|
|
||||||
The "Buffer Processor" (PaUtilBufferProcessor) manages conversion of audio
|
|
||||||
data from host buffers to user buffers and back again. Where required, the
|
|
||||||
buffer processor takes care of converting between host and user sample formats,
|
|
||||||
interleaving and deinterleaving multichannel buffers, and adapting between host
|
|
||||||
and user buffers with different lengths. The buffer processor may be used with
|
|
||||||
full and half duplex streams, for both callback streams and blocking read/write
|
|
||||||
streams.
|
|
||||||
|
|
||||||
One of the important capabilities provided by the buffer processor is
|
|
||||||
the ability to adapt between user and host buffer sizes of different lengths
|
|
||||||
with minimum latency. Although this task is relatively easy to perform when
|
|
||||||
the host buffer size is an integer multiple of the user buffer size, the
|
|
||||||
problem is more complicated when this is not the case - especially for
|
|
||||||
full-duplex callback streams. Where necessary the adaption is implemented by
|
|
||||||
internally buffering some input and/or output data. The buffer adation
|
|
||||||
algorithm used by the buffer processor was originally implemented by
|
|
||||||
Stephan Letz for the ASIO version of PortAudio, and is described in his
|
|
||||||
Callback_adaption_.pdf which is included in the distribution.
|
|
||||||
|
|
||||||
The buffer processor performs sample conversion using the functions provided
|
|
||||||
by pa_converters.c.
|
|
||||||
|
|
||||||
The following sections provide an overview of how to use the buffer processor.
|
|
||||||
Interested readers are advised to consult the host API implementations for
|
|
||||||
examples of buffer processor usage.
|
|
||||||
|
|
||||||
|
|
||||||
<h4>Initialization, resetting and termination</h4>
|
|
||||||
|
|
||||||
When a stream is opened, the buffer processor should be initialized using
|
|
||||||
PaUtil_InitializeBufferProcessor. This function initializes internal state
|
|
||||||
and allocates temporary buffers as necessary according to the supplied
|
|
||||||
configuration parameters. Some of the parameters correspond to those requested
|
|
||||||
by the user in their call to Pa_OpenStream(), others reflect the requirements
|
|
||||||
of the host API implementation - they indicate host buffer sizes, formats,
|
|
||||||
and the type of buffering which the Host API uses. The buffer processor should
|
|
||||||
be initialized for callback streams and blocking read/write streams.
|
|
||||||
|
|
||||||
Call PaUtil_ResetBufferProcessor to clear any sample data which is present
|
|
||||||
in the buffer processor before starting to use it (for example when
|
|
||||||
Pa_StartStream is called).
|
|
||||||
|
|
||||||
When the buffer processor is no longer used call
|
|
||||||
PaUtil_TerminateBufferProcessor.
|
|
||||||
|
|
||||||
|
|
||||||
<h4>Using the buffer processor for a callback stream</h4>
|
|
||||||
|
|
||||||
The buffer processor's role in a callback stream is to take host input buffers
|
|
||||||
process them with the stream callback, and fill host output buffers. For a
|
|
||||||
full duplex stream, the buffer processor handles input and output simultaneously
|
|
||||||
due to the requirements of the minimum-latency buffer adation algorithm.
|
|
||||||
|
|
||||||
When a host buffer becomes available, the implementation should call
|
|
||||||
the buffer processor to process the buffer. The buffer processor calls the
|
|
||||||
stream callback to consume and/or produce audio data as necessary. The buffer
|
|
||||||
processor will convert sample formats, interleave/deinterleave channels,
|
|
||||||
and slice or chunk the data to the appropriate buffer lengths according to
|
|
||||||
the requirements of the stream callback and the host API.
|
|
||||||
|
|
||||||
To process a host buffer (or a pair of host buffers for a full-duplex stream)
|
|
||||||
use the following calling sequence:
|
|
||||||
|
|
||||||
-# Call PaUtil_BeginBufferProcessing
|
|
||||||
-# For a stream which takes input:
|
|
||||||
- Call PaUtil_SetInputFrameCount with the number of frames in the host input
|
|
||||||
buffer.
|
|
||||||
- Call one of the following functions one or more times to tell the
|
|
||||||
buffer processor about the host input buffer(s): PaUtil_SetInputChannel,
|
|
||||||
PaUtil_SetInterleavedInputChannels, PaUtil_SetNonInterleavedInputChannel.
|
|
||||||
Which function you call will depend on whether the host buffer(s) are
|
|
||||||
interleaved or not.
|
|
||||||
- If the available host data is split across two buffers (for example a
|
|
||||||
data range at the end of a circular buffer and another range at the
|
|
||||||
beginning of the circular buffer), also call
|
|
||||||
PaUtil_Set2ndInputFrameCount, PaUtil_Set2ndInputChannel,
|
|
||||||
PaUtil_Set2ndInterleavedInputChannels,
|
|
||||||
PaUtil_Set2ndNonInterleavedInputChannel as necessary to tell the buffer
|
|
||||||
processor about the second buffer.
|
|
||||||
-# For a stream which generates output:
|
|
||||||
- Call PaUtil_SetOutputFrameCount with the number of frames in the host
|
|
||||||
output buffer.
|
|
||||||
- Call one of the following functions one or more times to tell the
|
|
||||||
buffer processor about the host output buffer(s): PaUtil_SetOutputChannel,
|
|
||||||
PaUtil_SetInterleavedOutputChannels, PaUtil_SetNonInterleavedOutputChannel.
|
|
||||||
Which function you call will depend on whether the host buffer(s) are
|
|
||||||
interleaved or not.
|
|
||||||
- If the available host output buffer space is split across two buffers
|
|
||||||
(for example a data range at the end of a circular buffer and another
|
|
||||||
range at the beginning of the circular buffer), call
|
|
||||||
PaUtil_Set2ndOutputFrameCount, PaUtil_Set2ndOutputChannel,
|
|
||||||
PaUtil_Set2ndInterleavedOutputChannels,
|
|
||||||
PaUtil_Set2ndNonInterleavedOutputChannel as necessary to tell the buffer
|
|
||||||
processor about the second buffer.
|
|
||||||
-# Call PaUtil_EndBufferProcessing, this function performs the actual data
|
|
||||||
conversion and processing.
|
|
||||||
|
|
||||||
|
|
||||||
<h4>Using the buffer processor for a blocking read/write stream</h4>
|
|
||||||
|
|
||||||
Blocking read/write streams use the buffer processor to convert and copy user
|
|
||||||
output data to a host buffer, and to convert and copy host input data to
|
|
||||||
the user's buffer. The buffer processor does not perform any buffer adaption.
|
|
||||||
When using the buffer processor in a blocking read/write stream the input and
|
|
||||||
output conversion are performed separately by the PaUtil_CopyInput and
|
|
||||||
PaUtil_CopyOutput functions.
|
|
||||||
|
|
||||||
To copy data from a host input buffer to the buffer(s) which the user supplies
|
|
||||||
to Pa_ReadStream, use the following calling sequence.
|
|
||||||
|
|
||||||
- Repeat the following three steps until the user buffer(s) have been filled
|
|
||||||
with samples from the host input buffers:
|
|
||||||
-# Call PaUtil_SetInputFrameCount with the number of frames in the host
|
|
||||||
input buffer.
|
|
||||||
-# Call one of the following functions one or more times to tell the
|
|
||||||
buffer processor about the host input buffer(s): PaUtil_SetInputChannel,
|
|
||||||
PaUtil_SetInterleavedInputChannels, PaUtil_SetNonInterleavedInputChannel.
|
|
||||||
Which function you call will depend on whether the host buffer(s) are
|
|
||||||
interleaved or not.
|
|
||||||
-# Call PaUtil_CopyInput with the user buffer pointer (or a copy of the
|
|
||||||
array of buffer pointers for a non-interleaved stream) passed to
|
|
||||||
Pa_ReadStream, along with the number of frames in the user buffer(s).
|
|
||||||
Be careful to pass a <i>copy</i> of the user buffer pointers to
|
|
||||||
PaUtil_CopyInput because PaUtil_CopyInput advances the pointers to
|
|
||||||
the start of the next region to copy.
|
|
||||||
- PaUtil_CopyInput will not copy more data than is available in the
|
|
||||||
host buffer(s), so the above steps need to be repeated until the user
|
|
||||||
buffer(s) are full.
|
|
||||||
|
|
||||||
|
|
||||||
To copy data to the host output buffer from the user buffers(s) supplied
|
|
||||||
to Pa_WriteStream use the following calling sequence.
|
|
||||||
|
|
||||||
- Repeat the following three steps until all frames from the user buffer(s)
|
|
||||||
have been copied to the host API:
|
|
||||||
-# Call PaUtil_SetOutputFrameCount with the number of frames in the host
|
|
||||||
output buffer.
|
|
||||||
-# Call one of the following functions one or more times to tell the
|
|
||||||
buffer processor about the host output buffer(s): PaUtil_SetOutputChannel,
|
|
||||||
PaUtil_SetInterleavedOutputChannels, PaUtil_SetNonInterleavedOutputChannel.
|
|
||||||
Which function you call will depend on whether the host buffer(s) are
|
|
||||||
interleaved or not.
|
|
||||||
-# Call PaUtil_CopyOutput with the user buffer pointer (or a copy of the
|
|
||||||
array of buffer pointers for a non-interleaved stream) passed to
|
|
||||||
Pa_WriteStream, along with the number of frames in the user buffer(s).
|
|
||||||
Be careful to pass a <i>copy</i> of the user buffer pointers to
|
|
||||||
PaUtil_CopyOutput because PaUtil_CopyOutput advances the pointers to
|
|
||||||
the start of the next region to copy.
|
|
||||||
- PaUtil_CopyOutput will not copy more data than fits in the host buffer(s),
|
|
||||||
so the above steps need to be repeated until all user data is copied.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
#include "pa_converters.h"
|
|
||||||
#include "pa_dither.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
/** @brief Mode flag passed to PaUtil_InitializeBufferProcessor indicating the type
|
|
||||||
of buffering that the host API uses.
|
|
||||||
|
|
||||||
The mode used depends on whether the host API or the implementation manages
|
|
||||||
the buffers, and how these buffers are used (scatter gather, circular buffer).
|
|
||||||
*/
|
|
||||||
typedef enum {
|
|
||||||
/** The host buffer size is a fixed known size. */
|
|
||||||
paUtilFixedHostBufferSize,
|
|
||||||
|
|
||||||
/** The host buffer size may vary, but has a known maximum size. */
|
|
||||||
paUtilBoundedHostBufferSize,
|
|
||||||
|
|
||||||
/** Nothing is known about the host buffer size. */
|
|
||||||
paUtilUnknownHostBufferSize,
|
|
||||||
|
|
||||||
/** The host buffer size varies, and the client does not require the buffer
|
|
||||||
processor to consume all of the input and fill all of the output buffer. This
|
|
||||||
is useful when the implementation has access to the host API's circular buffer
|
|
||||||
and only needs to consume/fill some of it, not necessarily all of it, with each
|
|
||||||
call to the buffer processor. This is the only mode where
|
|
||||||
PaUtil_EndBufferProcessing() may not consume the whole buffer.
|
|
||||||
*/
|
|
||||||
paUtilVariableHostBufferSizePartialUsageAllowed
|
|
||||||
}PaUtilHostBufferSizeMode;
|
|
||||||
|
|
||||||
|
|
||||||
/** @brief An auxiliary data structure used internally by the buffer processor
|
|
||||||
to represent host input and output buffers. */
|
|
||||||
typedef struct PaUtilChannelDescriptor{
|
|
||||||
void *data;
|
|
||||||
unsigned int stride; /**< stride in samples, not bytes */
|
|
||||||
}PaUtilChannelDescriptor;
|
|
||||||
|
|
||||||
|
|
||||||
/** @brief The main buffer processor data structure.
|
|
||||||
|
|
||||||
Allocate one of these, initialize it with PaUtil_InitializeBufferProcessor
|
|
||||||
and terminate it with PaUtil_TerminateBufferProcessor.
|
|
||||||
*/
|
|
||||||
typedef struct {
|
|
||||||
unsigned long framesPerUserBuffer;
|
|
||||||
unsigned long framesPerHostBuffer;
|
|
||||||
|
|
||||||
PaUtilHostBufferSizeMode hostBufferSizeMode;
|
|
||||||
int useNonAdaptingProcess;
|
|
||||||
int userOutputSampleFormatIsEqualToHost;
|
|
||||||
int userInputSampleFormatIsEqualToHost;
|
|
||||||
unsigned long framesPerTempBuffer;
|
|
||||||
|
|
||||||
unsigned int inputChannelCount;
|
|
||||||
unsigned int bytesPerHostInputSample;
|
|
||||||
unsigned int bytesPerUserInputSample;
|
|
||||||
int userInputIsInterleaved;
|
|
||||||
PaUtilConverter *inputConverter;
|
|
||||||
PaUtilZeroer *inputZeroer;
|
|
||||||
|
|
||||||
unsigned int outputChannelCount;
|
|
||||||
unsigned int bytesPerHostOutputSample;
|
|
||||||
unsigned int bytesPerUserOutputSample;
|
|
||||||
int userOutputIsInterleaved;
|
|
||||||
PaUtilConverter *outputConverter;
|
|
||||||
PaUtilZeroer *outputZeroer;
|
|
||||||
|
|
||||||
unsigned long initialFramesInTempInputBuffer;
|
|
||||||
unsigned long initialFramesInTempOutputBuffer;
|
|
||||||
|
|
||||||
void *tempInputBuffer; /**< used for slips, block adaption, and conversion. */
|
|
||||||
void **tempInputBufferPtrs; /**< storage for non-interleaved buffer pointers, NULL for interleaved user input */
|
|
||||||
unsigned long framesInTempInputBuffer; /**< frames remaining in input buffer from previous adaption iteration */
|
|
||||||
|
|
||||||
void *tempOutputBuffer; /**< used for slips, block adaption, and conversion. */
|
|
||||||
void **tempOutputBufferPtrs; /**< storage for non-interleaved buffer pointers, NULL for interleaved user output */
|
|
||||||
unsigned long framesInTempOutputBuffer; /**< frames remaining in input buffer from previous adaption iteration */
|
|
||||||
|
|
||||||
PaStreamCallbackTimeInfo *timeInfo;
|
|
||||||
|
|
||||||
PaStreamCallbackFlags callbackStatusFlags;
|
|
||||||
|
|
||||||
int hostInputIsInterleaved;
|
|
||||||
unsigned long hostInputFrameCount[2];
|
|
||||||
PaUtilChannelDescriptor *hostInputChannels[2]; /**< pointers to arrays of channel descriptors.
|
|
||||||
pointers are NULL for half-duplex output processing.
|
|
||||||
hostInputChannels[i].data is NULL when the caller
|
|
||||||
calls PaUtil_SetNoInput()
|
|
||||||
*/
|
|
||||||
int hostOutputIsInterleaved;
|
|
||||||
unsigned long hostOutputFrameCount[2];
|
|
||||||
PaUtilChannelDescriptor *hostOutputChannels[2]; /**< pointers to arrays of channel descriptors.
|
|
||||||
pointers are NULL for half-duplex input processing.
|
|
||||||
hostOutputChannels[i].data is NULL when the caller
|
|
||||||
calls PaUtil_SetNoOutput()
|
|
||||||
*/
|
|
||||||
|
|
||||||
PaUtilTriangularDitherGenerator ditherGenerator;
|
|
||||||
|
|
||||||
double samplePeriod;
|
|
||||||
|
|
||||||
PaStreamCallback *streamCallback;
|
|
||||||
void *userData;
|
|
||||||
} PaUtilBufferProcessor;
|
|
||||||
|
|
||||||
|
|
||||||
/** @name Initialization, termination, resetting and info */
|
|
||||||
/*@{*/
|
|
||||||
|
|
||||||
/** Initialize a buffer processor's representation stored in a
|
|
||||||
PaUtilBufferProcessor structure. Be sure to call
|
|
||||||
PaUtil_TerminateBufferProcessor after finishing with a buffer processor.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor structure to initialize.
|
|
||||||
|
|
||||||
@param inputChannelCount The number of input channels as passed to
|
|
||||||
Pa_OpenStream or 0 for an output-only stream.
|
|
||||||
|
|
||||||
@param userInputSampleFormat Format of user input samples, as passed to
|
|
||||||
Pa_OpenStream. This parameter is ignored for ouput-only streams.
|
|
||||||
|
|
||||||
@param hostInputSampleFormat Format of host input samples. This parameter is
|
|
||||||
ignored for output-only streams. See note about host buffer interleave below.
|
|
||||||
|
|
||||||
@param outputChannelCount The number of output channels as passed to
|
|
||||||
Pa_OpenStream or 0 for an input-only stream.
|
|
||||||
|
|
||||||
@param userOutputSampleFormat Format of user output samples, as passed to
|
|
||||||
Pa_OpenStream. This parameter is ignored for input-only streams.
|
|
||||||
|
|
||||||
@param hostOutputSampleFormat Format of host output samples. This parameter is
|
|
||||||
ignored for input-only streams. See note about host buffer interleave below.
|
|
||||||
|
|
||||||
@param sampleRate Sample rate of the stream. The more accurate this is the
|
|
||||||
better - it is used for updating time stamps when adapting buffers.
|
|
||||||
|
|
||||||
@param streamFlags Stream flags as passed to Pa_OpenStream, this parameter is
|
|
||||||
used for selecting special sample conversion options such as clipping and
|
|
||||||
dithering.
|
|
||||||
|
|
||||||
@param framesPerUserBuffer Number of frames per user buffer, as requested
|
|
||||||
by the framesPerBuffer parameter to Pa_OpenStream. This parameter may be
|
|
||||||
zero to indicate that the user will accept any (and varying) buffer sizes.
|
|
||||||
|
|
||||||
@param framesPerHostBuffer Specifies the number of frames per host buffer
|
|
||||||
for the fixed buffer size mode, and the maximum number of frames
|
|
||||||
per host buffer for the bounded host buffer size mode. It is ignored for
|
|
||||||
the other modes.
|
|
||||||
|
|
||||||
@param hostBufferSizeMode A mode flag indicating the size variability of
|
|
||||||
host buffers that will be passed to the buffer processor. See
|
|
||||||
PaUtilHostBufferSizeMode for further details.
|
|
||||||
|
|
||||||
@param streamCallback The user stream callback passed to Pa_OpenStream.
|
|
||||||
|
|
||||||
@param userData The user data field passed to Pa_OpenStream.
|
|
||||||
|
|
||||||
@note The interleave flag is ignored for host buffer formats. Host
|
|
||||||
interleave is determined by the use of different SetInput and SetOutput
|
|
||||||
functions.
|
|
||||||
|
|
||||||
@return An error code indicating whether the initialization was successful.
|
|
||||||
If the error code is not PaNoError, the buffer processor was not initialized
|
|
||||||
and should not be used.
|
|
||||||
|
|
||||||
@see Pa_OpenStream, PaUtilHostBufferSizeMode, PaUtil_TerminateBufferProcessor
|
|
||||||
*/
|
|
||||||
PaError PaUtil_InitializeBufferProcessor( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
int inputChannelCount, PaSampleFormat userInputSampleFormat,
|
|
||||||
PaSampleFormat hostInputSampleFormat,
|
|
||||||
int outputChannelCount, PaSampleFormat userOutputSampleFormat,
|
|
||||||
PaSampleFormat hostOutputSampleFormat,
|
|
||||||
double sampleRate,
|
|
||||||
PaStreamFlags streamFlags,
|
|
||||||
unsigned long framesPerUserBuffer, /* 0 indicates don't care */
|
|
||||||
unsigned long framesPerHostBuffer,
|
|
||||||
PaUtilHostBufferSizeMode hostBufferSizeMode,
|
|
||||||
PaStreamCallback *streamCallback, void *userData );
|
|
||||||
|
|
||||||
|
|
||||||
/** Terminate a buffer processor's representation. Deallocates any temporary
|
|
||||||
buffers allocated by PaUtil_InitializeBufferProcessor.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor structure to terminate.
|
|
||||||
|
|
||||||
@see PaUtil_InitializeBufferProcessor.
|
|
||||||
*/
|
|
||||||
void PaUtil_TerminateBufferProcessor( PaUtilBufferProcessor* bufferProcessor );
|
|
||||||
|
|
||||||
|
|
||||||
/** Clear any internally buffered data. If you call
|
|
||||||
PaUtil_InitializeBufferProcessor in your OpenStream routine, make sure you
|
|
||||||
call PaUtil_ResetBufferProcessor in your StartStream call.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor to reset.
|
|
||||||
*/
|
|
||||||
void PaUtil_ResetBufferProcessor( PaUtilBufferProcessor* bufferProcessor );
|
|
||||||
|
|
||||||
|
|
||||||
/** Retrieve the input latency of a buffer processor, in frames.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor examine.
|
|
||||||
|
|
||||||
@return The input latency introduced by the buffer processor, in frames.
|
|
||||||
|
|
||||||
@see PaUtil_GetBufferProcessorOutputLatencyFrames
|
|
||||||
*/
|
|
||||||
unsigned long PaUtil_GetBufferProcessorInputLatencyFrames( PaUtilBufferProcessor* bufferProcessor );
|
|
||||||
|
|
||||||
/** Retrieve the output latency of a buffer processor, in frames.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor examine.
|
|
||||||
|
|
||||||
@return The output latency introduced by the buffer processor, in frames.
|
|
||||||
|
|
||||||
@see PaUtil_GetBufferProcessorInputLatencyFrames
|
|
||||||
*/
|
|
||||||
unsigned long PaUtil_GetBufferProcessorOutputLatencyFrames( PaUtilBufferProcessor* bufferProcessor );
|
|
||||||
|
|
||||||
/*@}*/
|
|
||||||
|
|
||||||
|
|
||||||
/** @name Host buffer pointer configuration
|
|
||||||
|
|
||||||
Functions to set host input and output buffers, used by both callback streams
|
|
||||||
and blocking read/write streams.
|
|
||||||
*/
|
|
||||||
/*@{*/
|
|
||||||
|
|
||||||
|
|
||||||
/** Set the number of frames in the input host buffer(s) specified by the
|
|
||||||
PaUtil_Set*InputChannel functions.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
|
|
||||||
@param frameCount The number of host input frames. A 0 frameCount indicates to
|
|
||||||
use the framesPerHostBuffer value passed to PaUtil_InitializeBufferProcessor.
|
|
||||||
|
|
||||||
@see PaUtil_SetNoInput, PaUtil_SetInputChannel,
|
|
||||||
PaUtil_SetInterleavedInputChannels, PaUtil_SetNonInterleavedInputChannel
|
|
||||||
*/
|
|
||||||
void PaUtil_SetInputFrameCount( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned long frameCount );
|
|
||||||
|
|
||||||
|
|
||||||
/** Indicate that no input is available. This function should be used when
|
|
||||||
priming the output of a full-duplex stream opened with the
|
|
||||||
paPrimeOutputBuffersUsingStreamCallback flag. Note that it is not necessary
|
|
||||||
to call this or any other PaUtil_Set*Input* functions for ouput-only streams.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
*/
|
|
||||||
void PaUtil_SetNoInput( PaUtilBufferProcessor* bufferProcessor );
|
|
||||||
|
|
||||||
|
|
||||||
/** Provide the buffer processor with a pointer to a host input channel.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
@param channel The channel number.
|
|
||||||
@param data The buffer.
|
|
||||||
@param stride The stride from one sample to the next, in samples. For
|
|
||||||
interleaved host buffers, the stride will usually be the same as the number of
|
|
||||||
channels in the buffer.
|
|
||||||
*/
|
|
||||||
void PaUtil_SetInputChannel( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int channel, void *data, unsigned int stride );
|
|
||||||
|
|
||||||
|
|
||||||
/** Provide the buffer processor with a pointer to an number of interleaved
|
|
||||||
host input channels.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
@param firstChannel The first channel number.
|
|
||||||
@param data The buffer.
|
|
||||||
@param channelCount The number of interleaved channels in the buffer. If
|
|
||||||
channelCount is zero, the number of channels specified to
|
|
||||||
PaUtil_InitializeBufferProcessor will be used.
|
|
||||||
*/
|
|
||||||
void PaUtil_SetInterleavedInputChannels( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int firstChannel, void *data, unsigned int channelCount );
|
|
||||||
|
|
||||||
|
|
||||||
/** Provide the buffer processor with a pointer to one non-interleaved host
|
|
||||||
output channel.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
@param channel The channel number.
|
|
||||||
@param data The buffer.
|
|
||||||
*/
|
|
||||||
void PaUtil_SetNonInterleavedInputChannel( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int channel, void *data );
|
|
||||||
|
|
||||||
|
|
||||||
/** Use for the second buffer half when the input buffer is split in two halves.
|
|
||||||
@see PaUtil_SetInputFrameCount
|
|
||||||
*/
|
|
||||||
void PaUtil_Set2ndInputFrameCount( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned long frameCount );
|
|
||||||
|
|
||||||
/** Use for the second buffer half when the input buffer is split in two halves.
|
|
||||||
@see PaUtil_SetInputChannel
|
|
||||||
*/
|
|
||||||
void PaUtil_Set2ndInputChannel( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int channel, void *data, unsigned int stride );
|
|
||||||
|
|
||||||
/** Use for the second buffer half when the input buffer is split in two halves.
|
|
||||||
@see PaUtil_SetInterleavedInputChannels
|
|
||||||
*/
|
|
||||||
void PaUtil_Set2ndInterleavedInputChannels( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int firstChannel, void *data, unsigned int channelCount );
|
|
||||||
|
|
||||||
/** Use for the second buffer half when the input buffer is split in two halves.
|
|
||||||
@see PaUtil_SetNonInterleavedInputChannel
|
|
||||||
*/
|
|
||||||
void PaUtil_Set2ndNonInterleavedInputChannel( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int channel, void *data );
|
|
||||||
|
|
||||||
|
|
||||||
/** Set the number of frames in the output host buffer(s) specified by the
|
|
||||||
PaUtil_Set*OutputChannel functions.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
|
|
||||||
@param frameCount The number of host output frames. A 0 frameCount indicates to
|
|
||||||
use the framesPerHostBuffer value passed to PaUtil_InitializeBufferProcessor.
|
|
||||||
|
|
||||||
@see PaUtil_SetOutputChannel, PaUtil_SetInterleavedOutputChannels,
|
|
||||||
PaUtil_SetNonInterleavedOutputChannel
|
|
||||||
*/
|
|
||||||
void PaUtil_SetOutputFrameCount( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned long frameCount );
|
|
||||||
|
|
||||||
|
|
||||||
/** Indicate that the output will be discarded. This function should be used
|
|
||||||
when implementing the paNeverDropInput mode for full duplex streams.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
*/
|
|
||||||
void PaUtil_SetNoOutput( PaUtilBufferProcessor* bufferProcessor );
|
|
||||||
|
|
||||||
|
|
||||||
/** Provide the buffer processor with a pointer to a host output channel.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
@param channel The channel number.
|
|
||||||
@param data The buffer.
|
|
||||||
@param stride The stride from one sample to the next, in samples. For
|
|
||||||
interleaved host buffers, the stride will usually be the same as the number of
|
|
||||||
channels in the buffer.
|
|
||||||
*/
|
|
||||||
void PaUtil_SetOutputChannel( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int channel, void *data, unsigned int stride );
|
|
||||||
|
|
||||||
|
|
||||||
/** Provide the buffer processor with a pointer to a number of interleaved
|
|
||||||
host output channels.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
@param firstChannel The first channel number.
|
|
||||||
@param data The buffer.
|
|
||||||
@param channelCount The number of interleaved channels in the buffer. If
|
|
||||||
channelCount is zero, the number of channels specified to
|
|
||||||
PaUtil_InitializeBufferProcessor will be used.
|
|
||||||
*/
|
|
||||||
void PaUtil_SetInterleavedOutputChannels( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int firstChannel, void *data, unsigned int channelCount );
|
|
||||||
|
|
||||||
|
|
||||||
/** Provide the buffer processor with a pointer to one non-interleaved host
|
|
||||||
output channel.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
@param channel The channel number.
|
|
||||||
@param data The buffer.
|
|
||||||
*/
|
|
||||||
void PaUtil_SetNonInterleavedOutputChannel( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int channel, void *data );
|
|
||||||
|
|
||||||
|
|
||||||
/** Use for the second buffer half when the output buffer is split in two halves.
|
|
||||||
@see PaUtil_SetOutputFrameCount
|
|
||||||
*/
|
|
||||||
void PaUtil_Set2ndOutputFrameCount( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned long frameCount );
|
|
||||||
|
|
||||||
/** Use for the second buffer half when the output buffer is split in two halves.
|
|
||||||
@see PaUtil_SetOutputChannel
|
|
||||||
*/
|
|
||||||
void PaUtil_Set2ndOutputChannel( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int channel, void *data, unsigned int stride );
|
|
||||||
|
|
||||||
/** Use for the second buffer half when the output buffer is split in two halves.
|
|
||||||
@see PaUtil_SetInterleavedOutputChannels
|
|
||||||
*/
|
|
||||||
void PaUtil_Set2ndInterleavedOutputChannels( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int firstChannel, void *data, unsigned int channelCount );
|
|
||||||
|
|
||||||
/** Use for the second buffer half when the output buffer is split in two halves.
|
|
||||||
@see PaUtil_SetNonInterleavedOutputChannel
|
|
||||||
*/
|
|
||||||
void PaUtil_Set2ndNonInterleavedOutputChannel( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned int channel, void *data );
|
|
||||||
|
|
||||||
/*@}*/
|
|
||||||
|
|
||||||
|
|
||||||
/** @name Buffer processing functions for callback streams
|
|
||||||
*/
|
|
||||||
/*@{*/
|
|
||||||
|
|
||||||
/** Commence processing a host buffer (or a pair of host buffers in the
|
|
||||||
full-duplex case) for a callback stream.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
|
|
||||||
@param timeInfo Timing information for the first sample of the host
|
|
||||||
buffer(s). This information may be adjusted when buffer adaption is being
|
|
||||||
performed.
|
|
||||||
|
|
||||||
@param callbackStatusFlags Flags indicating whether underruns and overruns
|
|
||||||
have occurred since the last time the buffer processor was called.
|
|
||||||
*/
|
|
||||||
void PaUtil_BeginBufferProcessing( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
PaStreamCallbackTimeInfo* timeInfo, PaStreamCallbackFlags callbackStatusFlags );
|
|
||||||
|
|
||||||
|
|
||||||
/** Finish processing a host buffer (or a pair of host buffers in the
|
|
||||||
full-duplex case) for a callback stream.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
|
|
||||||
@param callbackResult On input, indicates a previous callback result, and on
|
|
||||||
exit, the result of the user stream callback, if it is called.
|
|
||||||
On entry callbackResult should contain one of { paContinue, paComplete, or
|
|
||||||
paAbort}. If paComplete is passed, the stream callback will not be called
|
|
||||||
but any audio that was generated by previous stream callbacks will be copied
|
|
||||||
to the output buffer(s). You can check whether the buffer processor's internal
|
|
||||||
buffer is empty by calling PaUtil_IsBufferProcessorOutputEmpty.
|
|
||||||
|
|
||||||
If the stream callback is called its result is stored in *callbackResult. If
|
|
||||||
the stream callback returns paComplete or paAbort, all output buffers will be
|
|
||||||
full of valid data - some of which may be zeros to account for data that
|
|
||||||
wasn't generated by the terminating callback.
|
|
||||||
|
|
||||||
@return The number of frames processed. This usually corresponds to the
|
|
||||||
number of frames specified by the PaUtil_Set*FrameCount functions, except in
|
|
||||||
the paUtilVariableHostBufferSizePartialUsageAllowed buffer size mode when a
|
|
||||||
smaller value may be returned.
|
|
||||||
*/
|
|
||||||
unsigned long PaUtil_EndBufferProcessing( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
int *callbackResult );
|
|
||||||
|
|
||||||
|
|
||||||
/** Determine whether any callback generated output remains in the buffer
|
|
||||||
processor's internal buffers. This method may be used to determine when to
|
|
||||||
continue calling PaUtil_EndBufferProcessing() after the callback has returned
|
|
||||||
a callbackResult of paComplete.
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
|
|
||||||
@return Returns non-zero when callback generated output remains in the internal
|
|
||||||
buffer and zero (0) when there internal buffer contains no callback generated
|
|
||||||
data.
|
|
||||||
*/
|
|
||||||
int PaUtil_IsBufferProcessorOutputEmpty( PaUtilBufferProcessor* bufferProcessor );
|
|
||||||
|
|
||||||
/*@}*/
|
|
||||||
|
|
||||||
|
|
||||||
/** @name Buffer processing functions for blocking read/write streams
|
|
||||||
*/
|
|
||||||
/*@{*/
|
|
||||||
|
|
||||||
/** Copy samples from host input channels set up by the PaUtil_Set*InputChannels
|
|
||||||
functions to a user supplied buffer. This function is intended for use with
|
|
||||||
blocking read/write streams. Copies the minimum of the number of
|
|
||||||
user frames (specified by the frameCount parameter) and the number of available
|
|
||||||
host frames (specified in a previous call to SetInputFrameCount()).
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
|
|
||||||
@param buffer A pointer to the user buffer pointer, or a pointer to a pointer
|
|
||||||
to an array of user buffer pointers for a non-interleaved stream. It is
|
|
||||||
important that this parameter points to a copy of the user buffer pointers,
|
|
||||||
not to the actual user buffer pointers, because this function updates the
|
|
||||||
pointers before returning.
|
|
||||||
|
|
||||||
@param frameCount The number of frames of data in the buffer(s) pointed to by
|
|
||||||
the buffer parameter.
|
|
||||||
|
|
||||||
@return The number of frames copied. The buffer pointer(s) pointed to by the
|
|
||||||
buffer parameter are advanced to point to the frame(s) following the last one
|
|
||||||
filled.
|
|
||||||
*/
|
|
||||||
unsigned long PaUtil_CopyInput( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
void **buffer, unsigned long frameCount );
|
|
||||||
|
|
||||||
|
|
||||||
/* Copy samples from a user supplied buffer to host output channels set up by
|
|
||||||
the PaUtil_Set*OutputChannels functions. This function is intended for use with
|
|
||||||
blocking read/write streams. Copies the minimum of the number of
|
|
||||||
user frames (specified by the frameCount parameter) and the number of
|
|
||||||
host frames (specified in a previous call to SetOutputFrameCount()).
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
|
|
||||||
@param buffer A pointer to the user buffer pointer, or a pointer to a pointer
|
|
||||||
to an array of user buffer pointers for a non-interleaved stream. It is
|
|
||||||
important that this parameter points to a copy of the user buffer pointers,
|
|
||||||
not to the actual user buffer pointers, because this function updates the
|
|
||||||
pointers before returning.
|
|
||||||
|
|
||||||
@param frameCount The number of frames of data in the buffer(s) pointed to by
|
|
||||||
the buffer parameter.
|
|
||||||
|
|
||||||
@return The number of frames copied. The buffer pointer(s) pointed to by the
|
|
||||||
buffer parameter are advanced to point to the frame(s) following the last one
|
|
||||||
copied.
|
|
||||||
*/
|
|
||||||
unsigned long PaUtil_CopyOutput( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
const void ** buffer, unsigned long frameCount );
|
|
||||||
|
|
||||||
|
|
||||||
/* Zero samples in host output channels set up by the PaUtil_Set*OutputChannels
|
|
||||||
functions. This function is useful for flushing streams.
|
|
||||||
Zeros the minimum of frameCount and the number of host frames specified in a
|
|
||||||
previous call to SetOutputFrameCount().
|
|
||||||
|
|
||||||
@param bufferProcessor The buffer processor.
|
|
||||||
|
|
||||||
@param frameCount The maximum number of frames to zero.
|
|
||||||
|
|
||||||
@return The number of frames zeroed.
|
|
||||||
*/
|
|
||||||
unsigned long PaUtil_ZeroOutput( PaUtilBufferProcessor* bufferProcessor,
|
|
||||||
unsigned long frameCount );
|
|
||||||
|
|
||||||
|
|
||||||
/*@}*/
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_PROCESS_H */
|
|
|
@ -1,237 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library
|
|
||||||
* Ring Buffer utility.
|
|
||||||
*
|
|
||||||
* Author: Phil Burk, http://www.softsynth.com
|
|
||||||
* modified for SMP safety on Mac OS X by Bjorn Roche
|
|
||||||
* modified for SMP safety on Linux by Leland Lucius
|
|
||||||
* also, allowed for const where possible
|
|
||||||
* modified for multiple-byte-sized data elements by Sven Fischer
|
|
||||||
*
|
|
||||||
* Note that this is safe only for a single-thread reader and a
|
|
||||||
* single-thread writer.
|
|
||||||
*
|
|
||||||
* This program uses the PortAudio Portable Audio Library.
|
|
||||||
* For more information see: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@file
|
|
||||||
@ingroup common_src
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <math.h>
|
|
||||||
#include "pa_ringbuffer.h"
|
|
||||||
#include <string.h>
|
|
||||||
#include "pa_memorybarrier.h"
|
|
||||||
|
|
||||||
/***************************************************************************
|
|
||||||
* Initialize FIFO.
|
|
||||||
* elementCount must be power of 2, returns -1 if not.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_InitializeRingBuffer( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementSizeBytes, ring_buffer_size_t elementCount, void *dataPtr )
|
|
||||||
{
|
|
||||||
if( ((elementCount-1) & elementCount) != 0) return -1; /* Not Power of two. */
|
|
||||||
rbuf->bufferSize = elementCount;
|
|
||||||
rbuf->buffer = (char *)dataPtr;
|
|
||||||
PaUtil_FlushRingBuffer( rbuf );
|
|
||||||
rbuf->bigMask = (elementCount*2)-1;
|
|
||||||
rbuf->smallMask = (elementCount)-1;
|
|
||||||
rbuf->elementSizeBytes = elementSizeBytes;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***************************************************************************
|
|
||||||
** Return number of elements available for reading. */
|
|
||||||
ring_buffer_size_t PaUtil_GetRingBufferReadAvailable( const PaUtilRingBuffer *rbuf )
|
|
||||||
{
|
|
||||||
return ( (rbuf->writeIndex - rbuf->readIndex) & rbuf->bigMask );
|
|
||||||
}
|
|
||||||
/***************************************************************************
|
|
||||||
** Return number of elements available for writing. */
|
|
||||||
ring_buffer_size_t PaUtil_GetRingBufferWriteAvailable( const PaUtilRingBuffer *rbuf )
|
|
||||||
{
|
|
||||||
return ( rbuf->bufferSize - PaUtil_GetRingBufferReadAvailable(rbuf));
|
|
||||||
}
|
|
||||||
|
|
||||||
/***************************************************************************
|
|
||||||
** Clear buffer. Should only be called when buffer is NOT being read or written. */
|
|
||||||
void PaUtil_FlushRingBuffer( PaUtilRingBuffer *rbuf )
|
|
||||||
{
|
|
||||||
rbuf->writeIndex = rbuf->readIndex = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***************************************************************************
|
|
||||||
** Get address of region(s) to which we can write data.
|
|
||||||
** If the region is contiguous, size2 will be zero.
|
|
||||||
** If non-contiguous, size2 will be the size of second region.
|
|
||||||
** Returns room available to be written or elementCount, whichever is smaller.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_GetRingBufferWriteRegions( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementCount,
|
|
||||||
void **dataPtr1, ring_buffer_size_t *sizePtr1,
|
|
||||||
void **dataPtr2, ring_buffer_size_t *sizePtr2 )
|
|
||||||
{
|
|
||||||
ring_buffer_size_t index;
|
|
||||||
ring_buffer_size_t available = PaUtil_GetRingBufferWriteAvailable( rbuf );
|
|
||||||
if( elementCount > available ) elementCount = available;
|
|
||||||
/* Check to see if write is not contiguous. */
|
|
||||||
index = rbuf->writeIndex & rbuf->smallMask;
|
|
||||||
if( (index + elementCount) > rbuf->bufferSize )
|
|
||||||
{
|
|
||||||
/* Write data in two blocks that wrap the buffer. */
|
|
||||||
ring_buffer_size_t firstHalf = rbuf->bufferSize - index;
|
|
||||||
*dataPtr1 = &rbuf->buffer[index*rbuf->elementSizeBytes];
|
|
||||||
*sizePtr1 = firstHalf;
|
|
||||||
*dataPtr2 = &rbuf->buffer[0];
|
|
||||||
*sizePtr2 = elementCount - firstHalf;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*dataPtr1 = &rbuf->buffer[index*rbuf->elementSizeBytes];
|
|
||||||
*sizePtr1 = elementCount;
|
|
||||||
*dataPtr2 = NULL;
|
|
||||||
*sizePtr2 = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if( available )
|
|
||||||
PaUtil_FullMemoryBarrier(); /* (write-after-read) => full barrier */
|
|
||||||
|
|
||||||
return elementCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/***************************************************************************
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_AdvanceRingBufferWriteIndex( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementCount )
|
|
||||||
{
|
|
||||||
/* ensure that previous writes are seen before we update the write index
|
|
||||||
(write after write)
|
|
||||||
*/
|
|
||||||
PaUtil_WriteMemoryBarrier();
|
|
||||||
return rbuf->writeIndex = (rbuf->writeIndex + elementCount) & rbuf->bigMask;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***************************************************************************
|
|
||||||
** Get address of region(s) from which we can read data.
|
|
||||||
** If the region is contiguous, size2 will be zero.
|
|
||||||
** If non-contiguous, size2 will be the size of second region.
|
|
||||||
** Returns room available to be read or elementCount, whichever is smaller.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_GetRingBufferReadRegions( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementCount,
|
|
||||||
void **dataPtr1, ring_buffer_size_t *sizePtr1,
|
|
||||||
void **dataPtr2, ring_buffer_size_t *sizePtr2 )
|
|
||||||
{
|
|
||||||
ring_buffer_size_t index;
|
|
||||||
ring_buffer_size_t available = PaUtil_GetRingBufferReadAvailable( rbuf ); /* doesn't use memory barrier */
|
|
||||||
if( elementCount > available ) elementCount = available;
|
|
||||||
/* Check to see if read is not contiguous. */
|
|
||||||
index = rbuf->readIndex & rbuf->smallMask;
|
|
||||||
if( (index + elementCount) > rbuf->bufferSize )
|
|
||||||
{
|
|
||||||
/* Write data in two blocks that wrap the buffer. */
|
|
||||||
ring_buffer_size_t firstHalf = rbuf->bufferSize - index;
|
|
||||||
*dataPtr1 = &rbuf->buffer[index*rbuf->elementSizeBytes];
|
|
||||||
*sizePtr1 = firstHalf;
|
|
||||||
*dataPtr2 = &rbuf->buffer[0];
|
|
||||||
*sizePtr2 = elementCount - firstHalf;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*dataPtr1 = &rbuf->buffer[index*rbuf->elementSizeBytes];
|
|
||||||
*sizePtr1 = elementCount;
|
|
||||||
*dataPtr2 = NULL;
|
|
||||||
*sizePtr2 = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if( available )
|
|
||||||
PaUtil_ReadMemoryBarrier(); /* (read-after-read) => read barrier */
|
|
||||||
|
|
||||||
return elementCount;
|
|
||||||
}
|
|
||||||
/***************************************************************************
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_AdvanceRingBufferReadIndex( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementCount )
|
|
||||||
{
|
|
||||||
/* ensure that previous reads (copies out of the ring buffer) are always completed before updating (writing) the read index.
|
|
||||||
(write-after-read) => full barrier
|
|
||||||
*/
|
|
||||||
PaUtil_FullMemoryBarrier();
|
|
||||||
return rbuf->readIndex = (rbuf->readIndex + elementCount) & rbuf->bigMask;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***************************************************************************
|
|
||||||
** Return elements written. */
|
|
||||||
ring_buffer_size_t PaUtil_WriteRingBuffer( PaUtilRingBuffer *rbuf, const void *data, ring_buffer_size_t elementCount )
|
|
||||||
{
|
|
||||||
ring_buffer_size_t size1, size2, numWritten;
|
|
||||||
void *data1, *data2;
|
|
||||||
numWritten = PaUtil_GetRingBufferWriteRegions( rbuf, elementCount, &data1, &size1, &data2, &size2 );
|
|
||||||
if( size2 > 0 )
|
|
||||||
{
|
|
||||||
|
|
||||||
memcpy( data1, data, size1*rbuf->elementSizeBytes );
|
|
||||||
data = ((char *)data) + size1*rbuf->elementSizeBytes;
|
|
||||||
memcpy( data2, data, size2*rbuf->elementSizeBytes );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
memcpy( data1, data, size1*rbuf->elementSizeBytes );
|
|
||||||
}
|
|
||||||
PaUtil_AdvanceRingBufferWriteIndex( rbuf, numWritten );
|
|
||||||
return numWritten;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***************************************************************************
|
|
||||||
** Return elements read. */
|
|
||||||
ring_buffer_size_t PaUtil_ReadRingBuffer( PaUtilRingBuffer *rbuf, void *data, ring_buffer_size_t elementCount )
|
|
||||||
{
|
|
||||||
ring_buffer_size_t size1, size2, numRead;
|
|
||||||
void *data1, *data2;
|
|
||||||
numRead = PaUtil_GetRingBufferReadRegions( rbuf, elementCount, &data1, &size1, &data2, &size2 );
|
|
||||||
if( size2 > 0 )
|
|
||||||
{
|
|
||||||
memcpy( data, data1, size1*rbuf->elementSizeBytes );
|
|
||||||
data = ((char *)data) + size1*rbuf->elementSizeBytes;
|
|
||||||
memcpy( data, data2, size2*rbuf->elementSizeBytes );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
memcpy( data, data1, size1*rbuf->elementSizeBytes );
|
|
||||||
}
|
|
||||||
PaUtil_AdvanceRingBufferReadIndex( rbuf, numRead );
|
|
||||||
return numRead;
|
|
||||||
}
|
|
|
@ -1,236 +0,0 @@
|
||||||
#ifndef PA_RINGBUFFER_H
|
|
||||||
#define PA_RINGBUFFER_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library
|
|
||||||
* Ring Buffer utility.
|
|
||||||
*
|
|
||||||
* Author: Phil Burk, http://www.softsynth.com
|
|
||||||
* modified for SMP safety on OS X by Bjorn Roche.
|
|
||||||
* also allowed for const where possible.
|
|
||||||
* modified for multiple-byte-sized data elements by Sven Fischer
|
|
||||||
*
|
|
||||||
* Note that this is safe only for a single-thread reader
|
|
||||||
* and a single-thread writer.
|
|
||||||
*
|
|
||||||
* This program is distributed with the PortAudio Portable Audio Library.
|
|
||||||
* For more information see: http://www.portaudio.com
|
|
||||||
* Copyright (c) 1999-2000 Ross Bencina and Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
@brief Single-reader single-writer lock-free ring buffer
|
|
||||||
|
|
||||||
PaUtilRingBuffer is a ring buffer used to transport samples between
|
|
||||||
different execution contexts (threads, OS callbacks, interrupt handlers)
|
|
||||||
without requiring the use of any locks. This only works when there is
|
|
||||||
a single reader and a single writer (ie. one thread or callback writes
|
|
||||||
to the ring buffer, another thread or callback reads from it).
|
|
||||||
|
|
||||||
The PaUtilRingBuffer structure manages a ring buffer containing N
|
|
||||||
elements, where N must be a power of two. An element may be any size
|
|
||||||
(specified in bytes).
|
|
||||||
|
|
||||||
The memory area used to store the buffer elements must be allocated by
|
|
||||||
the client prior to calling PaUtil_InitializeRingBuffer() and must outlive
|
|
||||||
the use of the ring buffer.
|
|
||||||
|
|
||||||
@note The ring buffer functions are not normally exposed in the PortAudio libraries.
|
|
||||||
If you want to call them then you will need to add pa_ringbuffer.c to your application source code.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#if defined(__APPLE__)
|
|
||||||
#include <sys/types.h>
|
|
||||||
typedef int32_t ring_buffer_size_t;
|
|
||||||
#elif defined( __GNUC__ )
|
|
||||||
typedef long ring_buffer_size_t;
|
|
||||||
#elif (_MSC_VER >= 1400)
|
|
||||||
typedef long ring_buffer_size_t;
|
|
||||||
#elif defined(_MSC_VER) || defined(__BORLANDC__)
|
|
||||||
typedef long ring_buffer_size_t;
|
|
||||||
#else
|
|
||||||
typedef long ring_buffer_size_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
typedef struct PaUtilRingBuffer
|
|
||||||
{
|
|
||||||
ring_buffer_size_t bufferSize; /**< Number of elements in FIFO. Power of 2. Set by PaUtil_InitRingBuffer. */
|
|
||||||
volatile ring_buffer_size_t writeIndex; /**< Index of next writable element. Set by PaUtil_AdvanceRingBufferWriteIndex. */
|
|
||||||
volatile ring_buffer_size_t readIndex; /**< Index of next readable element. Set by PaUtil_AdvanceRingBufferReadIndex. */
|
|
||||||
ring_buffer_size_t bigMask; /**< Used for wrapping indices with extra bit to distinguish full/empty. */
|
|
||||||
ring_buffer_size_t smallMask; /**< Used for fitting indices to buffer. */
|
|
||||||
ring_buffer_size_t elementSizeBytes; /**< Number of bytes per element. */
|
|
||||||
char *buffer; /**< Pointer to the buffer containing the actual data. */
|
|
||||||
}PaUtilRingBuffer;
|
|
||||||
|
|
||||||
/** Initialize Ring Buffer to empty state ready to have elements written to it.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
|
|
||||||
@param elementSizeBytes The size of a single data element in bytes.
|
|
||||||
|
|
||||||
@param elementCount The number of elements in the buffer (must be a power of 2).
|
|
||||||
|
|
||||||
@param dataPtr A pointer to a previously allocated area where the data
|
|
||||||
will be maintained. It must be elementCount*elementSizeBytes long.
|
|
||||||
|
|
||||||
@return -1 if elementCount is not a power of 2, otherwise 0.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_InitializeRingBuffer( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementSizeBytes, ring_buffer_size_t elementCount, void *dataPtr );
|
|
||||||
|
|
||||||
/** Reset buffer to empty. Should only be called when buffer is NOT being read or written.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
*/
|
|
||||||
void PaUtil_FlushRingBuffer( PaUtilRingBuffer *rbuf );
|
|
||||||
|
|
||||||
/** Retrieve the number of elements available in the ring buffer for writing.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
|
|
||||||
@return The number of elements available for writing.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_GetRingBufferWriteAvailable( const PaUtilRingBuffer *rbuf );
|
|
||||||
|
|
||||||
/** Retrieve the number of elements available in the ring buffer for reading.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
|
|
||||||
@return The number of elements available for reading.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_GetRingBufferReadAvailable( const PaUtilRingBuffer *rbuf );
|
|
||||||
|
|
||||||
/** Write data to the ring buffer.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
|
|
||||||
@param data The address of new data to write to the buffer.
|
|
||||||
|
|
||||||
@param elementCount The number of elements to be written.
|
|
||||||
|
|
||||||
@return The number of elements written.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_WriteRingBuffer( PaUtilRingBuffer *rbuf, const void *data, ring_buffer_size_t elementCount );
|
|
||||||
|
|
||||||
/** Read data from the ring buffer.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
|
|
||||||
@param data The address where the data should be stored.
|
|
||||||
|
|
||||||
@param elementCount The number of elements to be read.
|
|
||||||
|
|
||||||
@return The number of elements read.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_ReadRingBuffer( PaUtilRingBuffer *rbuf, void *data, ring_buffer_size_t elementCount );
|
|
||||||
|
|
||||||
/** Get address of region(s) to which we can write data.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
|
|
||||||
@param elementCount The number of elements desired.
|
|
||||||
|
|
||||||
@param dataPtr1 The address where the first (or only) region pointer will be
|
|
||||||
stored.
|
|
||||||
|
|
||||||
@param sizePtr1 The address where the first (or only) region length will be
|
|
||||||
stored.
|
|
||||||
|
|
||||||
@param dataPtr2 The address where the second region pointer will be stored if
|
|
||||||
the first region is too small to satisfy elementCount.
|
|
||||||
|
|
||||||
@param sizePtr2 The address where the second region length will be stored if
|
|
||||||
the first region is too small to satisfy elementCount.
|
|
||||||
|
|
||||||
@return The room available to be written or elementCount, whichever is smaller.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_GetRingBufferWriteRegions( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementCount,
|
|
||||||
void **dataPtr1, ring_buffer_size_t *sizePtr1,
|
|
||||||
void **dataPtr2, ring_buffer_size_t *sizePtr2 );
|
|
||||||
|
|
||||||
/** Advance the write index to the next location to be written.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
|
|
||||||
@param elementCount The number of elements to advance.
|
|
||||||
|
|
||||||
@return The new position.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_AdvanceRingBufferWriteIndex( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementCount );
|
|
||||||
|
|
||||||
/** Get address of region(s) from which we can read data.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
|
|
||||||
@param elementCount The number of elements desired.
|
|
||||||
|
|
||||||
@param dataPtr1 The address where the first (or only) region pointer will be
|
|
||||||
stored.
|
|
||||||
|
|
||||||
@param sizePtr1 The address where the first (or only) region length will be
|
|
||||||
stored.
|
|
||||||
|
|
||||||
@param dataPtr2 The address where the second region pointer will be stored if
|
|
||||||
the first region is too small to satisfy elementCount.
|
|
||||||
|
|
||||||
@param sizePtr2 The address where the second region length will be stored if
|
|
||||||
the first region is too small to satisfy elementCount.
|
|
||||||
|
|
||||||
@return The number of elements available for reading.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_GetRingBufferReadRegions( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementCount,
|
|
||||||
void **dataPtr1, ring_buffer_size_t *sizePtr1,
|
|
||||||
void **dataPtr2, ring_buffer_size_t *sizePtr2 );
|
|
||||||
|
|
||||||
/** Advance the read index to the next location to be read.
|
|
||||||
|
|
||||||
@param rbuf The ring buffer.
|
|
||||||
|
|
||||||
@param elementCount The number of elements to advance.
|
|
||||||
|
|
||||||
@return The new position.
|
|
||||||
*/
|
|
||||||
ring_buffer_size_t PaUtil_AdvanceRingBufferReadIndex( PaUtilRingBuffer *rbuf, ring_buffer_size_t elementCount );
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_RINGBUFFER_H */
|
|
|
@ -1,150 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library
|
|
||||||
* stream interface
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 2008 Ross Bencina
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Stream interfaces, representation structures and helper functions
|
|
||||||
used to interface between pa_front.c host API implementations.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "pa_stream.h"
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_InitializeStreamInterface( PaUtilStreamInterface *streamInterface,
|
|
||||||
PaError (*Close)( PaStream* ),
|
|
||||||
PaError (*Start)( PaStream* ),
|
|
||||||
PaError (*Stop)( PaStream* ),
|
|
||||||
PaError (*Abort)( PaStream* ),
|
|
||||||
PaError (*IsStopped)( PaStream* ),
|
|
||||||
PaError (*IsActive)( PaStream* ),
|
|
||||||
PaTime (*GetTime)( PaStream* ),
|
|
||||||
double (*GetCpuLoad)( PaStream* ),
|
|
||||||
PaError (*Read)( PaStream*, void *, unsigned long ),
|
|
||||||
PaError (*Write)( PaStream*, const void *, unsigned long ),
|
|
||||||
signed long (*GetReadAvailable)( PaStream* ),
|
|
||||||
signed long (*GetWriteAvailable)( PaStream* ) )
|
|
||||||
{
|
|
||||||
streamInterface->Close = Close;
|
|
||||||
streamInterface->Start = Start;
|
|
||||||
streamInterface->Stop = Stop;
|
|
||||||
streamInterface->Abort = Abort;
|
|
||||||
streamInterface->IsStopped = IsStopped;
|
|
||||||
streamInterface->IsActive = IsActive;
|
|
||||||
streamInterface->GetTime = GetTime;
|
|
||||||
streamInterface->GetCpuLoad = GetCpuLoad;
|
|
||||||
streamInterface->Read = Read;
|
|
||||||
streamInterface->Write = Write;
|
|
||||||
streamInterface->GetReadAvailable = GetReadAvailable;
|
|
||||||
streamInterface->GetWriteAvailable = GetWriteAvailable;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_InitializeStreamRepresentation( PaUtilStreamRepresentation *streamRepresentation,
|
|
||||||
PaUtilStreamInterface *streamInterface,
|
|
||||||
PaStreamCallback *streamCallback,
|
|
||||||
void *userData )
|
|
||||||
{
|
|
||||||
streamRepresentation->magic = PA_STREAM_MAGIC;
|
|
||||||
streamRepresentation->nextOpenStream = 0;
|
|
||||||
streamRepresentation->streamInterface = streamInterface;
|
|
||||||
streamRepresentation->streamCallback = streamCallback;
|
|
||||||
streamRepresentation->streamFinishedCallback = 0;
|
|
||||||
|
|
||||||
streamRepresentation->userData = userData;
|
|
||||||
|
|
||||||
streamRepresentation->streamInfo.inputLatency = 0.;
|
|
||||||
streamRepresentation->streamInfo.outputLatency = 0.;
|
|
||||||
streamRepresentation->streamInfo.sampleRate = 0.;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void PaUtil_TerminateStreamRepresentation( PaUtilStreamRepresentation *streamRepresentation )
|
|
||||||
{
|
|
||||||
streamRepresentation->magic = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
PaError PaUtil_DummyRead( PaStream* stream,
|
|
||||||
void *buffer,
|
|
||||||
unsigned long frames )
|
|
||||||
{
|
|
||||||
(void)stream; /* unused parameter */
|
|
||||||
(void)buffer; /* unused parameter */
|
|
||||||
(void)frames; /* unused parameter */
|
|
||||||
|
|
||||||
return paCanNotReadFromACallbackStream;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
PaError PaUtil_DummyWrite( PaStream* stream,
|
|
||||||
const void *buffer,
|
|
||||||
unsigned long frames )
|
|
||||||
{
|
|
||||||
(void)stream; /* unused parameter */
|
|
||||||
(void)buffer; /* unused parameter */
|
|
||||||
(void)frames; /* unused parameter */
|
|
||||||
|
|
||||||
return paCanNotWriteToACallbackStream;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
signed long PaUtil_DummyGetReadAvailable( PaStream* stream )
|
|
||||||
{
|
|
||||||
(void)stream; /* unused parameter */
|
|
||||||
|
|
||||||
return paCanNotReadFromACallbackStream;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
signed long PaUtil_DummyGetWriteAvailable( PaStream* stream )
|
|
||||||
{
|
|
||||||
(void)stream; /* unused parameter */
|
|
||||||
|
|
||||||
return paCanNotWriteToACallbackStream;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
double PaUtil_DummyGetCpuLoad( PaStream* stream )
|
|
||||||
{
|
|
||||||
(void)stream; /* unused parameter */
|
|
||||||
|
|
||||||
return 0.0;
|
|
||||||
}
|
|
|
@ -1,205 +0,0 @@
|
||||||
#ifndef PA_STREAM_H
|
|
||||||
#define PA_STREAM_H
|
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library
|
|
||||||
* stream interface
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2008 Ross Bencina, Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Stream interfaces, representation structures and helper functions
|
|
||||||
used to interface between pa_front.c host API implementations.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "portaudio.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
|
|
||||||
#define PA_STREAM_MAGIC (0x18273645)
|
|
||||||
|
|
||||||
|
|
||||||
/** A structure representing an (abstract) interface to a host API. Contains
|
|
||||||
pointers to functions which implement the interface.
|
|
||||||
|
|
||||||
All PaStreamInterface functions are guaranteed to be called with a non-null,
|
|
||||||
valid stream parameter.
|
|
||||||
*/
|
|
||||||
typedef struct {
|
|
||||||
PaError (*Close)( PaStream* stream );
|
|
||||||
PaError (*Start)( PaStream *stream );
|
|
||||||
PaError (*Stop)( PaStream *stream );
|
|
||||||
PaError (*Abort)( PaStream *stream );
|
|
||||||
PaError (*IsStopped)( PaStream *stream );
|
|
||||||
PaError (*IsActive)( PaStream *stream );
|
|
||||||
PaTime (*GetTime)( PaStream *stream );
|
|
||||||
double (*GetCpuLoad)( PaStream* stream );
|
|
||||||
PaError (*Read)( PaStream* stream, void *buffer, unsigned long frames );
|
|
||||||
PaError (*Write)( PaStream* stream, const void *buffer, unsigned long frames );
|
|
||||||
signed long (*GetReadAvailable)( PaStream* stream );
|
|
||||||
signed long (*GetWriteAvailable)( PaStream* stream );
|
|
||||||
} PaUtilStreamInterface;
|
|
||||||
|
|
||||||
|
|
||||||
/** Initialize the fields of a PaUtilStreamInterface structure.
|
|
||||||
*/
|
|
||||||
void PaUtil_InitializeStreamInterface( PaUtilStreamInterface *streamInterface,
|
|
||||||
PaError (*Close)( PaStream* ),
|
|
||||||
PaError (*Start)( PaStream* ),
|
|
||||||
PaError (*Stop)( PaStream* ),
|
|
||||||
PaError (*Abort)( PaStream* ),
|
|
||||||
PaError (*IsStopped)( PaStream* ),
|
|
||||||
PaError (*IsActive)( PaStream* ),
|
|
||||||
PaTime (*GetTime)( PaStream* ),
|
|
||||||
double (*GetCpuLoad)( PaStream* ),
|
|
||||||
PaError (*Read)( PaStream* stream, void *buffer, unsigned long frames ),
|
|
||||||
PaError (*Write)( PaStream* stream, const void *buffer, unsigned long frames ),
|
|
||||||
signed long (*GetReadAvailable)( PaStream* stream ),
|
|
||||||
signed long (*GetWriteAvailable)( PaStream* stream ) );
|
|
||||||
|
|
||||||
|
|
||||||
/** Dummy Read function for use in interfaces to a callback based streams.
|
|
||||||
Pass to the Read parameter of PaUtil_InitializeStreamInterface.
|
|
||||||
@return An error code indicating that the function has no effect
|
|
||||||
because the stream is a callback stream.
|
|
||||||
*/
|
|
||||||
PaError PaUtil_DummyRead( PaStream* stream,
|
|
||||||
void *buffer,
|
|
||||||
unsigned long frames );
|
|
||||||
|
|
||||||
|
|
||||||
/** Dummy Write function for use in an interfaces to callback based streams.
|
|
||||||
Pass to the Write parameter of PaUtil_InitializeStreamInterface.
|
|
||||||
@return An error code indicating that the function has no effect
|
|
||||||
because the stream is a callback stream.
|
|
||||||
*/
|
|
||||||
PaError PaUtil_DummyWrite( PaStream* stream,
|
|
||||||
const void *buffer,
|
|
||||||
unsigned long frames );
|
|
||||||
|
|
||||||
|
|
||||||
/** Dummy GetReadAvailable function for use in interfaces to callback based
|
|
||||||
streams. Pass to the GetReadAvailable parameter of PaUtil_InitializeStreamInterface.
|
|
||||||
@return An error code indicating that the function has no effect
|
|
||||||
because the stream is a callback stream.
|
|
||||||
*/
|
|
||||||
signed long PaUtil_DummyGetReadAvailable( PaStream* stream );
|
|
||||||
|
|
||||||
|
|
||||||
/** Dummy GetWriteAvailable function for use in interfaces to callback based
|
|
||||||
streams. Pass to the GetWriteAvailable parameter of PaUtil_InitializeStreamInterface.
|
|
||||||
@return An error code indicating that the function has no effect
|
|
||||||
because the stream is a callback stream.
|
|
||||||
*/
|
|
||||||
signed long PaUtil_DummyGetWriteAvailable( PaStream* stream );
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/** Dummy GetCpuLoad function for use in an interface to a read/write stream.
|
|
||||||
Pass to the GetCpuLoad parameter of PaUtil_InitializeStreamInterface.
|
|
||||||
@return Returns 0.
|
|
||||||
*/
|
|
||||||
double PaUtil_DummyGetCpuLoad( PaStream* stream );
|
|
||||||
|
|
||||||
|
|
||||||
/** Non host specific data for a stream. This data is used by pa_front to
|
|
||||||
forward to the appropriate functions in the streamInterface structure.
|
|
||||||
*/
|
|
||||||
typedef struct PaUtilStreamRepresentation {
|
|
||||||
unsigned long magic; /**< set to PA_STREAM_MAGIC */
|
|
||||||
struct PaUtilStreamRepresentation *nextOpenStream; /**< field used by multi-api code */
|
|
||||||
PaUtilStreamInterface *streamInterface;
|
|
||||||
PaStreamCallback *streamCallback;
|
|
||||||
PaStreamFinishedCallback *streamFinishedCallback;
|
|
||||||
void *userData;
|
|
||||||
PaStreamInfo streamInfo;
|
|
||||||
} PaUtilStreamRepresentation;
|
|
||||||
|
|
||||||
|
|
||||||
/** Initialize a PaUtilStreamRepresentation structure.
|
|
||||||
|
|
||||||
@see PaUtil_InitializeStreamRepresentation
|
|
||||||
*/
|
|
||||||
void PaUtil_InitializeStreamRepresentation(
|
|
||||||
PaUtilStreamRepresentation *streamRepresentation,
|
|
||||||
PaUtilStreamInterface *streamInterface,
|
|
||||||
PaStreamCallback *streamCallback,
|
|
||||||
void *userData );
|
|
||||||
|
|
||||||
|
|
||||||
/** Clean up a PaUtilStreamRepresentation structure previously initialized
|
|
||||||
by a call to PaUtil_InitializeStreamRepresentation.
|
|
||||||
|
|
||||||
@see PaUtil_InitializeStreamRepresentation
|
|
||||||
*/
|
|
||||||
void PaUtil_TerminateStreamRepresentation( PaUtilStreamRepresentation *streamRepresentation );
|
|
||||||
|
|
||||||
|
|
||||||
/** Check that the stream pointer is valid.
|
|
||||||
|
|
||||||
@return Returns paNoError if the stream pointer appears to be OK, otherwise
|
|
||||||
returns an error indicating the cause of failure.
|
|
||||||
*/
|
|
||||||
PaError PaUtil_ValidateStreamPointer( PaStream *stream );
|
|
||||||
|
|
||||||
|
|
||||||
/** Cast an opaque stream pointer into a pointer to a PaUtilStreamRepresentation.
|
|
||||||
|
|
||||||
@see PaUtilStreamRepresentation
|
|
||||||
*/
|
|
||||||
#define PA_STREAM_REP( stream )\
|
|
||||||
((PaUtilStreamRepresentation*) (stream) )
|
|
||||||
|
|
||||||
|
|
||||||
/** Cast an opaque stream pointer into a pointer to a PaUtilStreamInterface.
|
|
||||||
|
|
||||||
@see PaUtilStreamRepresentation, PaUtilStreamInterface
|
|
||||||
*/
|
|
||||||
#define PA_STREAM_INTERFACE( stream )\
|
|
||||||
PA_STREAM_REP( (stream) )->streamInterface
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
#endif /* PA_STREAM_H */
|
|
|
@ -1 +0,0 @@
|
||||||
#define PA_SVN_REVISION 1954M
|
|
|
@ -1,238 +0,0 @@
|
||||||
/*
|
|
||||||
* $Id$
|
|
||||||
* Portable Audio I/O Library Trace Facility
|
|
||||||
* Store trace information in real-time for later printing.
|
|
||||||
*
|
|
||||||
* Based on the Open Source API proposed by Ross Bencina
|
|
||||||
* Copyright (c) 1999-2000 Phil Burk
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
* a copy of this software and associated documentation files
|
|
||||||
* (the "Software"), to deal in the Software without restriction,
|
|
||||||
* including without limitation the rights to use, copy, modify, merge,
|
|
||||||
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
||||||
* and to permit persons to whom the Software is furnished to do so,
|
|
||||||
* subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
|
|
||||||
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
||||||
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The text above constitutes the entire PortAudio license; however,
|
|
||||||
* the PortAudio community also makes the following non-binding requests:
|
|
||||||
*
|
|
||||||
* Any person wishing to distribute modifications to the Software is
|
|
||||||
* requested to send the modifications to the original developer so that
|
|
||||||
* they can be incorporated into the canonical version. It is also
|
|
||||||
* requested that these non-binding requests be included along with the
|
|
||||||
* license above.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** @file
|
|
||||||
@ingroup common_src
|
|
||||||
|
|
||||||
@brief Real-time safe event trace logging facility for debugging.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdarg.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <assert.h>
|
|
||||||
#include "pa_trace.h"
|
|
||||||
#include "pa_util.h"
|
|
||||||
#include "pa_debugprint.h"
|
|
||||||
|
|
||||||
#if PA_TRACE_REALTIME_EVENTS
|
|
||||||
|
|
||||||
static char const *traceTextArray[PA_MAX_TRACE_RECORDS];
|
|
||||||
static int traceIntArray[PA_MAX_TRACE_RECORDS];
|
|
||||||
static int traceIndex = 0;
|
|
||||||
static int traceBlock = 0;
|
|
||||||
|
|
||||||
/*********************************************************************/
|
|
||||||
void PaUtil_ResetTraceMessages()
|
|
||||||
{
|
|
||||||
traceIndex = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*********************************************************************/
|
|
||||||
void PaUtil_DumpTraceMessages()
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
int messageCount = (traceIndex < PA_MAX_TRACE_RECORDS) ? traceIndex : PA_MAX_TRACE_RECORDS;
|
|
||||||
|
|
||||||
printf("DumpTraceMessages: traceIndex = %d\n", traceIndex );
|
|
||||||
for( i=0; i<messageCount; i++ )
|
|
||||||
{
|
|
||||||
printf("%3d: %s = 0x%08X\n",
|
|
||||||
i, traceTextArray[i], traceIntArray[i] );
|
|
||||||
}
|
|
||||||
PaUtil_ResetTraceMessages();
|
|
||||||
fflush(stdout);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*********************************************************************/
|
|
||||||
void PaUtil_AddTraceMessage( const char *msg, int data )
|
|
||||||
{
|
|
||||||
if( (traceIndex == PA_MAX_TRACE_RECORDS) && (traceBlock == 0) )
|
|
||||||
{
|
|
||||||
traceBlock = 1;
|
|
||||||
/* PaUtil_DumpTraceMessages(); */
|
|
||||||
}
|
|
||||||
else if( traceIndex < PA_MAX_TRACE_RECORDS )
|
|
||||||
{
|
|
||||||
traceTextArray[traceIndex] = msg;
|
|
||||||
traceIntArray[traceIndex] = data;
|
|
||||||
traceIndex++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/************************************************************************/
|
|
||||||
/* High performance log alternative */
|
|
||||||
/************************************************************************/
|
|
||||||
|
|
||||||
typedef unsigned long long PaUint64;
|
|
||||||
|
|
||||||
typedef struct __PaHighPerformanceLog
|
|
||||||
{
|
|
||||||
unsigned magik;
|
|
||||||
int writePtr;
|
|
||||||
int readPtr;
|
|
||||||
int size;
|
|
||||||
double refTime;
|
|
||||||
char* data;
|
|
||||||
} PaHighPerformanceLog;
|
|
||||||
|
|
||||||
static const unsigned kMagik = 0xcafebabe;
|
|
||||||
|
|
||||||
#define USEC_PER_SEC (1000000ULL)
|
|
||||||
|
|
||||||
int PaUtil_InitializeHighSpeedLog( LogHandle* phLog, unsigned maxSizeInBytes )
|
|
||||||
{
|
|
||||||
PaHighPerformanceLog* pLog = (PaHighPerformanceLog*)PaUtil_AllocateMemory(sizeof(PaHighPerformanceLog));
|
|
||||||
if (pLog == 0)
|
|
||||||
{
|
|
||||||
return paInsufficientMemory;
|
|
||||||
}
|
|
||||||
assert(phLog != 0);
|
|
||||||
*phLog = pLog;
|
|
||||||
|
|
||||||
pLog->data = (char*)PaUtil_AllocateMemory(maxSizeInBytes);
|
|
||||||
if (pLog->data == 0)
|
|
||||||
{
|
|
||||||
PaUtil_FreeMemory(pLog);
|
|
||||||
return paInsufficientMemory;
|
|
||||||
}
|
|
||||||
pLog->magik = kMagik;
|
|
||||||
pLog->size = maxSizeInBytes;
|
|
||||||
pLog->refTime = PaUtil_GetTime();
|
|
||||||
return paNoError;
|
|
||||||
}
|
|
||||||
|
|
||||||
void PaUtil_ResetHighSpeedLogTimeRef( LogHandle hLog )
|
|
||||||
{
|
|
||||||
PaHighPerformanceLog* pLog = (PaHighPerformanceLog*)hLog;
|
|
||||||
assert(pLog->magik == kMagik);
|
|
||||||
pLog->refTime = PaUtil_GetTime();
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef struct __PaLogEntryHeader
|
|
||||||
{
|
|
||||||
int size;
|
|
||||||
double timeStamp;
|
|
||||||
} PaLogEntryHeader;
|
|
||||||
|
|
||||||
#ifdef __APPLE__
|
|
||||||
#define _vsnprintf vsnprintf
|
|
||||||
#define min(a,b) ((a)<(b)?(a):(b))
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
int PaUtil_AddHighSpeedLogMessage( LogHandle hLog, const char* fmt, ... )
|
|
||||||
{
|
|
||||||
va_list l;
|
|
||||||
int n = 0;
|
|
||||||
PaHighPerformanceLog* pLog = (PaHighPerformanceLog*)hLog;
|
|
||||||
if (pLog != 0)
|
|
||||||
{
|
|
||||||
PaLogEntryHeader* pHeader;
|
|
||||||
char* p;
|
|
||||||
int maxN;
|
|
||||||
assert(pLog->magik == kMagik);
|
|
||||||
pHeader = (PaLogEntryHeader*)( pLog->data + pLog->writePtr );
|
|
||||||
p = (char*)( pHeader + 1 );
|
|
||||||
maxN = pLog->size - pLog->writePtr - 2 * sizeof(PaLogEntryHeader);
|
|
||||||
|
|
||||||
pHeader->timeStamp = PaUtil_GetTime() - pLog->refTime;
|
|
||||||
if (maxN > 0)
|
|
||||||
{
|
|
||||||
if (maxN > 32)
|
|
||||||
{
|
|
||||||
va_start(l, fmt);
|
|
||||||
n = _vsnprintf(p, min(1024, maxN), fmt, l);
|
|
||||||
va_end(l);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
n = sprintf(p, "End of log...");
|
|
||||||
}
|
|
||||||
n = ((n + sizeof(unsigned)) & ~(sizeof(unsigned)-1)) + sizeof(PaLogEntryHeader);
|
|
||||||
pHeader->size = n;
|
|
||||||
#if 0
|
|
||||||
PaUtil_DebugPrint("%05u.%03u: %s\n", pHeader->timeStamp/1000, pHeader->timeStamp%1000, p);
|
|
||||||
#endif
|
|
||||||
pLog->writePtr += n;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return n;
|
|
||||||
}
|
|
||||||
|
|
||||||
void PaUtil_DumpHighSpeedLog( LogHandle hLog, const char* fileName )
|
|
||||||
{
|
|
||||||
FILE* f = (fileName != NULL) ? fopen(fileName, "w") : stdout;
|
|
||||||
unsigned localWritePtr;
|
|
||||||
PaHighPerformanceLog* pLog = (PaHighPerformanceLog*)hLog;
|
|
||||||
assert(pLog->magik == kMagik);
|
|
||||||
localWritePtr = pLog->writePtr;
|
|
||||||
while (pLog->readPtr != localWritePtr)
|
|
||||||
{
|
|
||||||
const PaLogEntryHeader* pHeader = (const PaLogEntryHeader*)( pLog->data + pLog->readPtr );
|
|
||||||
const char* p = (const char*)( pHeader + 1 );
|
|
||||||
const PaUint64 ts = (const PaUint64)( pHeader->timeStamp * USEC_PER_SEC );
|
|
||||||
assert(pHeader->size < (1024+sizeof(unsigned)+sizeof(PaLogEntryHeader)));
|
|
||||||
fprintf(f, "%05u.%03u: %s\n", (unsigned)(ts/1000), (unsigned)(ts%1000), p);
|
|
||||||
pLog->readPtr += pHeader->size;
|
|
||||||
}
|
|
||||||
if (f != stdout)
|
|
||||||
{
|
|
||||||
fclose(f);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void PaUtil_DiscardHighSpeedLog( LogHandle hLog )
|
|
||||||
{
|
|
||||||
PaHighPerformanceLog* pLog = (PaHighPerformanceLog*)hLog;
|
|
||||||
assert(pLog->magik == kMagik);
|
|
||||||
PaUtil_FreeMemory(pLog->data);
|
|
||||||
PaUtil_FreeMemory(pLog);
|
|
||||||
}
|
|
||||||
|
|
||||||
#else
|
|
||||||
/* This stub was added so that this file will generate a symbol.
|
|
||||||
* Otherwise linker/archiver programs will complain.
|
|
||||||
*/
|
|
||||||
int PaUtil_TraceStubToSatisfyLinker(void)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif /* TRACE_REALTIME_EVENTS */
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue