Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

jv4-decoder

Package Overview
Dependencies
Maintainers
0
Versions
12
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

jv4-decoder

  • 1.1.1
  • latest
  • npm
  • Socket score

Version published
Weekly downloads
74
increased by2366.67%
Maintainers
0
Weekly downloads
 
Created
Source

/*

  • This file is part of FFmpeg.
  • FFmpeg is free software; you can redistribute it and/or
  • modify it under the terms of the GNU Lesser General Public License
  • as published by the Free Software Foundation; either
  • version 2.1 of the License, or (at your option) any later version.
  • FFmpeg is distributed in the hope that it will be useful,
  • but WITHOUT ANY WARRANTY; without even the implied warranty of
  • MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  • GNU Lesser General Public License for more details.
  • You should have received a copy of the GNU Lesser General Public License
  • along with FFmpeg; if not, write to the Free Software Foundation, Inc.,
  • 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */

#ifndef AVUTIL_THREADMESSAGE_H #define AVUTIL_THREADMESSAGE_H

typedef struct AVThreadMessageQueue AVThreadMessageQueue;

typedef enum AVThreadMessageFlags {

/**
 * Perform non-blocking operation.
 * If this flag is set, send and recv operations are non-blocking and
 * return AVERROR(EAGAIN) immediately if they can not proceed.
 */
AV_THREAD_MESSAGE_NONBLOCK = 1,

} AVThreadMessageFlags;

/**

  • Allocate a new message queue.
  • @param mq pointer to the message queue
  • @param nelem maximum number of elements in the queue
  • @param elsize size of each element in the queue
  • @return >=0 for success; <0 for error, in particular AVERROR(ENOSYS) if
  •      lavu was built without thread support
    

*/ int av_thread_message_queue_alloc(AVThreadMessageQueue **mq, unsigned nelem, unsigned elsize);

/**

  • Free a message queue.
  • The message queue must no longer be in use by another thread. */ void av_thread_message_queue_free(AVThreadMessageQueue **mq);

/**

  • Send a message on the queue. */ int av_thread_message_queue_send(AVThreadMessageQueue *mq, void *msg, unsigned flags);

/**

  • Receive a message from the queue. */ int av_thread_message_queue_recv(AVThreadMessageQueue *mq, void *msg, unsigned flags);

/**

  • Set the sending error code.
  • If the error code is set to non-zero, av_thread_message_queue_send() will
  • return it immediately. Conventional values, such as AVERROR_EOF or
  • AVERROR(EAGAIN), can be used to cause the sending thread to stop or
  • suspend its operation. */ void av_thread_message_queue_set_err_send(AVThreadMessageQueue *mq, int err);

/**

  • Set the receiving error code.
  • If the error code is set to non-zero, av_thread_message_queue_recv() will
  • return it immediately when there are no longer available messages.
  • Conventional values, such as AVERROR_EOF or AVERROR(EAGAIN), can be used
  • to cause the receiving thread to stop or suspend its operation. */ void av_thread_message_queue_set_err_recv(AVThreadMessageQueue *mq, int err);

/**

  • Set the optional free message callback function which will be called if an
  • operation is removing messages from the queue. */ void av_thread_message_queue_set_free_func(AVThreadMessageQueue *mq, void (*free_func)(void *msg));

/**

  • Return the current number of messages in the queue.
  • @return the current number of messages or AVERROR(ENOSYS) if lavu was built
  •     without thread support
    

*/ int av_thread_message_queue_nb_elems(AVThreadMessageQueue *mq);

/**

  • Flush the message queue
  • This function is mostly equivalent to reading and free-ing every message
  • except that it will be done in a single operation (no lock/unlock between
  • reads). */ void av_thread_message_flush(AVThreadMessageQueue *mq);

#endif /* AVUTIL_THREADMESSAGE_H */

FAQs

Package last updated on 11 Dec 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc