mirror of
https://github.com/nu774/fdkaac.git
synced 2025-06-05 23:29:14 +02:00
Compare commits
6 Commits
Author | SHA1 | Date | |
---|---|---|---|
b87f2251a4 | |||
afe73f4916 | |||
fe2d3aa3e7 | |||
2f960ef8fd | |||
fb2b36350a | |||
f5363b23c3 |
176
ChangeLog
176
ChangeLog
@ -0,0 +1,176 @@
|
||||
2013-09-07 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* updated ChangeLog with new git2changelog.py [HEAD]
|
||||
|
||||
2013-06-14 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* add --moov-before-mdat [v0.3.0]
|
||||
|
||||
2013-03-04 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* fix an error message
|
||||
|
||||
2013-03-03 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* bump version [v0.2.0]
|
||||
|
||||
* add --gapless-mode
|
||||
|
||||
2013-02-20 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* simplify __timeb64 condition
|
||||
|
||||
* use fseeko64() on i686-pc-mingw32
|
||||
|
||||
2013-02-18 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* fix build issue on i686-pc-mingw (struct __timeb64 is missing)
|
||||
|
||||
2013-02-17 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* bump version [v0.1.9]
|
||||
|
||||
* fix to accept option -C
|
||||
|
||||
2013-02-16 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* bump version [v0.1.8]
|
||||
|
||||
* refine json metadata importing
|
||||
|
||||
* m4af: duplication check on adding tags
|
||||
|
||||
2013-02-15 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* add --tag-from-json [v0.1.7]
|
||||
|
||||
* fix implicit int variable decl.
|
||||
|
||||
* update m4af
|
||||
|
||||
2013-02-03 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* bump version [v0.1.6]
|
||||
|
||||
* win32: change _wfopen() -> wfsopen()
|
||||
|
||||
2013-01-30 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* update README (add note for character encoding)
|
||||
|
||||
2013-01-28 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* bump version [v0.1.5]
|
||||
|
||||
* gracefully shutdown on signals
|
||||
|
||||
2013-01-27 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* fix MSVC project build issue
|
||||
|
||||
2013-01-25 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* bump version [v0.1.4]
|
||||
|
||||
* add --tag-from-file
|
||||
|
||||
2013-01-24 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* add --silent
|
||||
|
||||
2013-01-19 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* retab
|
||||
|
||||
* bump version [v0.1.3]
|
||||
|
||||
* fix crash on wrong long option, rename --ignore-length to --ignorelength
|
||||
|
||||
2013-01-17 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* bump version [v0.1.2]
|
||||
|
||||
* compat_win32: free argv with atexit()
|
||||
|
||||
* take care of COPYRIGHT-SIGN in UTF-8
|
||||
|
||||
2013-01-15 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* bump version [v0.1.1]
|
||||
|
||||
* fix return type of put_type_entry() to void
|
||||
|
||||
* add ADTS header size(7) to output byte length
|
||||
|
||||
2013-01-13 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* fix mp4 duration & version calcuration [v0.1.0]
|
||||
|
||||
2013-01-11 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* add support for xid
|
||||
|
||||
* support for i686-pc-mingw32 (missing _vscprintf)
|
||||
|
||||
2013-01-10 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* bump version [v0.0.9]
|
||||
|
||||
* rename basename() -> aacenc_basename() and move to compat layer
|
||||
|
||||
2013-01-09 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* add --tag and --long-tag
|
||||
|
||||
* fix corner case of progress display
|
||||
|
||||
* calculate length from file size
|
||||
|
||||
* raw input support
|
||||
|
||||
2013-01-08 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* insert a white space in progress message
|
||||
|
||||
2013-01-07 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* fix typo of bitrate-mode option [v0.0.8]
|
||||
|
||||
* more static inlining (missed on the previous commit) [v0.0.7]
|
||||
|
||||
* check error of fread() and fwrite() [v0.0.6]
|
||||
|
||||
* change inline->static inline to follow C99 semantics (for Clang)
|
||||
|
||||
* explicitly add -lfdk-aac to LDADD in Makefile.am
|
||||
|
||||
* add some files to EXTRA_DIST in Makefile.am
|
||||
|
||||
* fixed a typo in usage message [v0.0.5]
|
||||
|
||||
2013-01-06 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* add MSVC projects
|
||||
|
||||
* add .gitattributes
|
||||
|
||||
* more tweak on configure.ac and Makefile.am (take care of getopt_long) [v0.0.4]
|
||||
|
||||
* use fstat() to test seekability of input file
|
||||
|
||||
* retrieve bitrate for tool tag with aacEncoder_GetParam()
|
||||
|
||||
* output to current working directory by default
|
||||
|
||||
2013-01-05 nu774 <honeycomb77@gmail.com>
|
||||
|
||||
* zero clear LIB_INFO before calling aacEncGetLibInfo() [v0.0.3]
|
||||
|
||||
* tweak configure.ac and Makefile.am
|
||||
|
||||
* update version.h [v0.0.2]
|
||||
|
||||
* fixed to clip before converting float to int
|
||||
|
||||
* initial commit [v0.0.1]
|
||||
|
||||
|
13
README
13
README
@ -32,6 +32,19 @@ look like the following:
|
||||
|
||||
MSVC solution for Visual Studio 2010 is under MSVC directory.
|
||||
|
||||
Available input format
|
||||
----------------------
|
||||
WAV (or RF64), upto 32bit int / 64bit float format is supported.
|
||||
However, since FDK AAC encoder is implemented based on fixed point integer,
|
||||
encoder itself treats 16bit input only.
|
||||
Therefore, when feeding non-integer input, be careful so that input doesn't
|
||||
exceed 0dBFS to avoid hard clips.
|
||||
You might also want to apply dither/noise shape beforehand when your input
|
||||
has higher resolution.
|
||||
|
||||
Note that fdkaac doesn't automatically resample for you
|
||||
when input samplerate is not supported by AAC spec.
|
||||
|
||||
Tagging Options
|
||||
---------------
|
||||
Generic tagging options like --tag, --tag-from-file, --long-tag allows you
|
||||
|
40
git2changelog.py
Executable file
40
git2changelog.py
Executable file
@ -0,0 +1,40 @@
|
||||
#!/usr/bin/env python
|
||||
|
||||
# Copyright (C) 2013 nu774
|
||||
# For conditions of distribution and use, see copyright notice in COPYING
|
||||
|
||||
import sys
|
||||
import re
|
||||
from subprocess import Popen, PIPE
|
||||
from itertools import groupby
|
||||
from collections import namedtuple
|
||||
|
||||
GITLOG_FMT = 'commit %H%nauthor %cn <%ae>%ndate %ad%nsubject %s%nref %d%n%n'
|
||||
GITLOG_CMD = ['git','log','--date=short','--format={0}'.format(GITLOG_FMT)]
|
||||
|
||||
Commit = namedtuple('Commit', 'commit author date subject ref')
|
||||
|
||||
def parse_gitlog(stream):
|
||||
re_decode_tag = re.compile(r'(?<=\()([^,)]+)')
|
||||
commit = dict()
|
||||
for line in stream:
|
||||
fields = line.decode('utf-8').rstrip('\r\n').split(' ', 1)
|
||||
if len(fields) == 2:
|
||||
key, value = fields
|
||||
if key == 'ref':
|
||||
m = re_decode_tag.search(value)
|
||||
value = ' [{0}]'.format(m.group()) if m else ''
|
||||
commit[key] = value
|
||||
elif commit:
|
||||
yield Commit(**commit)
|
||||
commit = dict()
|
||||
|
||||
output=sys.stdout.write
|
||||
|
||||
with Popen(GITLOG_CMD, shell=False, stdout=PIPE).stdout as pipe:
|
||||
commits = parse_gitlog(pipe)
|
||||
commits_by_date_author = groupby(commits, key=lambda x: (x.date, x.author))
|
||||
for (date, author), commits in commits_by_date_author:
|
||||
output('{0} {1}\n\n'.format(date, author))
|
||||
for c in commits:
|
||||
output(' * {0}{1}\n\n'.format(c.subject, c.ref))
|
@ -97,7 +97,7 @@ int aacenc_init(HANDLE_AACENCODER *encoder, const aacenc_param_t *params,
|
||||
}
|
||||
if (aacEncoder_SetParam(*encoder, AACENC_SIGNALING_MODE,
|
||||
params->sbr_signaling) != AACENC_OK) {
|
||||
fprintf(stderr, "ERROR: unsupported transport format\n");
|
||||
fprintf(stderr, "ERROR: failed to set SBR signaling mode\n");
|
||||
goto FAIL;
|
||||
}
|
||||
if (params->adts_crc_check)
|
||||
|
49
src/m4af.c
49
src/m4af.c
@ -23,6 +23,7 @@
|
||||
|
||||
#define m4af_realloc(memory,size) realloc(memory, size)
|
||||
#define m4af_free(memory) free(memory)
|
||||
#define m4af_max(a,b) ((a)<(b)?(b):(a))
|
||||
|
||||
#define M4AF_ATOM_WILD 0xffffffff
|
||||
|
||||
@ -596,12 +597,13 @@ int m4af_set_iTunSMPB(m4af_ctx_t *ctx)
|
||||
}
|
||||
|
||||
static
|
||||
void m4af_update_box_size(m4af_ctx_t *ctx, int64_t pos)
|
||||
uint32_t m4af_update_box_size(m4af_ctx_t *ctx, int64_t pos)
|
||||
{
|
||||
int64_t current_pos = m4af_tell(ctx);
|
||||
m4af_set_pos(ctx, pos);
|
||||
m4af_write32(ctx, current_pos - pos);
|
||||
m4af_set_pos(ctx, current_pos);
|
||||
return current_pos - pos;
|
||||
}
|
||||
|
||||
static
|
||||
@ -769,7 +771,11 @@ void m4af_write_esds_box(m4af_ctx_t *ctx, uint32_t track_idx)
|
||||
, 2);
|
||||
m4af_write24(ctx, track->bufferSizeDB);
|
||||
m4af_write32(ctx, track->maxBitrate);
|
||||
#if 0
|
||||
m4af_write32(ctx, track->avgBitrate);
|
||||
#else
|
||||
m4af_write32(ctx, 0);
|
||||
#endif
|
||||
/* DecoderSpecificInfo */
|
||||
m4af_write_descriptor(ctx, 5, track->decSpecificInfoSize);
|
||||
m4af_write(ctx, track->decSpecificInfo, track->decSpecificInfoSize);
|
||||
@ -1273,7 +1279,7 @@ void m4af_write_udta_box(m4af_ctx_t *ctx)
|
||||
}
|
||||
|
||||
static
|
||||
void m4af_write_moov_box(m4af_ctx_t *ctx)
|
||||
uint32_t m4af_write_moov_box(m4af_ctx_t *ctx)
|
||||
{
|
||||
unsigned i;
|
||||
int64_t pos = m4af_tell(ctx);
|
||||
@ -1283,7 +1289,7 @@ void m4af_write_moov_box(m4af_ctx_t *ctx)
|
||||
m4af_write_trak_box(ctx, i);
|
||||
if (ctx->num_tags)
|
||||
m4af_write_udta_box(ctx);
|
||||
m4af_update_box_size(ctx, pos);
|
||||
return m4af_update_box_size(ctx, pos);
|
||||
}
|
||||
|
||||
static
|
||||
@ -1301,10 +1307,35 @@ void m4af_finalize_mdat(m4af_ctx_t *ctx)
|
||||
m4af_set_pos(ctx, ctx->mdat_pos + ctx->mdat_size);
|
||||
}
|
||||
|
||||
int m4af_finalize(m4af_ctx_t *ctx)
|
||||
static
|
||||
void m4af_shift_mdat_pos(m4af_ctx_t *ctx, uint32_t offset)
|
||||
{
|
||||
unsigned i, j;
|
||||
int64_t begin, end;
|
||||
char buf[8192];
|
||||
|
||||
end = ctx->mdat_pos + ctx->mdat_size;
|
||||
for (; (begin = m4af_max(ctx->mdat_pos, end - 8192)) < end; end = begin) {
|
||||
m4af_set_pos(ctx, begin);
|
||||
ctx->io.read(ctx->io_cookie, buf, end - begin);
|
||||
m4af_set_pos(ctx, begin + offset);
|
||||
m4af_write(ctx, buf, end - begin);
|
||||
}
|
||||
for (i = 0; i < ctx->num_tracks; ++i)
|
||||
for (j = 0; j < ctx->track[i].num_chunks; ++j)
|
||||
ctx->track[i].chunk_table[j].offset += offset;
|
||||
ctx->mdat_pos += offset;
|
||||
m4af_set_pos(ctx, ctx->mdat_pos - 16);
|
||||
m4af_write_free_box(ctx, 0);
|
||||
m4af_write(ctx, "\0\0\0\0mdat", 8);
|
||||
m4af_finalize_mdat(ctx);
|
||||
}
|
||||
|
||||
int m4af_finalize(m4af_ctx_t *ctx, int optimize)
|
||||
{
|
||||
unsigned i;
|
||||
m4af_track_t *track;
|
||||
uint32_t moov_size;
|
||||
|
||||
for (i = 0; i < ctx->num_tracks; ++i) {
|
||||
track = ctx->track + i;
|
||||
@ -1323,6 +1354,14 @@ int m4af_finalize(m4af_ctx_t *ctx)
|
||||
(track->encoder_delay || track->padding))
|
||||
m4af_set_iTunSMPB(ctx);
|
||||
m4af_finalize_mdat(ctx);
|
||||
m4af_write_moov_box(ctx);
|
||||
moov_size = m4af_write_moov_box(ctx);
|
||||
if (optimize) {
|
||||
int64_t pos;
|
||||
m4af_shift_mdat_pos(ctx, moov_size + 1024);
|
||||
m4af_set_pos(ctx, 32);
|
||||
m4af_write_moov_box(ctx);
|
||||
pos = m4af_tell(ctx);
|
||||
m4af_write_free_box(ctx, ctx->mdat_pos - pos - 24);
|
||||
}
|
||||
return ctx->last_error;
|
||||
}
|
||||
|
@ -87,7 +87,7 @@ m4af_ctx_t *m4af_create(uint32_t codec, uint32_t timescale,
|
||||
|
||||
int m4af_begin_write(m4af_ctx_t *ctx);
|
||||
|
||||
int m4af_finalize(m4af_ctx_t *ctx);
|
||||
int m4af_finalize(m4af_ctx_t *ctx, int optimize);
|
||||
|
||||
void m4af_teardown(m4af_ctx_t **ctx);
|
||||
|
||||
|
13
src/main.c
13
src/main.c
@ -154,6 +154,7 @@ PROGNAME " %s\n"
|
||||
" 2: Both\n"
|
||||
" --ignorelength Ignore length of WAV header\n"
|
||||
" -S, --silent Don't print progress messages\n"
|
||||
" --moov-before-mdat Place moov box before mdat box on m4a output\n"
|
||||
"\n"
|
||||
"Options for raw (headerless) input:\n"
|
||||
" -R, --raw Treat input as raw (by default WAV is\n"
|
||||
@ -206,6 +207,7 @@ typedef struct aacenc_param_ex_t {
|
||||
unsigned gapless_mode;
|
||||
unsigned ignore_length;
|
||||
int silent;
|
||||
int moov_before_mdat;
|
||||
|
||||
int is_raw;
|
||||
unsigned raw_channels;
|
||||
@ -223,6 +225,7 @@ int parse_options(int argc, char **argv, aacenc_param_ex_t *params)
|
||||
int ch;
|
||||
unsigned n;
|
||||
|
||||
#define OPT_MOOV_BEFORE_MDAT M4AF_FOURCC('m','o','o','v')
|
||||
#define OPT_RAW_CHANNELS M4AF_FOURCC('r','c','h','n')
|
||||
#define OPT_RAW_RATE M4AF_FOURCC('r','r','a','t')
|
||||
#define OPT_RAW_FORMAT M4AF_FOURCC('r','f','m','t')
|
||||
@ -247,6 +250,7 @@ int parse_options(int argc, char **argv, aacenc_param_ex_t *params)
|
||||
{ "gapless-mode", required_argument, 0, 'G' },
|
||||
{ "ignorelength", no_argument, 0, 'I' },
|
||||
{ "silent", no_argument, 0, 'S' },
|
||||
{ "moov-before-mdat", no_argument, 0, OPT_MOOV_BEFORE_MDAT },
|
||||
|
||||
{ "raw", no_argument, 0, 'R' },
|
||||
{ "raw-channels", required_argument, 0, OPT_RAW_CHANNELS },
|
||||
@ -357,6 +361,9 @@ int parse_options(int argc, char **argv, aacenc_param_ex_t *params)
|
||||
case 'S':
|
||||
params->silent = 1;
|
||||
break;
|
||||
case OPT_MOOV_BEFORE_MDAT:
|
||||
params->moov_before_mdat = 1;
|
||||
break;
|
||||
case 'R':
|
||||
params->is_raw = 1;
|
||||
break;
|
||||
@ -580,7 +587,7 @@ int finalize_m4a(m4af_ctx_t *m4af, const aacenc_param_ex_t *params,
|
||||
|
||||
put_tool_tag(m4af, params, encoder);
|
||||
|
||||
if (m4af_finalize(m4af) < 0) {
|
||||
if (m4af_finalize(m4af, params->moov_before_mdat) < 0) {
|
||||
fprintf(stderr, "ERROR: failed to finalize m4a\n");
|
||||
return -1;
|
||||
}
|
||||
@ -647,7 +654,7 @@ int main(int argc, char **argv)
|
||||
{
|
||||
wav_io_context_t wav_io = { read_callback, seek_callback, tell_callback };
|
||||
m4af_io_callbacks_t
|
||||
m4af_io = { 0, write_callback, seek_callback, tell_callback };
|
||||
m4af_io = { read_callback, write_callback, seek_callback, tell_callback };
|
||||
aacenc_param_ex_t params = { 0 };
|
||||
|
||||
int result = 2;
|
||||
@ -711,7 +718,7 @@ int main(int argc, char **argv)
|
||||
params.output_filename = output_filename;
|
||||
}
|
||||
|
||||
if ((ofp = aacenc_fopen(params.output_filename, "wb")) == 0) {
|
||||
if ((ofp = aacenc_fopen(params.output_filename, "wb+")) == 0) {
|
||||
aacenc_fprintf(stderr, "ERROR: %s: %s\n", params.output_filename,
|
||||
strerror(errno));
|
||||
goto END;
|
||||
|
Reference in New Issue
Block a user