From 86a071acd499e56067a1743e6dea099cd91700ad Mon Sep 17 00:00:00 2001 From: hiwanz Date: Tue, 14 Jan 2025 15:37:50 +0800 Subject: [PATCH] =?UTF-8?q?Refactor:=20=E4=BC=98=E5=8C=96=E8=BD=AC?= =?UTF-8?q?=E6=8D=A2=E8=84=9A=E6=9C=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- converter.sh | 31 ++++++++++++------------------- silk2mp3.rb | 9 +++++---- 2 files changed, 17 insertions(+), 23 deletions(-) diff --git a/converter.sh b/converter.sh index 7f65f0b..33591da 100644 --- a/converter.sh +++ b/converter.sh @@ -1,16 +1,11 @@ #!/bin/bash -# File: converter.sh -# Date: August 19th, 2016 -# Time: 18:56:52 +0800 # Author: kn007 -# Blog: https://kn007.net +# Modified by: hiwanz # Link: https://github.com/kn007/silk-v3-decoder -# Usage: sh converter.sh silk_v3_file/input_folder output_format/output_folder flag(format) -# Flag: not define ---- not define, convert a file -# other value ---- format, convert a folder, batch conversion support -# Requirement: gcc ffmpeg +# Usage: sh converter.sh input_folder output_folder format +# Requirement: ffmpeg -# Colors +# 预设颜色 RED="$(tput setaf 1 2>/dev/null || echo '\e[0;31m')" GREEN="$(tput setaf 2 2>/dev/null || echo '\e[0;32m')" YELLOW="$(tput setaf 3 2>/dev/null || echo '\e[0;33m')" @@ -25,19 +20,16 @@ while [ -L "$SOURCE" ]; do [[ $SOURCE != /* ]] && SOURCE="$DIR/$SOURCE" done cur_dir=$(cd "$(dirname "$SOURCE")" && pwd) +decoder_bin="$cur_dir/silk/decoder" -if [ ! -r "$cur_dir/silk/decoder" ]; then +# 检查是否存在解码器 +if [ ! -r "$decoder_bin" ]; then echo -e "${WHITE}[Notice]${RESET} Silk v3 Decoder is not found, compile it." - cd $cur_dir/silk - make && make decoder - [ ! -r "$cur_dir/silk/decoder" ]&&echo -e "${RED}[Error]${RESET} Silk v3 Decoder Compile False, Please Check Your System For GCC."&&exit - echo -e "${WHITE}========= Silk v3 Decoder Compile Finish =========${RESET}" fi -cd $cur_dir - +# 批量转换 while [ $3 ]; do - [[ ! -z "$(pidof ffmpeg)" ]]&&echo -e "${RED}[Error]${RESET} ffmpeg is occupied by another application, please check it."&&exit + [[ ! -z "$(pgrep ffmpeg)" ]]&&echo -e "${RED}[Error]${RESET} ffmpeg is occupied by another application, please check it."&&exit [ ! -d "$1" ]&&echo -e "${RED}[Error]${RESET} Input folder not found, please check it."&&exit TOTAL=$(ls $1|wc -l) [ ! -d "$2" ]&&mkdir "$2"&&echo -e "${WHITE}[Notice]${RESET} Output folder not found, create it." @@ -46,7 +38,7 @@ while [ $3 ]; do echo -e "${WHITE}========= Batch Conversion Start ==========${RESET}" ls $1 | while read line; do let CURRENT+=1 - $cur_dir/silk/decoder "$1/$line" "$2/$line.pcm" > /dev/null 2>&1 + $decoder_bin "$1/$line" "$2/$line.pcm" > /dev/null 2>&1 if [ ! -f "$2/$line.pcm" ]; then ffmpeg -y -i "$1/$line" "$2/${line%.*}.$3" > /dev/null 2>&1 & ffmpeg_pid=$! @@ -65,7 +57,8 @@ while [ $3 ]; do exit done -$cur_dir/silk/decoder "$1" "$1.pcm" > /dev/null 2>&1 +# 单文件转换 +$decoder_bin "$1" "$1.pcm" > /dev/null 2>&1 if [ ! -f "$1.pcm" ]; then ffmpeg -y -i "$1" "${1%.*}.$2" > /dev/null 2>&1 & ffmpeg_pid=$! diff --git a/silk2mp3.rb b/silk2mp3.rb index ee47cf2..1ec32ff 100644 --- a/silk2mp3.rb +++ b/silk2mp3.rb @@ -1,9 +1,9 @@ class Silk2mp3 < Formula desc "A tool to convert silk files to mp3 files" homepage "https://github.com/hiwanz/homebrew-silk2mp3" - url "https://github.com/user-attachments/files/18406505/silk2mp3-v1.0.0.zip" + url "https://github.com/user-attachments/files/18406942/silk2mp3-v1.0.0.zip" version "1.0.0" - sha256 "a80aa15b3dba0f03a6f1c348c05e4cfc56a4982e4da2555a4527d02ed9a1b4d9" + sha256 "82e67a700c69d26b2832befd4fa11129acb9575818554570abdd3709ea3ebf40" depends_on "ffmpeg" @@ -16,8 +16,9 @@ def install def caveats <<~EOS - Sample: silk2mp3 input.silk mp3 - Sample: silk2mp3 input.silk wav + Sample1: silk2mp3 input.silk mp3 + Sample2: silk2mp3 input.silk wav + Sample3: silk2mp3 input_folder output_folder mp3 EOS end end \ No newline at end of file