|
|
@ -8,6 +8,7 @@ import (
|
|
|
|
"io"
|
|
|
|
"io"
|
|
|
|
"os"
|
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"os/signal"
|
|
|
|
|
|
|
|
"path"
|
|
|
|
"path/filepath"
|
|
|
|
"path/filepath"
|
|
|
|
"runtime"
|
|
|
|
"runtime"
|
|
|
|
"runtime/debug"
|
|
|
|
"runtime/debug"
|
|
|
@ -84,6 +85,11 @@ func printSupportedExtensions() {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func appMain(c *cli.Context) (err error) {
|
|
|
|
func appMain(c *cli.Context) (err error) {
|
|
|
|
|
|
|
|
cwd, err := os.Getwd()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return err
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if c.Bool("supported-ext") {
|
|
|
|
if c.Bool("supported-ext") {
|
|
|
|
printSupportedExtensions()
|
|
|
|
printSupportedExtensions()
|
|
|
|
return nil
|
|
|
|
return nil
|
|
|
@ -92,10 +98,7 @@ func appMain(c *cli.Context) (err error) {
|
|
|
|
if input == "" {
|
|
|
|
if input == "" {
|
|
|
|
switch c.Args().Len() {
|
|
|
|
switch c.Args().Len() {
|
|
|
|
case 0:
|
|
|
|
case 0:
|
|
|
|
input, err = os.Getwd()
|
|
|
|
input = cwd
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return err
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
case 1:
|
|
|
|
input = c.Args().Get(0)
|
|
|
|
input = c.Args().Get(0)
|
|
|
|
default:
|
|
|
|
default:
|
|
|
@ -104,22 +107,20 @@ func appMain(c *cli.Context) (err error) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
output := c.String("output")
|
|
|
|
output := c.String("output")
|
|
|
|
if output == "" {
|
|
|
|
|
|
|
|
var err error
|
|
|
|
|
|
|
|
output, err = os.Getwd()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return err
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if input == output {
|
|
|
|
|
|
|
|
return errors.New("input and output path are same")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
inputStat, err := os.Stat(input)
|
|
|
|
inputStat, err := os.Stat(input)
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if output == "" {
|
|
|
|
|
|
|
|
// Default to where the input is
|
|
|
|
|
|
|
|
if inputStat.IsDir() {
|
|
|
|
|
|
|
|
output = input
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
output = path.Dir(input)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
outputStat, err := os.Stat(output)
|
|
|
|
outputStat, err := os.Stat(output)
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
if errors.Is(err, os.ErrNotExist) {
|
|
|
|
if errors.Is(err, os.ErrNotExist) {
|
|
|
@ -150,8 +151,8 @@ func appMain(c *cli.Context) (err error) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if inputStat.IsDir() {
|
|
|
|
if inputStat.IsDir() {
|
|
|
|
wacthDir := c.Bool("watch")
|
|
|
|
watchDir := c.Bool("watch")
|
|
|
|
if !wacthDir {
|
|
|
|
if !watchDir {
|
|
|
|
return proc.processDir(input)
|
|
|
|
return proc.processDir(input)
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
return proc.watchDir(input)
|
|
|
|
return proc.watchDir(input)
|
|
|
@ -230,29 +231,29 @@ func (p *processor) processDir(inputDir string) error {
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var lastError error = nil
|
|
|
|
for _, item := range items {
|
|
|
|
for _, item := range items {
|
|
|
|
if item.IsDir() {
|
|
|
|
if item.IsDir() {
|
|
|
|
continue
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
filePath := filepath.Join(inputDir, item.Name())
|
|
|
|
filePath := filepath.Join(inputDir, item.Name())
|
|
|
|
allDec := common.GetDecoder(filePath, p.skipNoopDecoder)
|
|
|
|
if err := p.processFile(filePath); err != nil {
|
|
|
|
if len(allDec) == 0 {
|
|
|
|
lastError = err
|
|
|
|
logger.Info("skipping while no suitable decoder", zap.String("source", item.Name()))
|
|
|
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if err := p.process(filePath, allDec); err != nil {
|
|
|
|
|
|
|
|
logger.Error("conversion failed", zap.String("source", item.Name()), zap.Error(err))
|
|
|
|
logger.Error("conversion failed", zap.String("source", item.Name()), zap.Error(err))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if lastError != nil {
|
|
|
|
|
|
|
|
return fmt.Errorf("last error: %w", lastError)
|
|
|
|
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func (p *processor) processFile(filePath string) error {
|
|
|
|
func (p *processor) processFile(filePath string) error {
|
|
|
|
allDec := common.GetDecoder(filePath, p.skipNoopDecoder)
|
|
|
|
allDec := common.GetDecoder(filePath, p.skipNoopDecoder)
|
|
|
|
if len(allDec) == 0 {
|
|
|
|
if len(allDec) == 0 {
|
|
|
|
logger.Fatal("skipping while no suitable decoder")
|
|
|
|
return errors.New("skipping while no suitable decoder")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if err := p.process(filePath, allDec); err != nil {
|
|
|
|
if err := p.process(filePath, allDec); err != nil {
|
|
|
|