summaryrefslogtreecommitdiffstats
path: root/Alc/oss.c
diff options
context:
space:
mode:
authorChris Robinson <[email protected]>2010-12-09 23:32:47 -0800
committerChris Robinson <[email protected]>2010-12-09 23:32:47 -0800
commitb87447787a5bdbbc3daeafa65feeac8bc9049c23 (patch)
tree2dc12907d3b3ce0d9115907fa96d38f1b67691fc /Alc/oss.c
parent5a548f836693b6988e2728b045888848097ecc44 (diff)
Cleanup some ok() macros
Diffstat (limited to 'Alc/oss.c')
-rw-r--r--Alc/oss.c38
1 files changed, 23 insertions, 15 deletions
diff --git a/Alc/oss.c b/Alc/oss.c
index 8296349c..ea18689d 100644
--- a/Alc/oss.c
+++ b/Alc/oss.c
@@ -196,7 +196,6 @@ static ALCboolean oss_reset_playback(ALCdevice *device)
int ossFormat;
int ossSpeed;
char *err;
- int i;
switch(device->FmtType)
{
@@ -230,19 +229,24 @@ static ALCboolean oss_reset_playback(ALCdevice *device)
if(periods > 2) periods--;
numFragmentsLogSize = (periods << 16) | log2FragmentSize;
-#define ok(func, str) (i=(func),((i<0)?(err=(str)),0:1))
+#define CHECKERR(func) if((func) < 0) { \
+ err = #func; \
+ goto err; \
+}
/* Don't fail if SETFRAGMENT fails. We can handle just about anything
* that's reported back via GETOSPACE */
ioctl(data->fd, SNDCTL_DSP_SETFRAGMENT, &numFragmentsLogSize);
- if (!(ok(ioctl(data->fd, SNDCTL_DSP_SETFMT, &ossFormat), "set format") &&
- ok(ioctl(data->fd, SNDCTL_DSP_CHANNELS, &numChannels), "set channels") &&
- ok(ioctl(data->fd, SNDCTL_DSP_SPEED, &ossSpeed), "set speed") &&
- ok(ioctl(data->fd, SNDCTL_DSP_GETOSPACE, &info), "get space")))
+ CHECKERR(ioctl(data->fd, SNDCTL_DSP_SETFMT, &ossFormat));
+ CHECKERR(ioctl(data->fd, SNDCTL_DSP_CHANNELS, &numChannels));
+ CHECKERR(ioctl(data->fd, SNDCTL_DSP_SPEED, &ossSpeed));
+ CHECKERR(ioctl(data->fd, SNDCTL_DSP_GETOSPACE, &info));
+ if(0)
{
+ err:
AL_PRINT("%s failed: %s\n", err, strerror(errno));
return ALC_FALSE;
}
-#undef ok
+#undef CHECKERR
if((int)ChannelsFromDevFmt(device->FmtChans) != numChannels)
{
@@ -311,7 +315,6 @@ static ALCboolean oss_open_capture(ALCdevice *device, const ALCchar *deviceName)
int ossFormat;
int ossSpeed;
char *err;
- int i;
strncpy(driver, GetConfigValue("oss", "capture", "/dev/dsp"), sizeof(driver)-1);
driver[sizeof(driver)-1] = 0;
@@ -361,19 +364,24 @@ static ALCboolean oss_open_capture(ALCdevice *device, const ALCchar *deviceName)
log2FragmentSize = 4;
numFragmentsLogSize = (periods << 16) | log2FragmentSize;
-#define ok(func, str) (i=(func),((i<0)?(err=(str)),0:1))
- if (!(ok(ioctl(data->fd, SNDCTL_DSP_SETFRAGMENT, &numFragmentsLogSize), "set fragment") &&
- ok(ioctl(data->fd, SNDCTL_DSP_SETFMT, &ossFormat), "set format") &&
- ok(ioctl(data->fd, SNDCTL_DSP_CHANNELS, &numChannels), "set channels") &&
- ok(ioctl(data->fd, SNDCTL_DSP_SPEED, &ossSpeed), "set speed") &&
- ok(ioctl(data->fd, SNDCTL_DSP_GETISPACE, &info), "get space")))
+#define CHECKERR(func) if((func) < 0) { \
+ err = #func; \
+ goto err; \
+}
+ CHECKERR(ioctl(data->fd, SNDCTL_DSP_SETFRAGMENT, &numFragmentsLogSize));
+ CHECKERR(ioctl(data->fd, SNDCTL_DSP_SETFMT, &ossFormat));
+ CHECKERR(ioctl(data->fd, SNDCTL_DSP_CHANNELS, &numChannels));
+ CHECKERR(ioctl(data->fd, SNDCTL_DSP_SPEED, &ossSpeed));
+ CHECKERR(ioctl(data->fd, SNDCTL_DSP_GETISPACE, &info));
+ if(0)
{
+ err:
AL_PRINT("%s failed: %s\n", err, strerror(errno));
close(data->fd);
free(data);
return ALC_FALSE;
}
-#undef ok
+#undef CHECKERR
if((int)ChannelsFromDevFmt(device->FmtChans) != numChannels)
{