Diff between 4e5ce5de4d69f1dadf6366a26ff55d78be3f62d6 and 1a1d120edb6e18db01c174482a7c6037e3db2a57

Changed Files

File Additions Deletions Status
src/shared/hfp.c +12 -0 modified
src/shared/hfp.h +1 -0 modified

Full Patch

diff --git a/src/shared/hfp.c b/src/shared/hfp.c
index 6c804f5..a35cb7b 100644
--- a/src/shared/hfp.c
+++ b/src/shared/hfp.c
@@ -415,6 +415,18 @@ bool hfp_context_has_next(struct hfp_context *context)
 	return context->data[context->offset] != '\0';
 }
 
+void hfp_context_skip_field(struct hfp_context *context)
+{
+	const char *data = context->data;
+	unsigned int offset = context->offset;
+
+	while (data[offset] != '\0' && data[offset] != ',')
+		offset++;
+
+	context->offset = offset;
+	next_field(context);
+}
+
 bool hfp_context_get_range(struct hfp_context *context, uint32_t *min,
 								uint32_t *max)
 {
diff --git a/src/shared/hfp.h b/src/shared/hfp.h
index 5ba020d..2eb7838 100644
--- a/src/shared/hfp.h
+++ b/src/shared/hfp.h
@@ -130,6 +130,7 @@ bool hfp_context_get_unquoted_string(struct hfp_context *context,
 bool hfp_context_get_range(struct hfp_context *context, unsigned int *min,
 							unsigned int *max);
 bool hfp_context_has_next(struct hfp_context *context);
+void hfp_context_skip_field(struct hfp_context *context);
 
 typedef void (*hfp_hf_result_func_t)(struct hfp_context *context,
 							void *user_data);