]> git.alsa-project.org Git - alsa-gobject.git/commitdiff
ctl: elem-value: rewrite getter for IEC 60958 channel status
authorTakashi Sakamoto <o-takashi@sakamocchi.jp>
Sat, 25 Jun 2022 02:00:43 +0000 (11:00 +0900)
committerTakashi Sakamoto <o-takashi@sakamocchi.jp>
Sat, 25 Jun 2022 02:00:43 +0000 (11:00 +0900)
This commit rewrites the getter method so that it returns a pointer to
internal storage for IEC 60958 channel status.

Signed-off-by: Takashi Sakamoto <o-takashi@sakamocchi.jp>
src/ctl/alsactl.map
src/ctl/elem-value.c
src/ctl/elem-value.h

index b2902989b5068e6784f9cd14f32e30f43ad43094..a8fd5563c388e35200890c7400f6a436325764b4 100644 (file)
@@ -29,7 +29,6 @@ ALSA_GOBJECT_0_0_0 {
     "alsactl_elem_value_set_enum";
     "alsactl_elem_value_set_bytes";
     "alsactl_elem_value_set_iec60958_user_data";
-    "alsactl_elem_value_get_iec60958_user_data";
     "alsactl_elem_value_set_iec60958_channel_status";
     "alsactl_elem_value_get_iec60958_channel_status";
     "alsactl_elem_value_set_int64";
@@ -94,4 +93,5 @@ ALSA_GOBJECT_0_3_0 {
     "alsactl_elem_value_get_int";
     "alsactl_elem_value_get_enum";
     "alsactl_elem_value_get_bytes";
+    "alsactl_elem_value_get_iec60958_user_data";
 } ALSA_GOBJECT_0_2_0;
index efde32ba45a77e1551521921a5cf21df00bdd9d9..697fad22c5b6118171c23ff1304bc697b33bd5c8 100644 (file)
@@ -332,18 +332,17 @@ void alsactl_elem_value_set_iec60958_channel_status(ALSACtlElemValue *self, cons
 /**
  * alsactl_elem_value_get_iec60958_channel_status:
  * @self: A [class@ElemValue].
- * @status: (array length=length)(inout): The array of byte data for channel status bits for
- *          IEC 60958 element.
- * @length: The number of bytes in status argument, up to 24.
+ * @status: (array length=length) (out) (transfer none): The array of byte data for channel status
+ *          bits of IEC 60958.
+ * @length: The number of bytes in status argument up to 24.
  *
- * Copy channel status of IEC 60958 from internal storage.
+ * Refer to the array specific to [enum@ElemType].IEC60958 element in internal storage.
  */
-void alsactl_elem_value_get_iec60958_channel_status(ALSACtlElemValue *self, guint8 *const *status,
+void alsactl_elem_value_get_iec60958_channel_status(ALSACtlElemValue *self, const guint8 **status,
                                                     gsize *length)
 {
     ALSACtlElemValuePrivate *priv;
     struct snd_ctl_elem_value *value;
-    int i;
 
     g_return_if_fail(ALSACTL_IS_ELEM_VALUE(self));
     priv = alsactl_elem_value_get_instance_private(self);
@@ -352,9 +351,8 @@ void alsactl_elem_value_get_iec60958_channel_status(ALSACtlElemValue *self, guin
     g_return_if_fail(length != NULL);
 
     value = &priv->value;
-    *length = MIN(*length, G_N_ELEMENTS(value->value.iec958.status));
-    for (i = 0; i < *length; ++i)
-        (*status)[i] = value->value.iec958.status[i];
+    *status = value->value.iec958.status;
+    *length = G_N_ELEMENTS(value->value.iec958.status);
 }
 
 /**
index 6a1ef6e12aed126845c8640ebe37a47d673399a2..6a69105e4a7d21ac103a739a851490b017b6ab32 100644 (file)
@@ -39,7 +39,7 @@ void alsactl_elem_value_get_bytes(ALSACtlElemValue *self,
 void alsactl_elem_value_set_iec60958_channel_status(ALSACtlElemValue *self,
                                         const guint8 *status, gsize length);
 void alsactl_elem_value_get_iec60958_channel_status(ALSACtlElemValue *self,
-                                        guint8 *const *status, gsize *length);
+                                        const guint8 **status, gsize *length);
 
 void alsactl_elem_value_set_iec60958_user_data(ALSACtlElemValue *self,
                                         const guint8 *data, gsize length);