From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from ffbox0-bg.ffmpeg.org (ffbox0-bg.ffmpeg.org [79.124.17.100]) by master.gitmailbox.com (Postfix) with ESMTPS id E60064E676 for ; Wed, 25 Feb 2026 22:24:18 +0000 (UTC) Authentication-Results: ffbox; dkim=fail (body hash mismatch (got b'E9WMwmOdy8HH/Hqc+ey1QYwuKMcnG4Ce9XmBr4b+jDM=', expected b'/mreUkhEneBU2rF2egcDVwxWVsDoDhWQpWV2LvIdwM4=')) header.d=emresimsirli.com header.a=rsa-sha256 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ffmpeg.org; i=@ffmpeg.org; q=dns/txt; s=mail; t=1772058234; h=message-id : date : mime-version : to : reply-to : subject : list-id : list-archive : list-archive : list-help : list-owner : list-post : list-subscribe : list-unsubscribe : from : cc : content-type : content-transfer-encoding : from; bh=fyynBYbbYaBZ+O/sNZAYDGu+3ifqO6Ucff2qEG52jtQ=; b=EJYIrDo/nD0PpydX9s5cUl7AwYZ8he/qpOD/5nBsK84gRsbbVhhkZq4HGop0gUy384QqQ IC9CGxMvMXmebJQcPPoL3CQxkk02G4xp9TkFdcxlsTp5ELSw3n0M+F6qy/LB9eYh8UnED/g ZwQDHKK0AS0a2zvClc4fTu8nskQW1eLxJDGiGswmC6l+IrMH7sYgkKvjpaahaMG/QFr8bRz xeG3pWPHJzCcviQfB/rZkZGcX62gaV6FDmeZ9/Wh0RDVrtnys2Suv+SqaoSIaKi8DBSh0p5 QRuO6PzMKR0U2EDETHVaQOS+utygsdIYYjDZE7svgXCCBr5bMYE2MtaBew1g== Received: from [172.18.0.3] (unknown [172.18.0.3]) by ffbox0-bg.ffmpeg.org (Postfix) with ESMTP id 02F5D691DAB; Thu, 26 Feb 2026 00:23:54 +0200 (EET) ARC-Seal: i=1; cv=none; a=rsa-sha256; d=ffmpeg.org; s=arc; t=1772058220; b=nNeewqKFo0GOq/i5dF5BnHWNyuP7iOiSJBEQeKeJj6PLtO36ql08Qh3NQQ3Xu2QXRz+yW pVITvulMjF5KWQmsMhfrkllLjfDD865Ivx2CesJT0zcp8c2TiXXwHUUlJY3ikf9q8dJBONS vbHv6Yg9wZblgAHTX40VsYkIb3eWWHqizGoHPETwe9LolfZTB/CoW/B7LPfPaiVC9gVrH77 RUquWSBkp3da7EI8mel4VTjlnspkZbs58wkVXOiPNsbmBYsQi0a/uQ0nK9e9/vZdwb7Agwx 8SmqoB1WNchVfLO7NT+2r11Gw48lFw1poQmUCdLCd2nCHqMhdslpVFgGAN5Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=ffmpeg.org; s=arc; t=1772058220; h=from : sender : reply-to : subject : date : message-id : to : cc : mime-version : content-type : content-transfer-encoding : content-id : content-description : resent-date : resent-from : resent-sender : resent-to : resent-cc : resent-message-id : in-reply-to : references : list-id : list-help : list-unsubscribe : list-subscribe : list-post : list-owner : list-archive; bh=E9WMwmOdy8HH/Hqc+ey1QYwuKMcnG4Ce9XmBr4b+jDM=; b=JoArWh6WJqkrRMxgBV27dqrI0GlDS32G7rmq2bTWm47bPGxi+4+glkYFCDo2QMk5xvNmS VI3wLj7/c55gBDSwLml+yhLTjKy1TFUmbb+Oyslk3EZmGBxWMax8Q7sp32AL5GBX1Gl4UE7 3RnV42difqmeUV4PYNnbIajf+KJqLHmRmCcY/xG8hTL5/jQvISyGetiwIomKNj8DKNlCFnk uumjsSsXEY7UDyoKFSMICOJnDXKPSYnlSh63HGf/G0gmySwkzmKk6HPxdBCTgjjaQ7v3Axw 9pN85AE6GLF2yW7A0U3cz3ootlwmUNr0ju1WAaZ3rSjp9qjXCig0m3hSIQ+Q== ARC-Authentication-Results: i=1; ffmpeg.org; dkim=pass header.d=emresimsirli.com; arc=none; dmarc=pass header.from=emresimsirli.com policy.dmarc=quarantine Authentication-Results: ffmpeg.org; dkim=pass header.d=emresimsirli.com; arc=none (Message is not ARC signed); dmarc=pass (Used From Domain Record) header.from=emresimsirli.com policy.dmarc=quarantine Received: from out-183.mta1.migadu.com (out-183.mta1.migadu.com [95.215.58.183]) by ffbox0-bg.ffmpeg.org (Postfix) with ESMTPS id 723B2691D86 for ; Thu, 26 Feb 2026 00:23:24 +0200 (EET) Message-ID: <9e02b1d1-16e5-483c-a7a5-99a2385bc0c6@emresimsirli.com> DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=emresimsirli.com; s=key1; t=1772058202; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=/mreUkhEneBU2rF2egcDVwxWVsDoDhWQpWV2LvIdwM4=; b=lJsX70R81r4byVpyRs1zBLvkJ+VrmeEDtX5EZuq+7fK4RRh0uRqv/2rQ0sbR7lxedon41r IhA6cjSnwLc20Jq6301FgW7J9DZtp+JyJUneTBt1T+3bcHandr7S/DN2Sd1otwI5DWtHlE B1FFlpuAL59IZGeU3KuRUK368wHHr/4LKDdmwSXH1aiEtZMOyXsZrNFDxEt7OPCBoOSzTq pY+aXsh1OlWWYmDuFk0cOEW2qtu3OL3fYDlqXWAOBhor7Ui23WlcFVk51zdo6hmEo4yHf0 7EuQYP4WLEW3Tyan60T+pOT7lZuqFDpnpRybjfN8SZL5KUCsZt0rf3IyPtNHBQ== Date: Wed, 25 Feb 2026 23:23:15 +0100 MIME-Version: 1.0 X-Report-Abuse: Please report any abuse attempt to abuse@migadu.com and include these headers. To: ffmpeg-devel@ffmpeg.org Content-Language: en-US X-Migadu-Flow: FLOW_OUT Message-ID-Hash: LVPTBSIH34D23LH67NGXF7PSDMMBTECI X-Message-ID-Hash: LVPTBSIH34D23LH67NGXF7PSDMMBTECI X-MailFrom: SRS0=ioPZ=A5=emresimsirli.com=mail@ffmpeg.org X-Mailman-Rule-Misses: dmarc-mitigation; no-senders; approved; loop; banned-address; header-match-ffmpeg-devel.ffmpeg.org-0; header-match-ffmpeg-devel.ffmpeg.org-1; header-match-ffmpeg-devel.ffmpeg.org-2; header-match-ffmpeg-devel.ffmpeg.org-3; emergency; member-moderation; nonmember-moderation; administrivia; implicit-dest; max-recipients; max-size; news-moderation; no-subject; digests; suspicious-header X-Mailman-Version: 3.3.10 Precedence: list Reply-To: FFmpeg development discussions and patches Subject: [FFmpeg-devel] [PATCH] avformat: Add strftime_mkdir command line parameter to segment muxer List-Id: FFmpeg development discussions and patches Archived-At: Archived-At: List-Archive: List-Archive: List-Help: List-Owner: List-Post: List-Subscribe: List-Unsubscribe: From: Emre Simsirli via ffmpeg-devel Cc: Emre Simsirli Content-Type: text/plain; charset="us-ascii"; format="flowed" Content-Transfer-Encoding: 7bit Archived-At: List-Archive: List-Post: Adds strftime_mkdir parameter so that the parent directories defined in the segment name are correctly created. This makes the strftime functionality in 'segment' consistent with 'hls'. Signed-off-by: Emre Simsirli --- libavformat/segment.c | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/libavformat/segment.c b/libavformat/segment.c index 2c7ba0e776..d84115ef3a 100644 --- a/libavformat/segment.c +++ b/libavformat/segment.c @@ -97,6 +97,7 @@ typedef struct SegmentContext { int64_t time; ///< segment duration int64_t min_seg_duration; ///< minimum segment duration int use_strftime; ///< flag to expand filename with strftime + int use_strftime_mkdir; ///< flag to create parent directories with strftime_mkdir int increment_tc; ///< flag to increment timecode if found char *times_str; ///< segment times specification string @@ -208,6 +209,20 @@ static int set_segment_filename(AVFormatContext *s) av_bprint_finalize(&filename, NULL); return AVERROR(ENOMEM); } + + if (seg->use_strftime_mkdir) { + const char* dir; + char* fn_copy = av_strdup(filename.str); + if (!fn_copy) + return AVERROR(ENOMEM); + dir = av_dirname(fn_copy); + if (ff_mkdir_p(dir) == -1 && errno != EEXIST) { + av_log(s, AV_LOG_ERROR, "Could not create directory %s with use_strftime_mkdir\n", dir); + av_freep(&fn_copy); + return AVERROR(errno); + } + av_freep(&fn_copy); + } } else { ret = ff_bprint_get_frame_filename(&filename, s->url, seg->segment_idx, 0); if (ret < 0) { @@ -1077,6 +1092,7 @@ static const AVOption options[] = { { "segment_start_number", "set the sequence number of the first segment", OFFSET(segment_idx), AV_OPT_TYPE_INT, {.i64 = 0}, 0, INT_MAX, E }, { "segment_wrap_number", "set the number of wrap before the first segment", OFFSET(segment_idx_wrap_nb), AV_OPT_TYPE_INT, {.i64 = 0}, 0, INT_MAX, E }, { "strftime", "set filename expansion with strftime at segment creation", OFFSET(use_strftime), AV_OPT_TYPE_BOOL, {.i64 = 0 }, 0, 1, E }, + { "strftime_mkdir", "create last directory component in strftime-generated filename", OFFSET(use_strftime_mkdir), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, E }, { "increment_tc", "increment timecode between each segment", OFFSET(increment_tc), AV_OPT_TYPE_BOOL, {.i64 = 0 }, 0, 1, E }, { "break_non_keyframes", "allow breaking segments on non-keyframes", OFFSET(break_non_keyframes), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, E }, -- 2.53.0 _______________________________________________ ffmpeg-devel mailing list -- ffmpeg-devel@ffmpeg.org To unsubscribe send an email to ffmpeg-devel-leave@ffmpeg.org