[pulseaudio-discuss] [PATCH] utils: Adding a function to get volume from string

Flavio Ceolin flavio.ceolin at profusion.mobi
Wed Oct 24 12:29:45 PDT 2012


The allowed volume formats are dB, % or integer.
For example: 10% or 10db or 10.
---
 src/pulsecore/core-util.c | 39 +++++++++++++++++++++++++++++++++++++++
 src/pulsecore/core-util.h |  3 +++
 2 files changed, 42 insertions(+)

diff --git a/src/pulsecore/core-util.c b/src/pulsecore/core-util.c
index 710c9dc..874cccd 100644
--- a/src/pulsecore/core-util.c
+++ b/src/pulsecore/core-util.c
@@ -960,6 +960,45 @@ int pa_parse_boolean(const char *v) {
     return -1;
 }
 
+/* Try to parse a volume string to pa_volume_t. The allowed formats are:
+ * db,  % and unsigned integer */
+int pa_parse_volume(const char *v, pa_volume_t *volume) {
+    int len, ret = -1;
+    uint32_t i;
+    double d;
+    char str[64];
+    pa_assert(v);
+
+    len = strlen(v);
+    memcpy(str, v, PA_MIN(len, 64));
+
+    if (str[len - 1] == '%') {
+        str[len - 1] = '\0';
+        if (pa_atoi(str, &i) == 0) {
+            /* using 64 bits integer to avoid overflow */
+            uint64_t temp;
+            temp = PA_VOLUME_NORM * i;
+            *volume = PA_CLAMP_VOLUME(temp / 100);
+            ret = 0;
+        }
+    } else if (len > 2 && (str[len - 1] == 'b' || str[len - 1] == 'B') &&
+               (str[len - 2] == 'd' || str[len - 2] == 'D')) {
+        str[len - 2] = '\0';
+        if (pa_atod(str, &d) == 0) {
+            *volume = pa_sw_volume_from_dB(d);
+            ret = 0;
+        }
+    } else {
+        if (pa_atoi(v, &i) == 0) {
+            *volume= PA_CLAMP_VOLUME(i);
+            ret = 0;
+        }
+
+    }
+
+    return ret;
+}
+
 /* Split the specified string wherever one of the strings in delimiter
  * occurs. Each time it is called returns a newly allocated string
  * with pa_xmalloc(). The variable state points to, should be
diff --git a/src/pulsecore/core-util.h b/src/pulsecore/core-util.h
index b181266..9d59383 100644
--- a/src/pulsecore/core-util.h
+++ b/src/pulsecore/core-util.h
@@ -34,6 +34,7 @@
 #endif
 
 #include <pulse/gccmacro.h>
+#include <pulse/volume.h>
 #include <pulsecore/macro.h>
 #include <pulsecore/socket.h>
 
@@ -83,6 +84,8 @@ void pa_reset_priority(void);
 
 int pa_parse_boolean(const char *s) PA_GCC_PURE;
 
+int pa_parse_volume(const char *s, pa_volume_t *volume);
+
 static inline const char *pa_yes_no(pa_bool_t b) {
     return b ? "yes" : "no";
 }
-- 
1.7.11.7



More information about the pulseaudio-discuss mailing list