=====================================================================
Notice the major version change which comes with breaking changes to
2.x! Reconstructs "library" functions for both python and zsh scwrypts,
with changes to virtualenv naming conventions (you'll need to refresh
all virtualenv with the appropriate scwrypt).
--- Changes ------------------------------
- changed a naming convention across zsh scripts, particularly
  removing underscores where there is no need to avoid naming clash
  (e.g. 'zsh/lib/utils/io.zsh' renames '__STATUS' to 'STATUS')
- moved clients reliant on py.lib.http to the py.lib.http module
- python scripts now rely on py.lib.scwrypts.execute
- updated package.json in zx scripts to include `type = module`
- 'scwrypts --list' commandline argument now includes additional
  relevant data for each scwrypt
- environment variables no longer add themselves to be staged in the
  '.env.template'
--- New Features -------------------------
- new 'use' syntax for disjoint import within zsh scripts; took me
  a very long time to convince myself this would be necessary
- introduced scwrypt "groups" to allow portable module creation;
  (i.e. ability add your own scripts from another repo!)
- py.lib.scwrypts.io provides a combined IO stream for quick, hybrid
  use of input/output files and stdin/stdout
- py.lib.fzf provides a wrapper to provide similar functionality to
  zsh/utils/io.zsh including fzf_(head|tail)
- improved efficiency of various scwrypts; notably reducing runtime
  of scwrypts/environment sync
- improved scwrypts CLI by adding new options for exact scwrypt
  matching, better filtering, and prettier/more-detailed interfaces
--- New Scripts --------------------------
- py/twilio )
    basic SMS integration with twilio
     - send-sms
- py/directus )
    interactive directus GET query
     - get-items
- py/discord )
    post message to discord channel or webhook
     - post-message
		
	
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/zsh
 | |
| DEPENDENCIES+=()
 | |
| REQUIRED_ENV+=()
 | |
| 
 | |
| use media/youtube
 | |
| 
 | |
| CHECK_ENVIRONMENT
 | |
| #####################################################################
 | |
| 
 | |
| GET_AUDIO_CLIP() {
 | |
| 	local URLS=($@)
 | |
| 
 | |
| 	[[ ${#URLS[@]} -eq 0 ]] && URLS=($(echo '' | FZF_HEAD 'enter URL'))
 | |
| 	[[ ${#URLS[@]} -eq 0 ]] && ABORT
 | |
| 
 | |
| 	local FILENAME=$(YT__GET_FILENAME $URLS)
 | |
| 	[ ! $FILENAME ] && ERROR "unable to download '$URLS'"
 | |
| 
 | |
| 	INPUT_FILE="$YT__OUTPUT_DIR/$FILENAME"
 | |
| 
 | |
| 	[ ! -f "$INPUT_FILE" ] && {
 | |
| 		SCWRYPTS__RUN youtube/download -- $URLS || return 1
 | |
| 	}
 | |
| 
 | |
| 	SUCCESS "video download '$FILENAME' detected!"
 | |
| 
 | |
| 	LENGTH=$(GET_VIDEO_LENGTH "$INPUT_FILE")
 | |
| 	[ ! $LENGTH ] && { ERROR "unable to determine video length for '$INPUT_FILE'"; return 2; }
 | |
| 	START_TIME=$(echo 0 | FZF_HEAD "enter start time (0 ≤ t < $LENGTH)")
 | |
| 	[ ! $START_TIME ] && ABORT
 | |
| 	END_TIME=$(echo $LENGTH | FZF_HEAD "enter end time ($START_TIME > t ≥ $LENGTH)")
 | |
| 	[ ! $END_TIME ] && ABORT
 | |
| 
 | |
| 	STATUS
 | |
| 	STATUS "video      : $FILENAME"
 | |
| 	STATUS "start time : $START_TIME"
 | |
| 	STATUS "end time   : $END_TIME"
 | |
| 	STATUS
 | |
| 	OUTPUT_FILE=$(echo '' \
 | |
| 		| FZF_HEAD 'what should I call this clip? (.mp3)' \
 | |
| 		| sed 's/\.mp3$//' \
 | |
| 	)
 | |
| 	[ ! $OUTPUT_FILE ] && ABORT
 | |
| 	OUTPUT_FILE="$YT__OUTPUT_DIR/$OUTPUT_FILE.mp3"
 | |
| 
 | |
| 	ffmpeg -i "$INPUT_FILE" -q:a 0 -map a \
 | |
| 		-ss $START_TIME -t $(($END_TIME - $START_TIME))\
 | |
| 		"$OUTPUT_FILE" \
 | |
| 		&& SUCCESS "created clip '$OUTPUT_FILE'" \
 | |
| 		|| { ERROR "error creating clip '$(basename $OUTPUT_FILE)' (see above)"; return 3; }
 | |
| }
 | |
| 
 | |
| #####################################################################
 | |
| GET_AUDIO_CLIP $@
 |