Go to the documentation of this file.
22 #include "config_components.h"
32 #define SRT_STACK_SIZE 64
56 s->stack[
s->stack_ptr++] =
c;
62 if (
s->stack_ptr <= 0)
64 return s->stack[--
s->stack_ptr];
70 for (
i =
s->stack_ptr-1;
i >= 0;
i--)
78 srt_print(
s,
"</%c%s>",
tag,
tag ==
'f' ?
"ont" :
"");
87 while (
s->stack_ptr !=
i)
101 srt_print(
s,
"<font");
107 srt_print(
s,
" color=\"#%06x\"",
108 (
c & 0xFF0000) >> 16 |
c & 0xFF00 | (
c & 0xFF) << 16);
126 s->alignment_applied = 1;
148 srt_print(priv,
"\r\n");
155 srt_print(priv,
"<%c>", style);
163 if (
color != 0xFFFFFFFF)
164 srt_print(priv,
"<font color=\"#%06x\">",
172 srt_print(priv,
"<font face=\"%s\">",
name);
179 srt_print(priv,
"<font size=\"%d\">",
size);
185 if (!
s->alignment_applied && alignment >= 0) {
186 srt_print(
s,
"{\\an%d}", alignment);
187 s->alignment_applied = 1;
197 static void srt_move_cb(
void *priv,
int x1,
int y1,
int x2,
int y2,
228 unsigned char *buf,
int bufsize,
const AVSubtitle *sub,
248 s->alignment_applied = 0;
263 return s->buffer.len;
267 unsigned char *buf,
int bufsize,
const AVSubtitle *sub)
273 unsigned char *buf,
int bufsize,
const AVSubtitle *sub)
285 #if CONFIG_SRT_ENCODER
299 #if CONFIG_SUBRIP_ENCODER
312 #if CONFIG_TEXT_ENCODER
static void srt_new_line_cb(void *priv, int forced)
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default minimum maximum flags name is the option name
static int srt_stack_find(SRTContext *s, const char c)
Set of callback functions corresponding to each override codes that can be encountered in a "Dialogue...
static int av_bprint_is_complete(const AVBPrint *buf)
Test if the print buffer is complete (not truncated).
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
static void srt_stack_push_pop(SRTContext *s, const char c, int close)
static double cb(void *priv, double x, double y)
static const ASSCodesCallbacks text_callbacks
int alignment
position of the text (left, center, top...), defined after the layout of the numpad (1-3 sub,...
static void srt_alignment_cb(void *priv, int alignment)
ASSDialog * ff_ass_split_dialog(ASSSplitContext *ctx, const char *buf)
Split one ASS Dialogue line from a string buffer.
#define ASS_DEFAULT_ALIGNMENT
uint8_t * subtitle_header
static av_cold int srt_encode_init(AVCodecContext *avctx)
char * style
name of the ASSStyle to use with this dialog
@ SUBTITLE_ASS
Formatted text, the ass field must be set by the decoder and is authoritative.
static int srt_encode_frame(AVCodecContext *avctx, unsigned char *buf, int bufsize, const AVSubtitle *sub)
char * font_name
font face (case sensitive)
AVCodec p
The public AVCodec.
void av_bprint_init_for_buffer(AVBPrint *buf, char *buffer, unsigned size)
Init a print buffer using a pre-existing buffer.
const FFCodec ff_srt_encoder
#define AVERROR_BUFFER_TOO_SMALL
Buffer too small.
char * ass
0 terminated ASS/SSA compatible event line.
static char srt_stack_pop(SRTContext *s)
void ff_ass_free_dialog(ASSDialog **dialogp)
Free a dialogue obtained from ff_ass_split_dialog().
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
const FFCodec ff_text_encoder
#define CODEC_LONG_NAME(str)
static void srt_font_size_cb(void *priv, int size)
int primary_color
color that a subtitle will normally appear in
static int srt_stack_push(SRTContext *s, const char c)
static int srt_encode_close(AVCodecContext *avctx)
#define FF_CODEC_ENCODE_SUB_CB(func)
This struct can be casted to ASS to access to the split data.
ASSSplitContext * ff_ass_split(const char *buf)
Split a full ASS file or a ASS header from a string buffer and store the split structure in a newly a...
static void srt_cancel_overrides_cb(void *priv, const char *style)
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
fields extracted from the [V4(+) Styles] section
static void srt_close_tag(SRTContext *s, char tag)
int underline
whether text is underlined (1) or not (0)
int(* init)(AVBSFContext *ctx)
void ff_ass_split_free(ASSSplitContext *ctx)
Free all the memory allocated for an ASSSplitContext.
char * text
actual text which will be displayed as a subtitle, can include style override control codes (see ff_a...
ASSSplitContext * ass_ctx
static void srt_move_cb(void *priv, int x1, int y1, int x2, int y2, int t1, int t2)
int italic
whether text is italic (1) or not (0)
static av_printf_format(2, 3)
static int encode_frame(AVCodecContext *avctx, unsigned char *buf, int bufsize, const AVSubtitle *sub, const ASSCodesCallbacks *cb)
static void srt_color_cb(void *priv, unsigned int color, unsigned int color_id)
#define ASS_DEFAULT_UNDERLINE
ASSStyle * ff_ass_style_get(ASSSplitContext *ctx, const char *style)
Find an ASSStyle structure by its name.
static void srt_style_apply(SRTContext *s, const char *style)
#define i(width, name, range_min, range_max)
const FFCodec ff_subrip_encoder
const char * name
Name of the codec implementation.
#define ASS_DEFAULT_ITALIC
#define ASS_DEFAULT_COLOR
@ AV_CODEC_ID_TEXT
raw UTF-8 text
static void srt_end_cb(void *priv)
#define ASS_DEFAULT_FONT_SIZE
main external API structure.
void av_vbprintf(AVBPrint *buf, const char *fmt, va_list vl_arg)
Append a formatted string to a print buffer.
static void srt_style_cb(void *priv, char style, int close)
fields extracted from the [Events] section
static void srt_text_cb(void *priv, const char *text, int len)
static void srt_font_name_cb(void *priv, const char *name)
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
int ff_ass_split_override_codes(const ASSCodesCallbacks *callbacks, void *priv, const char *buf)
Split override codes out of a ASS "Dialogue" Text field.
static const ASSCodesCallbacks srt_callbacks
void av_bprint_append_data(AVBPrint *buf, const char *data, unsigned size)
Append data to a print buffer.
static int text_encode_frame(AVCodecContext *avctx, unsigned char *buf, int bufsize, const AVSubtitle *sub)
int bold
whether text is bold (1) or not (0)
void(* text)(void *priv, const char *text, int len)