diff options
| author | Mark Felder <feld@feld.me> | 2024-01-22 10:01:29 -0500 | 
|---|---|---|
| committer | Mark Felder <feld@feld.me> | 2024-01-22 10:13:17 -0500 | 
| commit | 0ac010ba3fa41c9bd06565259de57f2a5b5bb8ad (patch) | |
| tree | 9960ecae6bb61abbbf2ce50d3792b2a414563c73 /test/support/data_case.ex | |
| parent | 548434f85ccaa4a77c460fb5bda37153ea6e9c39 (diff) | |
| download | pleroma-0ac010ba3fa41c9bd06565259de57f2a5b5bb8ad.tar.gz pleroma-0ac010ba3fa41c9bd06565259de57f2a5b5bb8ad.zip | |
Replace custom fifo implementation with Exile
This is for streaming media to ffmpeg thumbnailer. The existing implementation relies on undocumented behavior.
Erlang open_port/2 does not officially support passing a string of a file path for opening. The specs clearly state you are to provide one of the following for open_port/2:
    {spawn, Command :: string() | binary()} |
    {spawn_driver, Command :: string() | binary()} |
    {spawn_executable, FileName :: file:name_all()} |
    {fd, In :: integer() >= 0, Out :: integer() >= 0}
Our method technically works but is strongly discouraged as it can block the scheduler and dialyzer throws errors as it recognizes we're breaking the contract and some of the functions we wrote may never return.
This is indirectly covered by the Erlang FAQ section "9.12 Why can't I open devices (e.g. a serial port) like normal files?"
https://www.erlang.org/faq/problems#idm1127
Diffstat (limited to 'test/support/data_case.ex')
0 files changed, 0 insertions, 0 deletions
