diff options
author | Drashna Jael're <drashna@live.com> | 2021-12-07 09:22:22 -0800 |
---|---|---|
committer | Drashna Jael're <drashna@live.com> | 2021-12-07 09:22:22 -0800 |
commit | 43002bdf77ab0f48af6b04e87edcc37f7cb7b905 (patch) | |
tree | 34f973d4cc11bef03d022c8770f0d3daf3386716 /util/sample_parser.py | |
parent | acec40a11a16cb7d8773a753bc166abdbb381ab4 (diff) |
Revert "Revert "Audio system overhaul (#11820)" due to freezing issues"
This reverts commit 996a19ee7ba3308e17fd347afde0b135852835cc.
Diffstat (limited to 'util/sample_parser.py')
-rwxr-xr-x | util/sample_parser.py | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/util/sample_parser.py b/util/sample_parser.py new file mode 100755 index 0000000000..70e193aee7 --- /dev/null +++ b/util/sample_parser.py @@ -0,0 +1,39 @@ +#!/usr/bin/env python3 +# +# Copyright 2019 Jack Humbert +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 2 of the License, or +# (at your option) any later version. +# +# This program 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 General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. +# + +import wave, struct, sys + +waveFile = wave.open(sys.argv[1], 'r') +# print(str(waveFile.getparams())) +# sys.exit() + +if (waveFile.getsampwidth() != 2): + raise(Exception("This script currently only works with 16bit audio files")) + +length = waveFile.getnframes() +out = "#define DAC_SAMPLE_CUSTOM_LENGTH " + str(length) + "\n\n" +out += "static const dacsample_t dac_sample_custom[" + str(length) + "] = {" +for i in range(0,length): + if (i % 8 == 0): + out += "\n " + waveData = waveFile.readframes(1) + data = struct.unpack("<h", waveData) + out += str(int((int(data[0]) + 0x8000) / 16)) + ", " +out = out[:-2] +out += "\n};" +print(out) |