<html>
    <head>
      <base href="https://bugs.freedesktop.org/" />
    </head>
    <body><table border="1" cellspacing="0" cellpadding="8">
        <tr>
          <th>Priority</th>
          <td>medium
          </td>
        </tr>

        <tr>
          <th>Bug ID</th>
          <td><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW --- - Unnecessary copying in pa_sink_get_formats()"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=71924">71924</a>
          </td>
        </tr>

        <tr>
          <th>CC</th>
          <td>lennart@poettering.net
          </td>
        </tr>

        <tr>
          <th>Assignee</th>
          <td>pulseaudio-bugs@lists.freedesktop.org
          </td>
        </tr>

        <tr>
          <th>Summary</th>
          <td>Unnecessary copying in pa_sink_get_formats()
          </td>
        </tr>

        <tr>
          <th>QA Contact</th>
          <td>pulseaudio-bugs@lists.freedesktop.org
          </td>
        </tr>

        <tr>
          <th>Severity</th>
          <td>normal
          </td>
        </tr>

        <tr>
          <th>Classification</th>
          <td>Unclassified
          </td>
        </tr>

        <tr>
          <th>OS</th>
          <td>All
          </td>
        </tr>

        <tr>
          <th>Reporter</th>
          <td>tanuk@iki.fi
          </td>
        </tr>

        <tr>
          <th>Hardware</th>
          <td>Other
          </td>
        </tr>

        <tr>
          <th>Status</th>
          <td>NEW
          </td>
        </tr>

        <tr>
          <th>Version</th>
          <td>unspecified
          </td>
        </tr>

        <tr>
          <th>Component</th>
          <td>core
          </td>
        </tr>

        <tr>
          <th>Product</th>
          <td>PulseAudio
          </td>
        </tr></table>
      <p>
        <div>
        <pre>pa_sink_get_formats() returns a freshly allocated idxset with freshly allocated
format info objects every time it's called. In my opinion this is waste of CPU
cycles, and also makes life harder for the callers of the function, because
they have to free the returned formats.

Currently the sink formats are stored inside the sink backend code. The formats
could also be stored in the pa_sink struct, in which case the whole
pa_sink_get_format() function could be removed (there's some point in keeping
the getter function for encapsulation reasons, though, but I'd prefer not to
keep it). If the formats are stored in pa_sink, then that raises a question how
pa_sink_set_formats() would work. The sink backend should still handle that
operation, but would the backend write directly to pa_sink.formats, or should
it be done in some other way? I personally would prefer to do it in some other
way, because while I slightly dislike getter functions, I do like setter
functions, so the backend shouldn't write directly to fields in the pa_sink
struct.

What would the "setter function" be called? pa_sink_set_formats() is a no-go,
because that's the function from which the setter function would be called. I
propose that pa_sink_formats_changed() is added. It would be called by the sink
backend when the formats change in the backend, similarly how
pa_sink_volume_changed() and pa_sink_mute_changed() are called when the
volume/mute changes in the backend.</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the QA Contact for the bug.</li>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>