Compare commits
12 Commits
0.5.0
...
86886fb5d9
Author | SHA1 | Date | |
---|---|---|---|
86886fb5d9
|
|||
f262d5f931
|
|||
12dc5c8ef9
|
|||
9aaee4c183
|
|||
2017617614
|
|||
21d4afcedb
|
|||
8347e9fbb2
|
|||
8d17a52f00
|
|||
4668da3223
|
|||
a3b30c4543
|
|||
3f358c8b7d
|
|||
7b7c15ad27
|
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
fyne-cross/*
|
||||||
|
ffmpeg/*
|
@@ -35,8 +35,11 @@
|
|||||||
|
|
||||||
## Работа с переводами:
|
## Работа с переводами:
|
||||||
1. go install -v github.com/nicksnyder/go-i18n/v2/goi18n@latest
|
1. go install -v github.com/nicksnyder/go-i18n/v2/goi18n@latest
|
||||||
2. goi18n merge -sourceLanguage ru -outdir languages languages/active.\*.toml languages/translate.\*.toml
|
3. Создаём файл languages/translate.\*.toml
|
||||||
3. В файлах **languages/translate.\*.toml** переводим текст на нужный язык
|
|
||||||
4. goi18n merge -sourceLanguage ru -outdir languages languages/active.\*.toml languages/translate.\*.toml
|
4. goi18n merge -sourceLanguage ru -outdir languages languages/active.\*.toml languages/translate.\*.toml
|
||||||
|
5. В файлах **languages/translate.\*.toml** переводим текст на нужный язык
|
||||||
|
6. goi18n merge -sourceLanguage ru -outdir languages languages/active.\*.toml languages/translate.\*.toml
|
||||||
|
|
||||||
|
___где * подставляем нужный язык___
|
||||||
|
|
||||||
Более подробно можно почитать тут: https://github.com/nicksnyder/go-i18n
|
Более подробно можно почитать тут: https://github.com/nicksnyder/go-i18n
|
@@ -1,24 +1,18 @@
|
|||||||
package convertor
|
package convertor
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
|
||||||
"fyne.io/fyne/v2"
|
|
||||||
"fyne.io/fyne/v2/canvas"
|
"fyne.io/fyne/v2/canvas"
|
||||||
"fyne.io/fyne/v2/container"
|
"fyne.io/fyne/v2/container"
|
||||||
"fyne.io/fyne/v2/storage"
|
|
||||||
"fyne.io/fyne/v2/widget"
|
"fyne.io/fyne/v2/widget"
|
||||||
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel/encoder"
|
|
||||||
"github.com/nicksnyder/go-i18n/v2/i18n"
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
"image/color"
|
"image/color"
|
||||||
"path/filepath"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type ViewContract interface {
|
type ViewContract interface {
|
||||||
Main(
|
Main(
|
||||||
runConvert func(setting HandleConvertSetting),
|
formConversion view.ConversionContract,
|
||||||
formats encoder.ConvertorFormatsContract,
|
|
||||||
)
|
)
|
||||||
SelectFFPath(
|
SelectFFPath(
|
||||||
ffmpegPath string,
|
ffmpegPath string,
|
||||||
@@ -33,275 +27,18 @@ type View struct {
|
|||||||
app kernel.AppContract
|
app kernel.AppContract
|
||||||
}
|
}
|
||||||
|
|
||||||
type HandleConvertSetting struct {
|
|
||||||
VideoFileInput kernel.File
|
|
||||||
DirectoryForSave string
|
|
||||||
OverwriteOutputFiles bool
|
|
||||||
Format string
|
|
||||||
Encoder encoder2.EncoderContract
|
|
||||||
}
|
|
||||||
|
|
||||||
type enableFormConversionStruct struct {
|
|
||||||
fileVideoForConversion *widget.Button
|
|
||||||
buttonForSelectedDir *widget.Button
|
|
||||||
form *widget.Form
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewView(app kernel.AppContract) *View {
|
func NewView(app kernel.AppContract) *View {
|
||||||
return &View{
|
return &View{
|
||||||
app: app,
|
app: app,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v View) Main(
|
func (v View) Main(formConversion view.ConversionContract) {
|
||||||
runConvert func(setting HandleConvertSetting),
|
|
||||||
formats encoder.ConvertorFormatsContract,
|
|
||||||
) {
|
|
||||||
form := &widget.Form{}
|
|
||||||
|
|
||||||
conversionMessage := canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
|
||||||
conversionMessage.TextSize = 16
|
|
||||||
conversionMessage.TextStyle = fyne.TextStyle{Bold: true}
|
|
||||||
|
|
||||||
fileVideoForConversion, fileVideoForConversionMessage, fileInput := v.getButtonFileVideoForConversion(form, conversionMessage)
|
|
||||||
buttonForSelectedDir, buttonForSelectedDirMessage, pathToSaveDirectory := v.getButtonForSelectingDirectoryForSaving()
|
|
||||||
|
|
||||||
isOverwriteOutputFiles := false
|
|
||||||
checkboxOverwriteOutputFilesTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "checkboxOverwriteOutputFilesTitle",
|
|
||||||
})
|
|
||||||
checkboxOverwriteOutputFiles := widget.NewCheck(checkboxOverwriteOutputFilesTitle, func(b bool) {
|
|
||||||
isOverwriteOutputFiles = b
|
|
||||||
})
|
|
||||||
|
|
||||||
selectEncoder := v.getSelectFormat(formats)
|
|
||||||
|
|
||||||
form.Items = []*widget.FormItem{
|
|
||||||
{
|
|
||||||
Text: v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "fileForConversionTitle"}),
|
|
||||||
Widget: fileVideoForConversion,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Widget: container.NewHScroll(fileVideoForConversionMessage),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Text: v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "buttonForSelectedDirTitle"}),
|
|
||||||
Widget: buttonForSelectedDir,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Widget: container.NewHScroll(buttonForSelectedDirMessage),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Widget: checkboxOverwriteOutputFiles,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Widget: selectEncoder.SelectFileType,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Text: v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "selectFormat"}),
|
|
||||||
Widget: selectEncoder.SelectFormat,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Text: v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "selectEncoder"}),
|
|
||||||
Widget: selectEncoder.SelectEncoder,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
form.SubmitText = v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "converterVideoFilesSubmitTitle",
|
|
||||||
})
|
|
||||||
|
|
||||||
enableFormConversionStruct := enableFormConversionStruct{
|
|
||||||
fileVideoForConversion: fileVideoForConversion,
|
|
||||||
buttonForSelectedDir: buttonForSelectedDir,
|
|
||||||
form: form,
|
|
||||||
}
|
|
||||||
|
|
||||||
form.OnSubmit = func() {
|
|
||||||
if len(*pathToSaveDirectory) == 0 {
|
|
||||||
showConversionMessage(conversionMessage, errors.New(v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "errorSelectedFolderSave",
|
|
||||||
})))
|
|
||||||
enableFormConversion(enableFormConversionStruct)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if len(selectEncoder.SelectFormat.Selected) == 0 {
|
|
||||||
showConversionMessage(conversionMessage, errors.New(v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "errorSelectedFormat",
|
|
||||||
})))
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if selectEncoder.Encoder == nil {
|
|
||||||
showConversionMessage(conversionMessage, errors.New(v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "errorSelectedEncoder",
|
|
||||||
})))
|
|
||||||
return
|
|
||||||
}
|
|
||||||
conversionMessage.Text = ""
|
|
||||||
|
|
||||||
fileVideoForConversion.Disable()
|
|
||||||
buttonForSelectedDir.Disable()
|
|
||||||
form.Disable()
|
|
||||||
|
|
||||||
setting := HandleConvertSetting{
|
|
||||||
VideoFileInput: *fileInput,
|
|
||||||
DirectoryForSave: *pathToSaveDirectory,
|
|
||||||
OverwriteOutputFiles: isOverwriteOutputFiles,
|
|
||||||
Format: selectEncoder.SelectFormat.Selected,
|
|
||||||
Encoder: selectEncoder.Encoder,
|
|
||||||
}
|
|
||||||
runConvert(setting)
|
|
||||||
enableFormConversion(enableFormConversionStruct)
|
|
||||||
|
|
||||||
fileVideoForConversionMessage.Text = ""
|
|
||||||
form.Disable()
|
|
||||||
}
|
|
||||||
|
|
||||||
converterVideoFilesTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
converterVideoFilesTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
MessageID: "converterVideoFilesTitle",
|
MessageID: "converterVideoFilesTitle",
|
||||||
})
|
})
|
||||||
v.app.GetWindow().SetContent(widget.NewCard(converterVideoFilesTitle, "", container.NewVBox(form, conversionMessage)))
|
v.app.GetWindow().SetContent(widget.NewCard(converterVideoFilesTitle, "", container.NewVScroll(formConversion.GetContent())))
|
||||||
form.Disable()
|
formConversion.AfterViewContent()
|
||||||
}
|
|
||||||
|
|
||||||
func (v View) getButtonFileVideoForConversion(form *widget.Form, conversionMessage *canvas.Text) (*widget.Button, *canvas.Text, *kernel.File) {
|
|
||||||
fileInput := &kernel.File{}
|
|
||||||
|
|
||||||
fileVideoForConversionMessage := canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
|
||||||
fileVideoForConversionMessage.TextSize = 16
|
|
||||||
fileVideoForConversionMessage.TextStyle = fyne.TextStyle{Bold: true}
|
|
||||||
|
|
||||||
buttonTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "choose",
|
|
||||||
})
|
|
||||||
|
|
||||||
var locationURI fyne.ListableURI
|
|
||||||
|
|
||||||
button := widget.NewButton(buttonTitle, func() {
|
|
||||||
v.app.GetWindow().NewFileOpen(func(r fyne.URIReadCloser, err error) {
|
|
||||||
if err != nil {
|
|
||||||
fileVideoForConversionMessage.Text = err.Error()
|
|
||||||
setStringErrorStyle(fileVideoForConversionMessage)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if r == nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
fileInput.Path = r.URI().Path()
|
|
||||||
fileInput.Name = r.URI().Name()
|
|
||||||
fileInput.Ext = r.URI().Extension()
|
|
||||||
|
|
||||||
fileVideoForConversionMessage.Text = r.URI().Path()
|
|
||||||
setStringSuccessStyle(fileVideoForConversionMessage)
|
|
||||||
|
|
||||||
form.Enable()
|
|
||||||
conversionMessage.Text = ""
|
|
||||||
|
|
||||||
listableURI := storage.NewFileURI(filepath.Dir(r.URI().Path()))
|
|
||||||
locationURI, err = storage.ListerForURI(listableURI)
|
|
||||||
}, locationURI)
|
|
||||||
})
|
|
||||||
|
|
||||||
return button, fileVideoForConversionMessage, fileInput
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v View) getButtonForSelectingDirectoryForSaving() (button *widget.Button, buttonMessage *canvas.Text, dirPath *string) {
|
|
||||||
buttonMessage = canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
|
||||||
buttonMessage.TextSize = 16
|
|
||||||
buttonMessage.TextStyle = fyne.TextStyle{Bold: true}
|
|
||||||
|
|
||||||
path := ""
|
|
||||||
dirPath = &path
|
|
||||||
|
|
||||||
buttonTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "choose",
|
|
||||||
})
|
|
||||||
|
|
||||||
var locationURI fyne.ListableURI
|
|
||||||
|
|
||||||
button = widget.NewButton(buttonTitle, func() {
|
|
||||||
v.app.GetWindow().NewFolderOpen(func(r fyne.ListableURI, err error) {
|
|
||||||
if err != nil {
|
|
||||||
buttonMessage.Text = err.Error()
|
|
||||||
setStringErrorStyle(buttonMessage)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if r == nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
path = r.Path()
|
|
||||||
|
|
||||||
buttonMessage.Text = r.Path()
|
|
||||||
setStringSuccessStyle(buttonMessage)
|
|
||||||
locationURI, _ = storage.ListerForURI(r)
|
|
||||||
|
|
||||||
}, locationURI)
|
|
||||||
})
|
|
||||||
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
type selectEncoder struct {
|
|
||||||
SelectFileType *widget.RadioGroup
|
|
||||||
SelectFormat *widget.Select
|
|
||||||
SelectEncoder *widget.Select
|
|
||||||
Encoder encoder2.EncoderContract
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v View) getSelectFormat(formats encoder.ConvertorFormatsContract) *selectEncoder {
|
|
||||||
selectEncoder := &selectEncoder{}
|
|
||||||
|
|
||||||
encoders := map[int]encoder2.EncoderDataContract{}
|
|
||||||
selectEncoder.SelectEncoder = widget.NewSelect([]string{}, func(s string) {
|
|
||||||
if encoders[selectEncoder.SelectEncoder.SelectedIndex()] == nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
selectEncoder.Encoder = encoders[selectEncoder.SelectEncoder.SelectedIndex()].NewEncoder()
|
|
||||||
})
|
|
||||||
|
|
||||||
formatSelected := ""
|
|
||||||
selectEncoder.SelectFormat = widget.NewSelect([]string{}, func(s string) {
|
|
||||||
if formatSelected == s {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
formatSelected = s
|
|
||||||
format, err := formats.GetFormat(s)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
encoderOptions := []string{}
|
|
||||||
encoders = format.GetEncoders()
|
|
||||||
for _, e := range encoders {
|
|
||||||
encoderOptions = append(encoderOptions, v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "encoder_" + e.GetTitle()}))
|
|
||||||
}
|
|
||||||
selectEncoder.SelectEncoder.SetOptions(encoderOptions)
|
|
||||||
selectEncoder.SelectEncoder.SetSelectedIndex(0)
|
|
||||||
})
|
|
||||||
|
|
||||||
fileTypeOptions := []string{}
|
|
||||||
for _, fileType := range encoder2.GetListFileType() {
|
|
||||||
fileTypeOptions = append(fileTypeOptions, fileType.Name())
|
|
||||||
}
|
|
||||||
selectEncoder.SelectFileType = widget.NewRadioGroup([]string{"video", "audio", "image"}, func(s string) {
|
|
||||||
formatOptions := []string{}
|
|
||||||
for _, f := range formats.GetFormats() {
|
|
||||||
if s != f.GetFileType().Name() {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
formatOptions = append(formatOptions, f.GetTitle())
|
|
||||||
}
|
|
||||||
selectEncoder.SelectFormat.SetOptions(formatOptions)
|
|
||||||
if s == encoder2.FileType(encoder2.Video).Name() {
|
|
||||||
selectEncoder.SelectFormat.SetSelected("mp4")
|
|
||||||
} else {
|
|
||||||
selectEncoder.SelectFormat.SetSelectedIndex(0)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
selectEncoder.SelectFileType.Horizontal = true
|
|
||||||
selectEncoder.SelectFileType.SetSelected("video")
|
|
||||||
|
|
||||||
return selectEncoder
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func setStringErrorStyle(text *canvas.Text) {
|
func setStringErrorStyle(text *canvas.Text) {
|
||||||
@@ -313,14 +50,3 @@ func setStringSuccessStyle(text *canvas.Text) {
|
|||||||
text.Color = color.RGBA{R: 49, G: 127, B: 114, A: 255}
|
text.Color = color.RGBA{R: 49, G: 127, B: 114, A: 255}
|
||||||
text.Refresh()
|
text.Refresh()
|
||||||
}
|
}
|
||||||
|
|
||||||
func showConversionMessage(conversionMessage *canvas.Text, err error) {
|
|
||||||
conversionMessage.Text = err.Error()
|
|
||||||
setStringErrorStyle(conversionMessage)
|
|
||||||
}
|
|
||||||
|
|
||||||
func enableFormConversion(enableFormConversionStruct enableFormConversionStruct) {
|
|
||||||
enableFormConversionStruct.fileVideoForConversion.Enable()
|
|
||||||
enableFormConversionStruct.buttonForSelectedDir.Enable()
|
|
||||||
enableFormConversionStruct.form.Enable()
|
|
||||||
}
|
|
||||||
|
444
convertor/view/conversion.go
Normal file
444
convertor/view/conversion.go
Normal file
@@ -0,0 +1,444 @@
|
|||||||
|
package view
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"fyne.io/fyne/v2"
|
||||||
|
"fyne.io/fyne/v2/canvas"
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/storage"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view/form_items"
|
||||||
|
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel/encoder"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
"image/color"
|
||||||
|
"path/filepath"
|
||||||
|
)
|
||||||
|
|
||||||
|
type ConversionContract interface {
|
||||||
|
GetContent() fyne.CanvasObject
|
||||||
|
AfterViewContent()
|
||||||
|
}
|
||||||
|
|
||||||
|
type Conversion struct {
|
||||||
|
app kernel.AppContract
|
||||||
|
form *form
|
||||||
|
conversionMessage *canvas.Text
|
||||||
|
fileForConversion *fileForConversion
|
||||||
|
directoryForSaving *directoryForSaving
|
||||||
|
overwriteOutputFiles *overwriteOutputFiles
|
||||||
|
selectEncoder *selectEncoder
|
||||||
|
runConvert func(setting HandleConvertSetting)
|
||||||
|
}
|
||||||
|
|
||||||
|
type HandleConvertSetting struct {
|
||||||
|
FileInput kernel.File
|
||||||
|
DirectoryForSave string
|
||||||
|
OverwriteOutputFiles bool
|
||||||
|
Format string
|
||||||
|
Encoder encoder2.EncoderContract
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewConversion(app kernel.AppContract, formats encoder.ConvertorFormatsContract, runConvert func(setting HandleConvertSetting)) *Conversion {
|
||||||
|
conversionMessage := canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
||||||
|
conversionMessage.TextSize = 16
|
||||||
|
conversionMessage.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
fileForConversion := newFileForConversion(app)
|
||||||
|
directoryForSaving := newDirectoryForSaving(app)
|
||||||
|
overwriteOutputFiles := newOverwriteOutputFiles(app)
|
||||||
|
selectEncoder := newSelectEncoder(app, formats)
|
||||||
|
|
||||||
|
items := []*widget.FormItem{
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "fileForConversionTitle"}),
|
||||||
|
Widget: fileForConversion.button,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Widget: container.NewHScroll(fileForConversion.message),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "buttonForSelectedDirTitle"}),
|
||||||
|
Widget: directoryForSaving.button,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Widget: container.NewHScroll(directoryForSaving.message),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Widget: overwriteOutputFiles.checkbox,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Widget: selectEncoder.SelectFileType,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "selectFormat"}),
|
||||||
|
Widget: selectEncoder.SelectFormat,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "selectEncoder"}),
|
||||||
|
Widget: selectEncoder.SelectEncoder,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
form := newForm(app, items)
|
||||||
|
|
||||||
|
return &Conversion{
|
||||||
|
app: app,
|
||||||
|
form: form,
|
||||||
|
conversionMessage: conversionMessage,
|
||||||
|
fileForConversion: fileForConversion,
|
||||||
|
directoryForSaving: directoryForSaving,
|
||||||
|
overwriteOutputFiles: overwriteOutputFiles,
|
||||||
|
selectEncoder: selectEncoder,
|
||||||
|
runConvert: runConvert,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) GetContent() fyne.CanvasObject {
|
||||||
|
c.form.form.OnSubmit = c.submit
|
||||||
|
c.fileForConversion.AddChangeCallback(c.selectFileForConversion)
|
||||||
|
c.selectEncoder.AddChangeCallback(c.changeEncoder)
|
||||||
|
if c.selectEncoder.Encoder != nil {
|
||||||
|
c.selectEncoder.SelectEncoder.SetSelectedIndex(c.selectEncoder.SelectEncoder.SelectedIndex())
|
||||||
|
}
|
||||||
|
|
||||||
|
return container.NewVBox(
|
||||||
|
c.form.form,
|
||||||
|
c.conversionMessage,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) changeEncoder(encoder encoder2.EncoderContract) {
|
||||||
|
items := []*widget.FormItem{}
|
||||||
|
|
||||||
|
if form_items.Views[encoder.GetName()] != nil {
|
||||||
|
items = form_items.Views[encoder.GetName()](encoder, c.app)
|
||||||
|
}
|
||||||
|
|
||||||
|
c.form.ChangeItems(items)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) AfterViewContent() {
|
||||||
|
c.form.form.Disable()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) selectFileForConversion(err error) {
|
||||||
|
c.conversionMessage.Text = ""
|
||||||
|
if err != nil {
|
||||||
|
c.form.form.Disable()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
c.form.form.Enable()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) submit() {
|
||||||
|
if len(c.directoryForSaving.path) == 0 {
|
||||||
|
showConversionMessage(c.conversionMessage, errors.New(c.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "errorSelectedFolderSave",
|
||||||
|
})))
|
||||||
|
c.enableFormConversion()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if len(c.selectEncoder.SelectFormat.Selected) == 0 {
|
||||||
|
showConversionMessage(c.conversionMessage, errors.New(c.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "errorSelectedFormat",
|
||||||
|
})))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if c.selectEncoder.Encoder == nil {
|
||||||
|
showConversionMessage(c.conversionMessage, errors.New(c.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "errorSelectedEncoder",
|
||||||
|
})))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
c.conversionMessage.Text = ""
|
||||||
|
|
||||||
|
c.fileForConversion.button.Disable()
|
||||||
|
c.directoryForSaving.button.Disable()
|
||||||
|
c.form.form.Disable()
|
||||||
|
|
||||||
|
setting := HandleConvertSetting{
|
||||||
|
FileInput: *c.fileForConversion.file,
|
||||||
|
DirectoryForSave: c.directoryForSaving.path,
|
||||||
|
OverwriteOutputFiles: c.overwriteOutputFiles.IsChecked(),
|
||||||
|
Format: c.selectEncoder.SelectFormat.Selected,
|
||||||
|
Encoder: c.selectEncoder.Encoder,
|
||||||
|
}
|
||||||
|
c.runConvert(setting)
|
||||||
|
c.enableFormConversion()
|
||||||
|
|
||||||
|
c.fileForConversion.message.Text = ""
|
||||||
|
c.form.form.Disable()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) enableFormConversion() {
|
||||||
|
c.fileForConversion.button.Enable()
|
||||||
|
c.directoryForSaving.button.Enable()
|
||||||
|
c.form.form.Enable()
|
||||||
|
}
|
||||||
|
|
||||||
|
type fileForConversion struct {
|
||||||
|
button *widget.Button
|
||||||
|
message *canvas.Text
|
||||||
|
file *kernel.File
|
||||||
|
|
||||||
|
changeCallbacks map[int]func(err error)
|
||||||
|
}
|
||||||
|
|
||||||
|
func newFileForConversion(app kernel.AppContract) *fileForConversion {
|
||||||
|
fileForConversion := &fileForConversion{
|
||||||
|
file: &kernel.File{},
|
||||||
|
changeCallbacks: map[int]func(err error){},
|
||||||
|
}
|
||||||
|
|
||||||
|
buttonTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "choose",
|
||||||
|
})
|
||||||
|
|
||||||
|
fileForConversion.message = canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
||||||
|
fileForConversion.message.TextSize = 16
|
||||||
|
fileForConversion.message.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
var locationURI fyne.ListableURI
|
||||||
|
|
||||||
|
fileForConversion.button = widget.NewButton(buttonTitle, func() {
|
||||||
|
app.GetWindow().NewFileOpen(func(r fyne.URIReadCloser, err error) {
|
||||||
|
if err != nil {
|
||||||
|
fileForConversion.message.Text = err.Error()
|
||||||
|
setStringErrorStyle(fileForConversion.message)
|
||||||
|
fileForConversion.eventSelectFile(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if r == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
fileForConversion.file.Path = r.URI().Path()
|
||||||
|
fileForConversion.file.Name = r.URI().Name()
|
||||||
|
fileForConversion.file.Ext = r.URI().Extension()
|
||||||
|
|
||||||
|
fileForConversion.message.Text = r.URI().Path()
|
||||||
|
setStringSuccessStyle(fileForConversion.message)
|
||||||
|
|
||||||
|
fileForConversion.eventSelectFile(nil)
|
||||||
|
|
||||||
|
listableURI := storage.NewFileURI(filepath.Dir(r.URI().Path()))
|
||||||
|
locationURI, err = storage.ListerForURI(listableURI)
|
||||||
|
}, locationURI)
|
||||||
|
})
|
||||||
|
|
||||||
|
return fileForConversion
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c fileForConversion) AddChangeCallback(callback func(err error)) {
|
||||||
|
c.changeCallbacks[len(c.changeCallbacks)] = callback
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c fileForConversion) eventSelectFile(err error) {
|
||||||
|
for _, changeCallback := range c.changeCallbacks {
|
||||||
|
changeCallback(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type directoryForSaving struct {
|
||||||
|
button *widget.Button
|
||||||
|
message *canvas.Text
|
||||||
|
path string
|
||||||
|
}
|
||||||
|
|
||||||
|
func newDirectoryForSaving(app kernel.AppContract) *directoryForSaving {
|
||||||
|
directoryForSaving := &directoryForSaving{
|
||||||
|
path: "",
|
||||||
|
}
|
||||||
|
|
||||||
|
directoryForSaving.message = canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
||||||
|
directoryForSaving.message.TextSize = 16
|
||||||
|
directoryForSaving.message.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
buttonTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "choose",
|
||||||
|
})
|
||||||
|
|
||||||
|
var locationURI fyne.ListableURI
|
||||||
|
|
||||||
|
directoryForSaving.button = widget.NewButton(buttonTitle, func() {
|
||||||
|
app.GetWindow().NewFolderOpen(func(r fyne.ListableURI, err error) {
|
||||||
|
if err != nil {
|
||||||
|
directoryForSaving.message.Text = err.Error()
|
||||||
|
setStringErrorStyle(directoryForSaving.message)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if r == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
directoryForSaving.path = r.Path()
|
||||||
|
|
||||||
|
directoryForSaving.message.Text = r.Path()
|
||||||
|
setStringSuccessStyle(directoryForSaving.message)
|
||||||
|
locationURI, _ = storage.ListerForURI(r)
|
||||||
|
|
||||||
|
}, locationURI)
|
||||||
|
})
|
||||||
|
|
||||||
|
return directoryForSaving
|
||||||
|
}
|
||||||
|
|
||||||
|
type overwriteOutputFiles struct {
|
||||||
|
checkbox *widget.Check
|
||||||
|
isChecked bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func newOverwriteOutputFiles(app kernel.AppContract) *overwriteOutputFiles {
|
||||||
|
overwriteOutputFiles := &overwriteOutputFiles{
|
||||||
|
isChecked: false,
|
||||||
|
}
|
||||||
|
checkboxOverwriteOutputFilesTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "checkboxOverwriteOutputFilesTitle",
|
||||||
|
})
|
||||||
|
overwriteOutputFiles.checkbox = widget.NewCheck(checkboxOverwriteOutputFilesTitle, func(b bool) {
|
||||||
|
overwriteOutputFiles.isChecked = b
|
||||||
|
})
|
||||||
|
|
||||||
|
return overwriteOutputFiles
|
||||||
|
}
|
||||||
|
|
||||||
|
func (receiver overwriteOutputFiles) IsChecked() bool {
|
||||||
|
return receiver.isChecked
|
||||||
|
}
|
||||||
|
|
||||||
|
type selectEncoder struct {
|
||||||
|
SelectFileType *widget.RadioGroup
|
||||||
|
SelectFormat *widget.Select
|
||||||
|
SelectEncoder *widget.Select
|
||||||
|
Encoder encoder2.EncoderContract
|
||||||
|
|
||||||
|
changeCallbacks map[int]func(encoder encoder2.EncoderContract)
|
||||||
|
}
|
||||||
|
|
||||||
|
func newSelectEncoder(app kernel.AppContract, formats encoder.ConvertorFormatsContract) *selectEncoder {
|
||||||
|
selectEncoder := &selectEncoder{
|
||||||
|
changeCallbacks: map[int]func(encoder encoder2.EncoderContract){},
|
||||||
|
}
|
||||||
|
|
||||||
|
encoders := map[int]encoder2.EncoderDataContract{}
|
||||||
|
selectEncoder.SelectEncoder = widget.NewSelect([]string{}, func(s string) {
|
||||||
|
if encoders[selectEncoder.SelectEncoder.SelectedIndex()] == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
selectEncoderData := encoders[selectEncoder.SelectEncoder.SelectedIndex()]
|
||||||
|
selectEncoder.ChangeEncoder(selectEncoderData.NewEncoder())
|
||||||
|
})
|
||||||
|
|
||||||
|
formatSelected := ""
|
||||||
|
selectEncoder.SelectFormat = widget.NewSelect([]string{}, func(s string) {
|
||||||
|
if formatSelected == s {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
formatSelected = s
|
||||||
|
format, err := formats.GetFormat(s)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
encoderOptions := []string{}
|
||||||
|
encoders = map[int]encoder2.EncoderDataContract{}
|
||||||
|
for _, e := range format.GetEncoders() {
|
||||||
|
encoders[len(encoders)] = e
|
||||||
|
encoderOptions = append(encoderOptions, app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "encoder_" + e.GetTitle()}))
|
||||||
|
}
|
||||||
|
selectEncoder.SelectEncoder.SetOptions(encoderOptions)
|
||||||
|
selectEncoder.SelectEncoder.SetSelectedIndex(0)
|
||||||
|
})
|
||||||
|
|
||||||
|
fileTypeOptions := []string{}
|
||||||
|
for _, fileType := range encoder2.GetListFileType() {
|
||||||
|
fileTypeOptions = append(fileTypeOptions, fileType.Name())
|
||||||
|
}
|
||||||
|
|
||||||
|
encoderGroupVideo := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "encoderGroupVideo"})
|
||||||
|
encoderGroupAudio := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "encoderGroupAudio"})
|
||||||
|
encoderGroupImage := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "encoderGroupImage"})
|
||||||
|
encoderGroup := map[string]string{
|
||||||
|
encoderGroupVideo: "video",
|
||||||
|
encoderGroupAudio: "audio",
|
||||||
|
encoderGroupImage: "image",
|
||||||
|
}
|
||||||
|
selectEncoder.SelectFileType = widget.NewRadioGroup([]string{encoderGroupVideo, encoderGroupAudio, encoderGroupImage}, func(s string) {
|
||||||
|
groupCode := encoderGroup[s]
|
||||||
|
|
||||||
|
formatOptions := []string{}
|
||||||
|
for _, f := range formats.GetFormats() {
|
||||||
|
if groupCode != f.GetFileType().Name() {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
formatOptions = append(formatOptions, f.GetTitle())
|
||||||
|
}
|
||||||
|
selectEncoder.SelectFormat.SetOptions(formatOptions)
|
||||||
|
if groupCode == encoder2.FileType(encoder2.Video).Name() {
|
||||||
|
selectEncoder.SelectFormat.SetSelected("mp4")
|
||||||
|
} else {
|
||||||
|
selectEncoder.SelectFormat.SetSelectedIndex(0)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
selectEncoder.SelectFileType.Horizontal = true
|
||||||
|
selectEncoder.SelectFileType.Required = true
|
||||||
|
selectEncoder.SelectFileType.SetSelected(encoderGroupVideo)
|
||||||
|
|
||||||
|
return selectEncoder
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *selectEncoder) ChangeEncoder(encoder encoder2.EncoderContract) {
|
||||||
|
e.Encoder = encoder
|
||||||
|
e.eventSelectEncoder(e.Encoder)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *selectEncoder) AddChangeCallback(callback func(encoder encoder2.EncoderContract)) {
|
||||||
|
e.changeCallbacks[len(e.changeCallbacks)] = callback
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *selectEncoder) eventSelectEncoder(encoder encoder2.EncoderContract) {
|
||||||
|
for _, changeCallback := range e.changeCallbacks {
|
||||||
|
changeCallback(encoder)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func setStringErrorStyle(text *canvas.Text) {
|
||||||
|
text.Color = color.RGBA{R: 255, G: 0, B: 0, A: 255}
|
||||||
|
text.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
func setStringSuccessStyle(text *canvas.Text) {
|
||||||
|
text.Color = color.RGBA{R: 49, G: 127, B: 114, A: 255}
|
||||||
|
text.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
func showConversionMessage(conversionMessage *canvas.Text, err error) {
|
||||||
|
conversionMessage.Text = err.Error()
|
||||||
|
setStringErrorStyle(conversionMessage)
|
||||||
|
}
|
||||||
|
|
||||||
|
type form struct {
|
||||||
|
form *widget.Form
|
||||||
|
items []*widget.FormItem
|
||||||
|
}
|
||||||
|
|
||||||
|
func newForm(app kernel.AppContract, items []*widget.FormItem) *form {
|
||||||
|
f := widget.NewForm()
|
||||||
|
f.SubmitText = app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "converterVideoFilesSubmitTitle",
|
||||||
|
})
|
||||||
|
f.Items = items
|
||||||
|
|
||||||
|
return &form{
|
||||||
|
form: f,
|
||||||
|
items: items,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f form) ChangeItems(items []*widget.FormItem) {
|
||||||
|
f.form.Items = f.items
|
||||||
|
f.form.Refresh()
|
||||||
|
f.form.Items = append(f.form.Items, items...)
|
||||||
|
f.form.Refresh()
|
||||||
|
}
|
16
convertor/view/form_items/form.go
Normal file
16
convertor/view/form_items/form.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package form_items
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view/form_items/h264_nvenc"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view/form_items/libx264"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view/form_items/libx265"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
)
|
||||||
|
|
||||||
|
var Views = map[string]func(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem{
|
||||||
|
"libx264": libx264.View,
|
||||||
|
"h264_nvenc": h264_nvenc.View,
|
||||||
|
"libx265": libx265.View,
|
||||||
|
}
|
65
convertor/view/form_items/h264_nvenc/view.go
Normal file
65
convertor/view/form_items/h264_nvenc/view.go
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
package h264_nvenc
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/h264_nvenc"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
)
|
||||||
|
|
||||||
|
func View(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
items := []*widget.FormItem{}
|
||||||
|
|
||||||
|
items = append(items, presetParameter(encoder, app)...)
|
||||||
|
|
||||||
|
return items
|
||||||
|
}
|
||||||
|
|
||||||
|
func presetParameter(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
parameter, err := encoder.GetParameter("preset")
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
presets := map[string]string{}
|
||||||
|
presetsForSelect := []string{}
|
||||||
|
presetDefault := ""
|
||||||
|
|
||||||
|
for _, name := range h264_nvenc.Presets {
|
||||||
|
title := name
|
||||||
|
presetsForSelect = append(presetsForSelect, name)
|
||||||
|
presets[title] = name
|
||||||
|
if name == parameter.Get() {
|
||||||
|
presetDefault = title
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
elementSelect := widget.NewSelect(presetsForSelect, func(s string) {
|
||||||
|
if presets[s] == "" {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.Set(presets[s])
|
||||||
|
})
|
||||||
|
elementSelect.SetSelected(presetDefault)
|
||||||
|
elementSelect.Hide()
|
||||||
|
|
||||||
|
checkboxTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "parameterCheckbox"})
|
||||||
|
elementCheckbox := widget.NewCheck(checkboxTitle, func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
parameter.SetEnable()
|
||||||
|
elementSelect.Show()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.SetDisable()
|
||||||
|
elementSelect.Hide()
|
||||||
|
})
|
||||||
|
|
||||||
|
return []*widget.FormItem{
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "formPreset"}),
|
||||||
|
Widget: container.NewVBox(elementCheckbox, elementSelect),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
65
convertor/view/form_items/libx264/view.go
Normal file
65
convertor/view/form_items/libx264/view.go
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
package libx264
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libx264"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
)
|
||||||
|
|
||||||
|
func View(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
items := []*widget.FormItem{}
|
||||||
|
|
||||||
|
items = append(items, presetParameter(encoder, app)...)
|
||||||
|
|
||||||
|
return items
|
||||||
|
}
|
||||||
|
|
||||||
|
func presetParameter(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
parameter, err := encoder.GetParameter("preset")
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
presets := map[string]string{}
|
||||||
|
presetsForSelect := []string{}
|
||||||
|
presetDefault := ""
|
||||||
|
|
||||||
|
for _, name := range libx264.Presets {
|
||||||
|
title := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "preset_" + name})
|
||||||
|
presetsForSelect = append(presetsForSelect, title)
|
||||||
|
presets[title] = name
|
||||||
|
if name == parameter.Get() {
|
||||||
|
presetDefault = title
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
elementSelect := widget.NewSelect(presetsForSelect, func(s string) {
|
||||||
|
if presets[s] == "" {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.Set(presets[s])
|
||||||
|
})
|
||||||
|
elementSelect.SetSelected(presetDefault)
|
||||||
|
elementSelect.Hide()
|
||||||
|
|
||||||
|
checkboxTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "parameterCheckbox"})
|
||||||
|
elementCheckbox := widget.NewCheck(checkboxTitle, func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
parameter.SetEnable()
|
||||||
|
elementSelect.Show()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.SetDisable()
|
||||||
|
elementSelect.Hide()
|
||||||
|
})
|
||||||
|
|
||||||
|
return []*widget.FormItem{
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "formPreset"}),
|
||||||
|
Widget: container.NewVBox(elementCheckbox, elementSelect),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
65
convertor/view/form_items/libx265/view.go
Normal file
65
convertor/view/form_items/libx265/view.go
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
package libx265
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libx265"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
)
|
||||||
|
|
||||||
|
func View(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
items := []*widget.FormItem{}
|
||||||
|
|
||||||
|
items = append(items, presetParameter(encoder, app)...)
|
||||||
|
|
||||||
|
return items
|
||||||
|
}
|
||||||
|
|
||||||
|
func presetParameter(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
parameter, err := encoder.GetParameter("preset")
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
presets := map[string]string{}
|
||||||
|
presetsForSelect := []string{}
|
||||||
|
presetDefault := ""
|
||||||
|
|
||||||
|
for _, name := range libx265.Presets {
|
||||||
|
title := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "preset_" + name})
|
||||||
|
presetsForSelect = append(presetsForSelect, title)
|
||||||
|
presets[title] = name
|
||||||
|
if name == parameter.Get() {
|
||||||
|
presetDefault = title
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
elementSelect := widget.NewSelect(presetsForSelect, func(s string) {
|
||||||
|
if presets[s] == "" {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.Set(presets[s])
|
||||||
|
})
|
||||||
|
elementSelect.SetSelected(presetDefault)
|
||||||
|
elementSelect.Hide()
|
||||||
|
|
||||||
|
checkboxTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "parameterCheckbox"})
|
||||||
|
elementCheckbox := widget.NewCheck(checkboxTitle, func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
parameter.SetEnable()
|
||||||
|
elementSelect.Show()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.SetDisable()
|
||||||
|
elementSelect.Hide()
|
||||||
|
})
|
||||||
|
|
||||||
|
return []*widget.FormItem{
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "formPreset"}),
|
||||||
|
Widget: container.NewVBox(elementCheckbox, elementSelect),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
@@ -1,5 +1,5 @@
|
|||||||
//go:build !windows
|
//go:build !windows && !linux
|
||||||
// +build !windows
|
// +build !windows,!linux
|
||||||
|
|
||||||
package convertor
|
package convertor
|
||||||
|
|
||||||
|
63
convertor/view_setting_button_download_ffmpeg_linux.go
Normal file
63
convertor/view_setting_button_download_ffmpeg_linux.go
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
//go:build linux
|
||||||
|
// +build linux
|
||||||
|
|
||||||
|
package convertor
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2"
|
||||||
|
"fyne.io/fyne/v2/canvas"
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
"golang.org/x/image/colornames"
|
||||||
|
"image/color"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (v View) blockDownloadFFmpeg(
|
||||||
|
donwloadFFmpeg func(progressBar *widget.ProgressBar, progressMessage *canvas.Text) error,
|
||||||
|
) *fyne.Container {
|
||||||
|
|
||||||
|
errorDownloadFFmpegMessage := canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
||||||
|
errorDownloadFFmpegMessage.TextSize = 16
|
||||||
|
errorDownloadFFmpegMessage.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
progressDownloadFFmpegMessage := canvas.NewText("", color.RGBA{R: 49, G: 127, B: 114, A: 255})
|
||||||
|
progressDownloadFFmpegMessage.TextSize = 16
|
||||||
|
progressDownloadFFmpegMessage.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
progressBar := widget.NewProgressBar()
|
||||||
|
|
||||||
|
var buttonDownloadFFmpeg *widget.Button
|
||||||
|
|
||||||
|
buttonDownloadFFmpeg = widget.NewButton(v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "download",
|
||||||
|
}), func() {
|
||||||
|
buttonDownloadFFmpeg.Disable()
|
||||||
|
|
||||||
|
err := donwloadFFmpeg(progressBar, progressDownloadFFmpegMessage)
|
||||||
|
if err != nil {
|
||||||
|
errorDownloadFFmpegMessage.Text = err.Error()
|
||||||
|
}
|
||||||
|
|
||||||
|
buttonDownloadFFmpeg.Enable()
|
||||||
|
})
|
||||||
|
|
||||||
|
downloadFFmpegFromSiteMessage := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "downloadFFmpegFromSite",
|
||||||
|
})
|
||||||
|
|
||||||
|
return container.NewVBox(
|
||||||
|
canvas.NewLine(colornames.Darkgreen),
|
||||||
|
widget.NewCard(v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "buttonDownloadFFmpeg",
|
||||||
|
}), "", container.NewVBox(
|
||||||
|
widget.NewRichTextFromMarkdown(
|
||||||
|
downloadFFmpegFromSiteMessage+" [https://github.com/BtbN/FFmpeg-Builds/releases](https://github.com/BtbN/FFmpeg-Builds/releases)",
|
||||||
|
),
|
||||||
|
buttonDownloadFFmpeg,
|
||||||
|
errorDownloadFFmpegMessage,
|
||||||
|
progressDownloadFFmpegMessage,
|
||||||
|
progressBar,
|
||||||
|
)),
|
||||||
|
)
|
||||||
|
}
|
7
db/db.go
Normal file
7
db/db.go
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
package db
|
||||||
|
|
||||||
|
import "errors"
|
||||||
|
|
||||||
|
var (
|
||||||
|
ErrRecordNotFound = errors.New("record not found")
|
||||||
|
)
|
@@ -2,15 +2,13 @@ package apng
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "apng"}
|
return []string{"-c:v", "apng"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("apng", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package bmp
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "bmp"}
|
return []string{"-c:v", "bmp"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("bmp", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -1,7 +1,20 @@
|
|||||||
package encoder
|
package encoder
|
||||||
|
|
||||||
|
import "errors"
|
||||||
|
|
||||||
type EncoderContract interface {
|
type EncoderContract interface {
|
||||||
|
GetName() string
|
||||||
GetParams() []string
|
GetParams() []string
|
||||||
|
GetParameter(name string) (ParameterContract, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
type ParameterContract interface {
|
||||||
|
GetName() string
|
||||||
|
Set(string) error
|
||||||
|
Get() string
|
||||||
|
IsEnabled() bool
|
||||||
|
SetEnable()
|
||||||
|
SetDisable()
|
||||||
}
|
}
|
||||||
|
|
||||||
type EncoderDataContract interface {
|
type EncoderDataContract interface {
|
||||||
@@ -77,3 +90,80 @@ func GetListFileType() []FileTypeContract {
|
|||||||
FileType(Image),
|
FileType(Image),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type Encoder struct {
|
||||||
|
name string
|
||||||
|
parameters map[string]ParameterContract
|
||||||
|
getParams func(parameters map[string]ParameterContract) []string
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewEncoder(name string, parameters map[string]ParameterContract, getParams func(parameters map[string]ParameterContract) []string) *Encoder {
|
||||||
|
return &Encoder{
|
||||||
|
name: name,
|
||||||
|
parameters: parameters,
|
||||||
|
getParams: getParams,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *Encoder) GetName() string {
|
||||||
|
return e.name
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *Encoder) GetParams() []string {
|
||||||
|
return e.getParams(e.parameters)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *Encoder) GetParameter(name string) (ParameterContract, error) {
|
||||||
|
if e.parameters[name] == nil {
|
||||||
|
return nil, errors.New("parameter not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
return e.parameters[name], nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type Parameter struct {
|
||||||
|
name string
|
||||||
|
isEnabled bool
|
||||||
|
parameter string
|
||||||
|
setParameter func(string) (string, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewParameter(name string, isEnabled bool, defaultParameter string, setParameter func(string) (string, error)) *Parameter {
|
||||||
|
return &Parameter{
|
||||||
|
name: name,
|
||||||
|
isEnabled: isEnabled,
|
||||||
|
parameter: defaultParameter,
|
||||||
|
setParameter: setParameter,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) GetName() string {
|
||||||
|
return p.name
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) Set(s string) (err error) {
|
||||||
|
if p.setParameter != nil {
|
||||||
|
s, err = p.setParameter(s)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
p.parameter = s
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) Get() string {
|
||||||
|
return p.parameter
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) IsEnabled() bool {
|
||||||
|
return p.isEnabled
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) SetEnable() {
|
||||||
|
p.isEnabled = true
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) SetDisable() {
|
||||||
|
p.isEnabled = false
|
||||||
|
}
|
||||||
|
@@ -2,15 +2,13 @@ package flv
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "flv"}
|
return []string{"-c:v", "flv"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("flv", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package gif
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "gif"}
|
return []string{"-c:v", "gif"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("gif", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -1,18 +1,40 @@
|
|||||||
package h264_nvenc
|
package h264_nvenc
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
)
|
)
|
||||||
|
|
||||||
type encoder struct {
|
var Presets = []string{
|
||||||
|
"default",
|
||||||
|
"slow",
|
||||||
|
"medium",
|
||||||
|
"fast",
|
||||||
|
"hp",
|
||||||
|
"hq",
|
||||||
|
"bd",
|
||||||
|
"ll",
|
||||||
|
"llhq",
|
||||||
|
"llhp",
|
||||||
|
"lossless",
|
||||||
|
"losslesshp",
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{
|
||||||
}
|
"preset": newParameterPreset(),
|
||||||
|
}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
params := []string{"-c:v", "h264_nvenc"}
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
if parameters["preset"] != nil && parameters["preset"].IsEnabled() {
|
||||||
return []string{"-c:v", "h264_nvenc"}
|
params = append(params, "-preset", parameters["preset"].Get())
|
||||||
|
}
|
||||||
|
|
||||||
|
return params
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("h264_nvenc", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
@@ -21,3 +43,16 @@ func NewData() encoder2.EncoderDataContract {
|
|||||||
fileType := encoder2.FileType(encoder2.Video)
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func newParameterPreset() encoder2.ParameterContract {
|
||||||
|
setParameter := func(s string) (string, error) {
|
||||||
|
for _, value := range Presets {
|
||||||
|
if value == s {
|
||||||
|
return value, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return "", errors.New("preset not found")
|
||||||
|
}
|
||||||
|
return encoder2.NewParameter("preset", false, "default", setParameter)
|
||||||
|
}
|
||||||
|
@@ -2,15 +2,13 @@ package libmp3lame
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:a", "libmp3lame"}
|
return []string{"-c:a", "libmp3lame"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libmp3lame", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package libshine
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:a", "libshine"}
|
return []string{"-c:a", "libshine"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libshine", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package libtwolame
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:a", "libtwolame"}
|
return []string{"-c:a", "libtwolame"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libtwolame", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package libvpx
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "libvpx"}
|
return []string{"-c:v", "libvpx"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libvpx", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package libvpx_vp9
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "libvpx-vp9"}
|
return []string{"-c:v", "libvpx-vp9"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libvpx_vp9", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package libwebp
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "libwebp"}
|
return []string{"-c:v", "libwebp"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libwebp", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package libwebp_anim
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "libwebp_anim"}
|
return []string{"-c:v", "libwebp_anim"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libwebp_anim", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -1,16 +1,38 @@
|
|||||||
package libx264
|
package libx264
|
||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import (
|
||||||
|
"errors"
|
||||||
|
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
)
|
||||||
|
|
||||||
type encoder struct {
|
var Presets = []string{
|
||||||
|
"ultrafast",
|
||||||
|
"superfast",
|
||||||
|
"veryfast",
|
||||||
|
"faster",
|
||||||
|
"fast",
|
||||||
|
"medium",
|
||||||
|
"slow",
|
||||||
|
"slower",
|
||||||
|
"veryslow",
|
||||||
|
"placebo",
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{
|
||||||
}
|
"preset": newParameterPreset(),
|
||||||
|
}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
params := []string{"-c:v", "libx264"}
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
if parameters["preset"] != nil && parameters["preset"].IsEnabled() {
|
||||||
return []string{"-c:v", "libx264"}
|
params = append(params, "-preset", parameters["preset"].Get())
|
||||||
|
}
|
||||||
|
|
||||||
|
return params
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libx264", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
@@ -19,3 +41,16 @@ func NewData() encoder2.EncoderDataContract {
|
|||||||
fileType := encoder2.FileType(encoder2.Video)
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func newParameterPreset() encoder2.ParameterContract {
|
||||||
|
setParameter := func(s string) (string, error) {
|
||||||
|
for _, value := range Presets {
|
||||||
|
if value == s {
|
||||||
|
return value, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return "", errors.New("preset not found")
|
||||||
|
}
|
||||||
|
return encoder2.NewParameter("preset", false, "medium", setParameter)
|
||||||
|
}
|
||||||
|
@@ -1,16 +1,38 @@
|
|||||||
package libx265
|
package libx265
|
||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import (
|
||||||
|
"errors"
|
||||||
|
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
)
|
||||||
|
|
||||||
type encoder struct {
|
var Presets = []string{
|
||||||
|
"ultrafast",
|
||||||
|
"superfast",
|
||||||
|
"veryfast",
|
||||||
|
"faster",
|
||||||
|
"fast",
|
||||||
|
"medium",
|
||||||
|
"slow",
|
||||||
|
"slower",
|
||||||
|
"veryslow",
|
||||||
|
"placebo",
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{
|
||||||
}
|
"preset": newParameterPreset(),
|
||||||
|
}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
params := []string{"-c:v", "libx265"}
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
if parameters["preset"] != nil && parameters["preset"].IsEnabled() {
|
||||||
return []string{"-c:v", "libx265"}
|
params = append(params, "-preset", parameters["preset"].Get())
|
||||||
|
}
|
||||||
|
|
||||||
|
return params
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libx265", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
@@ -19,3 +41,16 @@ func NewData() encoder2.EncoderDataContract {
|
|||||||
fileType := encoder2.FileType(encoder2.Video)
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func newParameterPreset() encoder2.ParameterContract {
|
||||||
|
setParameter := func(s string) (string, error) {
|
||||||
|
for _, value := range Presets {
|
||||||
|
if value == s {
|
||||||
|
return value, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return "", errors.New("preset not found")
|
||||||
|
}
|
||||||
|
return encoder2.NewParameter("preset", false, "medium", setParameter)
|
||||||
|
}
|
||||||
|
@@ -2,15 +2,13 @@ package libxvid
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "libxvid"}
|
return []string{"-c:v", "libxvid"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libxvid", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package mjpeg
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "mjpeg"}
|
return []string{"-c:v", "mjpeg"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mjpeg", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package mp2
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:a", "mp2"}
|
return []string{"-c:a", "mp2"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mp2", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package mp2fixed
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:a", "mp2fixed"}
|
return []string{"-c:a", "mp2fixed"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mp2fixed", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package mpeg1video
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "mpeg1video"}
|
return []string{"-c:v", "mpeg1video"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mpeg1video", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package mpeg2video
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "mpeg2video"}
|
return []string{"-c:v", "mpeg2video"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mpeg2video", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package mpeg4
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "mpeg4"}
|
return []string{"-c:v", "mpeg4"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mpeg4", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package msmpeg4
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "msmpeg4"}
|
return []string{"-c:v", "msmpeg4"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("msmpeg4", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package msmpeg4v2
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "msmpeg4v2"}
|
return []string{"-c:v", "msmpeg4v2"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("msmpeg4v2", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package msvideo1
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "msvideo1"}
|
return []string{"-c:v", "msvideo1"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("msvideo1", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package png
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "png"}
|
return []string{"-c:v", "png"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("png", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package qtrle
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "qtrle"}
|
return []string{"-c:v", "qtrle"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("qtrle", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package sgi
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "sgi"}
|
return []string{"-c:v", "sgi"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("sgi", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package tiff
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "tiff"}
|
return []string{"-c:v", "tiff"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("tiff", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package wmav1
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:a", "wmav1"}
|
return []string{"-c:a", "wmav1"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("wmav1", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package wmav2
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:a", "wmav2"}
|
return []string{"-c:a", "wmav2"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("wmav2", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package wmv1
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "wmv1"}
|
return []string{"-c:v", "wmv1"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("wmv1", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package wmv2
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "wmv2"}
|
return []string{"-c:v", "wmv2"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("wmv2", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
@@ -2,15 +2,13 @@ package xbm
|
|||||||
|
|
||||||
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
type encoder struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEncoder() encoder2.EncoderContract {
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
return &encoder{}
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
}
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
|
||||||
func (e encoder) GetParams() []string {
|
|
||||||
return []string{"-c:v", "xbm"}
|
return []string{"-c:v", "xbm"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("xbm", parameters, getParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewData() encoder2.EncoderDataContract {
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
16
go.mod
16
go.mod
@@ -1,15 +1,18 @@
|
|||||||
module git.kor-elf.net/kor-elf/gui-for-ffmpeg
|
module git.kor-elf.net/kor-elf/gui-for-ffmpeg
|
||||||
|
|
||||||
go 1.21
|
go 1.23
|
||||||
|
|
||||||
|
toolchain go1.23.9
|
||||||
|
|
||||||
require (
|
require (
|
||||||
fyne.io/fyne/v2 v2.4.3
|
fyne.io/fyne/v2 v2.4.3
|
||||||
github.com/BurntSushi/toml v1.3.2
|
github.com/BurntSushi/toml v1.3.2
|
||||||
github.com/mattn/go-sqlite3 v1.14.21
|
github.com/mattn/go-sqlite3 v1.14.21
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.4.0
|
github.com/nicksnyder/go-i18n/v2 v2.4.0
|
||||||
|
github.com/ulikunitz/xz v0.5.12
|
||||||
|
go.etcd.io/bbolt v1.4.0
|
||||||
|
golang.org/x/image v0.11.0
|
||||||
golang.org/x/text v0.14.0
|
golang.org/x/text v0.14.0
|
||||||
gorm.io/driver/sqlite v1.5.4
|
|
||||||
gorm.io/gorm v1.25.6
|
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
@@ -26,19 +29,16 @@ require (
|
|||||||
github.com/go-text/typesetting v0.0.0-20230616162802-9c17dd34aa4a // indirect
|
github.com/go-text/typesetting v0.0.0-20230616162802-9c17dd34aa4a // indirect
|
||||||
github.com/godbus/dbus/v5 v5.1.0 // indirect
|
github.com/godbus/dbus/v5 v5.1.0 // indirect
|
||||||
github.com/gopherjs/gopherjs v1.17.2 // indirect
|
github.com/gopherjs/gopherjs v1.17.2 // indirect
|
||||||
github.com/jinzhu/inflection v1.0.0 // indirect
|
|
||||||
github.com/jinzhu/now v1.1.5 // indirect
|
|
||||||
github.com/jsummers/gobmp v0.0.0-20151104160322-e2ba15ffa76e // indirect
|
github.com/jsummers/gobmp v0.0.0-20151104160322-e2ba15ffa76e // indirect
|
||||||
github.com/pmezard/go-difflib v1.0.0 // indirect
|
github.com/pmezard/go-difflib v1.0.0 // indirect
|
||||||
github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c // indirect
|
github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c // indirect
|
||||||
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef // indirect
|
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef // indirect
|
||||||
github.com/stretchr/testify v1.8.4 // indirect
|
github.com/stretchr/testify v1.10.0 // indirect
|
||||||
github.com/tevino/abool v1.2.0 // indirect
|
github.com/tevino/abool v1.2.0 // indirect
|
||||||
github.com/yuin/goldmark v1.5.5 // indirect
|
github.com/yuin/goldmark v1.5.5 // indirect
|
||||||
golang.org/x/image v0.11.0 // indirect
|
|
||||||
golang.org/x/mobile v0.0.0-20230531173138-3c911d8e3eda // indirect
|
golang.org/x/mobile v0.0.0-20230531173138-3c911d8e3eda // indirect
|
||||||
golang.org/x/net v0.20.0 // indirect
|
golang.org/x/net v0.20.0 // indirect
|
||||||
golang.org/x/sys v0.16.0 // indirect
|
golang.org/x/sys v0.29.0 // indirect
|
||||||
gopkg.in/yaml.v3 v3.0.1 // indirect
|
gopkg.in/yaml.v3 v3.0.1 // indirect
|
||||||
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2 // indirect
|
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2 // indirect
|
||||||
)
|
)
|
||||||
|
45
go.sum
45
go.sum
@@ -73,8 +73,8 @@ github.com/envoyproxy/go-control-plane v0.9.9-0.20201210154907-fd9021fe5dad/go.m
|
|||||||
github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk=
|
github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk=
|
||||||
github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
|
github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
|
||||||
github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4=
|
github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4=
|
||||||
github.com/fredbi/uri v1.0.0 h1:s4QwUAZ8fz+mbTsukND+4V5f+mJ/wjaTokwstGUAemg=
|
github.com/felixge/fgprof v0.9.3 h1:VvyZxILNuCiUCSXtPtYmmtGvb65nqXh2QFWc0Wpf2/g=
|
||||||
github.com/fredbi/uri v1.0.0/go.mod h1:1xC40RnIOGCaQzswaOvrzvG/3M3F0hyDVb3aO/1iGy0=
|
github.com/felixge/fgprof v0.9.3/go.mod h1:RdbpDgzqYVh/T9fPELJyV7EYJuHB55UTEULNun8eiPw=
|
||||||
github.com/fredbi/uri v1.1.0 h1:OqLpTXtyRg9ABReqvDGdJPqZUxs8cyBDOMXBbskCaB8=
|
github.com/fredbi/uri v1.1.0 h1:OqLpTXtyRg9ABReqvDGdJPqZUxs8cyBDOMXBbskCaB8=
|
||||||
github.com/fredbi/uri v1.1.0/go.mod h1:aYTUoAXBOq7BLfVJ8GnKmfcuURosB1xyHDIfWeC/iW4=
|
github.com/fredbi/uri v1.1.0/go.mod h1:aYTUoAXBOq7BLfVJ8GnKmfcuURosB1xyHDIfWeC/iW4=
|
||||||
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
|
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
|
||||||
@@ -87,7 +87,6 @@ github.com/fyne-io/glfw-js v0.0.0-20220120001248-ee7290d23504/go.mod h1:gLRWYfYn
|
|||||||
github.com/fyne-io/image v0.0.0-20220602074514-4956b0afb3d2 h1:hnLq+55b7Zh7/2IRzWCpiTcAvjv/P8ERF+N7+xXbZhk=
|
github.com/fyne-io/image v0.0.0-20220602074514-4956b0afb3d2 h1:hnLq+55b7Zh7/2IRzWCpiTcAvjv/P8ERF+N7+xXbZhk=
|
||||||
github.com/fyne-io/image v0.0.0-20220602074514-4956b0afb3d2/go.mod h1:eO7W361vmlPOrykIg+Rsh1SZ3tQBaOsfzZhsIOb/Lm0=
|
github.com/fyne-io/image v0.0.0-20220602074514-4956b0afb3d2/go.mod h1:eO7W361vmlPOrykIg+Rsh1SZ3tQBaOsfzZhsIOb/Lm0=
|
||||||
github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
|
github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
|
||||||
github.com/go-gl/gl v0.0.0-20211210172815-726fda9656d6 h1:zDw5v7qm4yH7N8C8uWd+8Ii9rROdgWxQuGoJ9WDXxfk=
|
|
||||||
github.com/go-gl/gl v0.0.0-20211210172815-726fda9656d6/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw=
|
github.com/go-gl/gl v0.0.0-20211210172815-726fda9656d6/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw=
|
||||||
github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71 h1:5BVwOaUSBTlVZowGO6VZGw2H/zl9nrd3eCZfYV+NfQA=
|
github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71 h1:5BVwOaUSBTlVZowGO6VZGw2H/zl9nrd3eCZfYV+NfQA=
|
||||||
github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw=
|
github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw=
|
||||||
@@ -95,8 +94,6 @@ github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9
|
|||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20211213063430-748e38ca8aec/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20211213063430-748e38ca8aec/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20221017161538-93cebf72946b h1:GgabKamyOYguHqHjSkDACcgoPIz3w0Dis/zJ1wyHHHU=
|
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20221017161538-93cebf72946b/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240118000515-a250818d05e3 h1:nanQfMsOs3gnuKRm0E5jXWomedE/9YIFXdmHJNZYeqc=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240118000515-a250818d05e3 h1:nanQfMsOs3gnuKRm0E5jXWomedE/9YIFXdmHJNZYeqc=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240118000515-a250818d05e3/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240118000515-a250818d05e3/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
github.com/go-text/render v0.0.0-20230619120952-35bccb6164b8 h1:VkKnvzbvHqgEfm351rfr8Uclu5fnwq8HP2ximUzJsBM=
|
github.com/go-text/render v0.0.0-20230619120952-35bccb6164b8 h1:VkKnvzbvHqgEfm351rfr8Uclu5fnwq8HP2ximUzJsBM=
|
||||||
@@ -167,6 +164,8 @@ github.com/google/pprof v0.0.0-20201023163331-3e6fc7fc9c4c/go.mod h1:kpwsk12EmLe
|
|||||||
github.com/google/pprof v0.0.0-20201203190320-1bf35d6f28c2/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
github.com/google/pprof v0.0.0-20201203190320-1bf35d6f28c2/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
||||||
github.com/google/pprof v0.0.0-20210122040257-d980be63207e/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
github.com/google/pprof v0.0.0-20210122040257-d980be63207e/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
||||||
github.com/google/pprof v0.0.0-20210226084205-cbba55b83ad5/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
github.com/google/pprof v0.0.0-20210226084205-cbba55b83ad5/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
||||||
|
github.com/google/pprof v0.0.0-20211214055906-6f57359322fd h1:1FjCyPC+syAzJ5/2S8fqdZK1R22vvA0J7JZKcuOIQ7Y=
|
||||||
|
github.com/google/pprof v0.0.0-20211214055906-6f57359322fd/go.mod h1:KgnwoLYCZ8IQu3XUZ8Nc/bM9CCZFOyjUNOSygVozoDg=
|
||||||
github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI=
|
github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI=
|
||||||
github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
||||||
github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg=
|
github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg=
|
||||||
@@ -201,10 +200,6 @@ github.com/hashicorp/serf v0.8.2/go.mod h1:6hOLApaqBFA1NXqRQAsxw9QxuDEvNxSQRwA/J
|
|||||||
github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
||||||
github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
||||||
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
|
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
|
||||||
github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E=
|
|
||||||
github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkryuEj+Srlc=
|
|
||||||
github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ=
|
|
||||||
github.com/jinzhu/now v1.1.5/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8=
|
|
||||||
github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
|
github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
|
||||||
github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU=
|
github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU=
|
||||||
github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk=
|
github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk=
|
||||||
@@ -222,8 +217,6 @@ github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
|
|||||||
github.com/magiconair/properties v1.8.5/go.mod h1:y3VJvCyxH9uVvJTWEGAELF3aiYNyPKd5NZ3oSwXrF60=
|
github.com/magiconair/properties v1.8.5/go.mod h1:y3VJvCyxH9uVvJTWEGAELF3aiYNyPKd5NZ3oSwXrF60=
|
||||||
github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
|
github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
|
||||||
github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
|
github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
|
||||||
github.com/mattn/go-sqlite3 v1.14.19 h1:fhGleo2h1p8tVChob4I9HpmVFIAkKGpiukdrgQbWfGI=
|
|
||||||
github.com/mattn/go-sqlite3 v1.14.19/go.mod h1:2eHXhiwb8IkHr+BDWZGa96P6+rkvnG63S2DGjv9HUNg=
|
|
||||||
github.com/mattn/go-sqlite3 v1.14.21 h1:IXocQLOykluc3xPE0Lvy8FtggMz1G+U3mEjg+0zGizc=
|
github.com/mattn/go-sqlite3 v1.14.21 h1:IXocQLOykluc3xPE0Lvy8FtggMz1G+U3mEjg+0zGizc=
|
||||||
github.com/mattn/go-sqlite3 v1.14.21/go.mod h1:Uh1q+B4BYcTPb+yiD3kU8Ct7aC0hY9fxUwlHK0RXw+Y=
|
github.com/mattn/go-sqlite3 v1.14.21/go.mod h1:Uh1q+B4BYcTPb+yiD3kU8Ct7aC0hY9fxUwlHK0RXw+Y=
|
||||||
github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg=
|
github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg=
|
||||||
@@ -240,13 +233,13 @@ github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lN
|
|||||||
github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
|
github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
|
||||||
github.com/neelance/astrewrite v0.0.0-20160511093645-99348263ae86/go.mod h1:kHJEU3ofeGjhHklVoIGuVj85JJwZ6kWPaJwCIxgnFmo=
|
github.com/neelance/astrewrite v0.0.0-20160511093645-99348263ae86/go.mod h1:kHJEU3ofeGjhHklVoIGuVj85JJwZ6kWPaJwCIxgnFmo=
|
||||||
github.com/neelance/sourcemap v0.0.0-20200213170602-2833bce08e4c/go.mod h1:Qr6/a/Q4r9LP1IltGz7tA7iOK1WonHEYhu1HRBA7ZiM=
|
github.com/neelance/sourcemap v0.0.0-20200213170602-2833bce08e4c/go.mod h1:Qr6/a/Q4r9LP1IltGz7tA7iOK1WonHEYhu1HRBA7ZiM=
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.3.0 h1:2NPsCsNFCVd7i+Su0xYsBrIhS3bE2XMv5gNTft2O+PQ=
|
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.3.0/go.mod h1:nxYSZE9M0bf3Y70gPQjN9ha7XNHX7gMc814+6wVyEI4=
|
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.4.0 h1:3IcvPOAvnCKwNm0TB0dLDTuawWEj+ax/RERNC+diLMM=
|
github.com/nicksnyder/go-i18n/v2 v2.4.0 h1:3IcvPOAvnCKwNm0TB0dLDTuawWEj+ax/RERNC+diLMM=
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.4.0/go.mod h1:nxYSZE9M0bf3Y70gPQjN9ha7XNHX7gMc814+6wVyEI4=
|
github.com/nicksnyder/go-i18n/v2 v2.4.0/go.mod h1:nxYSZE9M0bf3Y70gPQjN9ha7XNHX7gMc814+6wVyEI4=
|
||||||
github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
|
github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
|
||||||
github.com/pelletier/go-toml v1.9.3/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c=
|
github.com/pelletier/go-toml v1.9.3/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c=
|
||||||
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
|
github.com/pkg/profile v1.7.0 h1:hnbDkaNWPCLMO9wGLdBFTIZvzDrDfBM2072E1S9gJkA=
|
||||||
|
github.com/pkg/profile v1.7.0/go.mod h1:8Uer0jas47ZQMJ7VD+OHknK4YDY07LPUC6dEvqDjvNo=
|
||||||
github.com/pkg/sftp v1.10.1/go.mod h1:lYOWFsE0bwd1+KfKJaKeuokY15vzFx25BLbzYYoAxZI=
|
github.com/pkg/sftp v1.10.1/go.mod h1:lYOWFsE0bwd1+KfKJaKeuokY15vzFx25BLbzYYoAxZI=
|
||||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||||
@@ -274,7 +267,6 @@ github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c/go.mod h1:cNQ3dwVJtS
|
|||||||
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef h1:Ch6Q+AZUxDBCVqdkI8FSpFyZDtCVBc2VmejdNrm5rRQ=
|
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef h1:Ch6Q+AZUxDBCVqdkI8FSpFyZDtCVBc2VmejdNrm5rRQ=
|
||||||
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef/go.mod h1:nXTWP6+gD5+LUJ8krVhhoeHjvHTutPxMYl5SvkcnJNE=
|
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef/go.mod h1:nXTWP6+gD5+LUJ8krVhhoeHjvHTutPxMYl5SvkcnJNE=
|
||||||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||||
github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw=
|
|
||||||
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
||||||
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
||||||
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
||||||
@@ -282,12 +274,13 @@ github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5
|
|||||||
github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
|
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
|
||||||
github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcUk=
|
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
||||||
github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo=
|
|
||||||
github.com/subosito/gotenv v1.2.0/go.mod h1:N0PQaV/YGNqwC0u51sEeR/aUtSLEXKX9iv69rRypqCw=
|
github.com/subosito/gotenv v1.2.0/go.mod h1:N0PQaV/YGNqwC0u51sEeR/aUtSLEXKX9iv69rRypqCw=
|
||||||
github.com/tevino/abool v1.2.0 h1:heAkClL8H6w+mK5md9dzsuohKeXHUpY7Vw0ZCKW+huA=
|
github.com/tevino/abool v1.2.0 h1:heAkClL8H6w+mK5md9dzsuohKeXHUpY7Vw0ZCKW+huA=
|
||||||
github.com/tevino/abool v1.2.0/go.mod h1:qc66Pna1RiIsPa7O4Egxxs9OqkuxDX55zznh9K07Tzg=
|
github.com/tevino/abool v1.2.0/go.mod h1:qc66Pna1RiIsPa7O4Egxxs9OqkuxDX55zznh9K07Tzg=
|
||||||
|
github.com/ulikunitz/xz v0.5.12 h1:37Nm15o69RwBkXM0J6A5OlE67RZTfzUxTj8fB3dfcsc=
|
||||||
|
github.com/ulikunitz/xz v0.5.12/go.mod h1:nbz6k7qbPmH4IRqmfOplQw/tblSgqTqBwxkY0oWt/14=
|
||||||
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
@@ -297,6 +290,8 @@ github.com/yuin/goldmark v1.4.0/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1
|
|||||||
github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
|
github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
|
||||||
github.com/yuin/goldmark v1.5.5 h1:IJznPe8wOzfIKETmMkd06F8nXkmlhaHqFRM9l1hAGsU=
|
github.com/yuin/goldmark v1.5.5 h1:IJznPe8wOzfIKETmMkd06F8nXkmlhaHqFRM9l1hAGsU=
|
||||||
github.com/yuin/goldmark v1.5.5/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
|
github.com/yuin/goldmark v1.5.5/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
|
||||||
|
go.etcd.io/bbolt v1.4.0 h1:TU77id3TnN/zKr7CO/uk+fBCwF2jGcMuw2B/FMAzYIk=
|
||||||
|
go.etcd.io/bbolt v1.4.0/go.mod h1:AsD+OCi/qPN1giOX1aiLAha3o1U8rAz65bvN4j0sRuk=
|
||||||
go.etcd.io/etcd/api/v3 v3.5.0/go.mod h1:cbVKeC6lCfl7j/8jBhAK6aIYO9XOjdptoxU/nLQcPvs=
|
go.etcd.io/etcd/api/v3 v3.5.0/go.mod h1:cbVKeC6lCfl7j/8jBhAK6aIYO9XOjdptoxU/nLQcPvs=
|
||||||
go.etcd.io/etcd/client/pkg/v3 v3.5.0/go.mod h1:IJHfcCEKxYu1Os13ZdwCwIUTUVGYTSAM3YSwc9/Ac1g=
|
go.etcd.io/etcd/client/pkg/v3 v3.5.0/go.mod h1:IJHfcCEKxYu1Os13ZdwCwIUTUVGYTSAM3YSwc9/Ac1g=
|
||||||
go.etcd.io/etcd/client/v2 v2.305.0/go.mod h1:h9puh54ZTgAKtEbut2oe9P4L/oqKCVB6xsXlzd7alYQ=
|
go.etcd.io/etcd/client/v2 v2.305.0/go.mod h1:h9puh54ZTgAKtEbut2oe9P4L/oqKCVB6xsXlzd7alYQ=
|
||||||
@@ -401,8 +396,6 @@ golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96b
|
|||||||
golang.org/x/net v0.0.0-20210805182204-aaa1db679c0d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
|
golang.org/x/net v0.0.0-20210805182204-aaa1db679c0d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
|
||||||
golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c=
|
golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c=
|
||||||
golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
|
golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
|
||||||
golang.org/x/net v0.17.0 h1:pVaXccu2ozPjCXewfr1S7xza/zcXTity9cCdXQYSjIM=
|
|
||||||
golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE=
|
|
||||||
golang.org/x/net v0.20.0 h1:aCL9BSgETF1k+blQaYUBx9hJ9LOGP3gAVemcZlf1Kpo=
|
golang.org/x/net v0.20.0 h1:aCL9BSgETF1k+blQaYUBx9hJ9LOGP3gAVemcZlf1Kpo=
|
||||||
golang.org/x/net v0.20.0/go.mod h1:z8BVo6PvndSri0LbOE3hAn0apkU+1YvI6E70E9jsnvY=
|
golang.org/x/net v0.20.0/go.mod h1:z8BVo6PvndSri0LbOE3hAn0apkU+1YvI6E70E9jsnvY=
|
||||||
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
|
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
|
||||||
@@ -430,6 +423,8 @@ golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJ
|
|||||||
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.10.0 h1:3NQrjDixjgGwUOCaF8w2+VYHv0Ve/vGYSbdkTa98gmQ=
|
||||||
|
golang.org/x/sync v0.10.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
|
||||||
golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
golang.org/x/sys v0.0.0-20181026203630-95b1ffbd15a5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20181026203630-95b1ffbd15a5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
@@ -479,10 +474,8 @@ golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBc
|
|||||||
golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.0.0-20220908164124-27713097b956/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.0.0-20220908164124-27713097b956/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.13.0 h1:Af8nKPmuFypiUBjVoU9V20FiaFXOcuZI21p0ycVYYGE=
|
golang.org/x/sys v0.29.0 h1:TPYlXGxvx1MGTn2GiZDhnjPA9wZzZeGKHHmKhHYvgaU=
|
||||||
golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.29.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
||||||
golang.org/x/sys v0.16.0 h1:xWw16ngr6ZMtmxDyKyIgsE93KNKz5HKmMa3b8ALHidU=
|
|
||||||
golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
|
||||||
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
|
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
|
||||||
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
|
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
|
||||||
golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k=
|
golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k=
|
||||||
@@ -677,12 +670,6 @@ gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C
|
|||||||
gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
||||||
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gorm.io/driver/sqlite v1.5.4 h1:IqXwXi8M/ZlPzH/947tn5uik3aYQslP9BVveoax0nV0=
|
|
||||||
gorm.io/driver/sqlite v1.5.4/go.mod h1:qxAuCol+2r6PannQDpOP1FP6ag3mKi4esLnB/jHed+4=
|
|
||||||
gorm.io/gorm v1.25.5 h1:zR9lOiiYf09VNh5Q1gphfyia1JpiClIWG9hQaxB/mls=
|
|
||||||
gorm.io/gorm v1.25.5/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8=
|
|
||||||
gorm.io/gorm v1.25.6 h1:V92+vVda1wEISSOMtodHVRcUIOPYa2tgQtyF+DfFx+A=
|
|
||||||
gorm.io/gorm v1.25.6/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8=
|
|
||||||
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2 h1:oomkgU6VaQDsV6qZby2uz1Lap0eXmku8+2em3A/l700=
|
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2 h1:oomkgU6VaQDsV6qZby2uz1Lap0eXmku8+2em3A/l700=
|
||||||
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2/go.mod h1:sUMDUKNB2ZcVjt92UnLy3cdGs+wDAcrPdV3JP6sVgA4=
|
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2/go.mod h1:sUMDUKNB2ZcVjt92UnLy3cdGs+wDAcrPdV3JP6sVgA4=
|
||||||
honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
||||||
|
@@ -3,6 +3,7 @@ package handler
|
|||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view"
|
||||||
error2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/error"
|
error2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/error"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/helper"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/helper"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
@@ -44,7 +45,8 @@ func (h ConvertorHandler) MainConvertor() {
|
|||||||
h.errorView.PanicError(err)
|
h.errorView.PanicError(err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
h.convertorView.Main(h.runConvert, formats)
|
conversion := view.NewConversion(h.app, formats, h.runConvert)
|
||||||
|
h.convertorView.Main(conversion)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
h.convertorView.SelectFFPath("", "", h.saveSettingFFPath, nil, h.downloadFFmpeg)
|
h.convertorView.SelectFFPath("", "", h.saveSettingFFPath, nil, h.downloadFFmpeg)
|
||||||
@@ -64,12 +66,12 @@ func (h ConvertorHandler) GetFfprobeVersion() (string, error) {
|
|||||||
return h.app.GetConvertorService().GetFFprobeVersion()
|
return h.app.GetConvertorService().GetFFprobeVersion()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h ConvertorHandler) runConvert(setting convertor.HandleConvertSetting) {
|
func (h ConvertorHandler) runConvert(setting view.HandleConvertSetting) {
|
||||||
h.app.GetQueue().Add(&kernel.ConvertSetting{
|
h.app.GetQueue().Add(&kernel.ConvertSetting{
|
||||||
VideoFileInput: setting.VideoFileInput,
|
VideoFileInput: setting.FileInput,
|
||||||
VideoFileOut: kernel.File{
|
VideoFileOut: kernel.File{
|
||||||
Path: setting.DirectoryForSave + helper.PathSeparator() + setting.VideoFileInput.Name + "." + setting.Format,
|
Path: setting.DirectoryForSave + helper.PathSeparator() + setting.FileInput.Name + "." + setting.Format,
|
||||||
Name: setting.VideoFileInput.Name,
|
Name: setting.FileInput.Name,
|
||||||
Ext: "." + setting.Format,
|
Ext: "." + setting.Format,
|
||||||
},
|
},
|
||||||
OverwriteOutputFiles: setting.OverwriteOutputFiles,
|
OverwriteOutputFiles: setting.OverwriteOutputFiles,
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
//go:build !windows
|
//go:build !windows && !linux
|
||||||
// +build !windows
|
// +build !windows,!linux
|
||||||
|
|
||||||
package handler
|
package handler
|
||||||
|
|
||||||
|
208
handler/convertor_linux.go
Normal file
208
handler/convertor_linux.go
Normal file
@@ -0,0 +1,208 @@
|
|||||||
|
//go:build linux
|
||||||
|
// +build linux
|
||||||
|
|
||||||
|
package handler
|
||||||
|
|
||||||
|
import (
|
||||||
|
"archive/tar"
|
||||||
|
"errors"
|
||||||
|
"fyne.io/fyne/v2/canvas"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
"github.com/ulikunitz/xz"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
)
|
||||||
|
|
||||||
|
func getPathsToFF() []kernel.FFPathUtilities {
|
||||||
|
return []kernel.FFPathUtilities{{"ffmpeg/bin/ffmpeg", "ffmpeg/bin/ffprobe"}, {"ffmpeg", "ffprobe"}}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h ConvertorHandler) downloadFFmpeg(progressBar *widget.ProgressBar, progressMessage *canvas.Text) (err error) {
|
||||||
|
isDirectoryFFmpeg := isDirectory("ffmpeg")
|
||||||
|
if isDirectoryFFmpeg == false {
|
||||||
|
err = os.Mkdir("ffmpeg", 0777)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
progressMessage.Text = h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "downloadRun",
|
||||||
|
})
|
||||||
|
progressMessage.Refresh()
|
||||||
|
err = downloadFile("ffmpeg/ffmpeg.tar.xz", "https://github.com/BtbN/FFmpeg-Builds/releases/download/latest/ffmpeg-master-latest-linux64-gpl.tar.xz", progressBar)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
progressMessage.Text = h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "unzipRun",
|
||||||
|
})
|
||||||
|
progressMessage.Refresh()
|
||||||
|
err = unTarXz("ffmpeg/ffmpeg.tar.xz", "ffmpeg", progressBar)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
_ = os.Remove("ffmpeg/ffmpeg.tar.xz")
|
||||||
|
|
||||||
|
progressMessage.Text = h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "testFF",
|
||||||
|
})
|
||||||
|
progressMessage.Refresh()
|
||||||
|
|
||||||
|
err = h.saveSettingFFPath("ffmpeg/ffmpeg-master-latest-linux64-gpl/bin/ffmpeg", "ffmpeg/ffmpeg-master-latest-linux64-gpl/bin/ffprobe")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func downloadFile(filepath string, url string, progressBar *widget.ProgressBar) (err error) {
|
||||||
|
progressBar.Value = 0
|
||||||
|
progressBar.Max = 100
|
||||||
|
|
||||||
|
req, err := http.NewRequest("GET", url, nil)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
resp, err := http.DefaultClient.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
|
||||||
|
f, err := os.OpenFile(filepath, os.O_CREATE|os.O_WRONLY, 0644)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
|
||||||
|
buf := make([]byte, 32*1024)
|
||||||
|
var downloaded int64
|
||||||
|
for {
|
||||||
|
n, err := resp.Body.Read(buf)
|
||||||
|
if err != nil {
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if n > 0 {
|
||||||
|
f.Write(buf[:n])
|
||||||
|
downloaded += int64(n)
|
||||||
|
progressBar.Value = float64(downloaded) / float64(resp.ContentLength) * 100
|
||||||
|
progressBar.Refresh()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func unTarXz(fileTar string, directory string, progressBar *widget.ProgressBar) error {
|
||||||
|
progressBar.Value = 0
|
||||||
|
progressBar.Max = 100
|
||||||
|
|
||||||
|
f, err := os.Open(fileTar)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
|
||||||
|
xzReader, err := xz.NewReader(f)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
tarReader := tar.NewReader(xzReader)
|
||||||
|
|
||||||
|
totalFiles := 0
|
||||||
|
for {
|
||||||
|
_, err := tarReader.Next()
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
totalFiles++
|
||||||
|
}
|
||||||
|
|
||||||
|
// Rewind back to the beginning of the file to re-process
|
||||||
|
_, err = f.Seek(0, 0)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
xzReader, err = xz.NewReader(f)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
tarReader = tar.NewReader(xzReader)
|
||||||
|
|
||||||
|
// We count the number of files already unpacked
|
||||||
|
unpackedFiles := 0
|
||||||
|
|
||||||
|
for {
|
||||||
|
header, err := tarReader.Next()
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
targetPath := filepath.Join(directory, header.Name)
|
||||||
|
switch header.Typeflag {
|
||||||
|
case tar.TypeDir:
|
||||||
|
err := os.MkdirAll(targetPath, 0755)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
case tar.TypeReg:
|
||||||
|
outFile, err := os.Create(targetPath)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer outFile.Close()
|
||||||
|
|
||||||
|
_, err = io.Copy(outFile, tarReader)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
return errors.New("unsupported file type")
|
||||||
|
}
|
||||||
|
|
||||||
|
unpackedFiles++
|
||||||
|
progressBar.Value = float64(unpackedFiles) / float64(totalFiles) * 100
|
||||||
|
progressBar.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
ffmpegPath := filepath.Join(directory, "ffmpeg-master-latest-linux64-gpl", "bin", "ffmpeg")
|
||||||
|
err = os.Chmod(ffmpegPath, 0755)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
ffprobePath := filepath.Join(directory, "ffmpeg-master-latest-linux64-gpl", "bin", "ffprobe")
|
||||||
|
err = os.Chmod(ffprobePath, 0755)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func isDirectory(path string) bool {
|
||||||
|
fileInfo, err := os.Stat(path)
|
||||||
|
if err != nil {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
return fileInfo.IsDir()
|
||||||
|
}
|
@@ -42,7 +42,7 @@ func (h ConvertorHandler) downloadFFmpeg(progressBar *widget.ProgressBar, progre
|
|||||||
MessageID: "unzipRun",
|
MessageID: "unzipRun",
|
||||||
})
|
})
|
||||||
progressMessage.Refresh()
|
progressMessage.Refresh()
|
||||||
err = unZip("ffmpeg/ffmpeg.zip", "ffmpeg")
|
err = unZip("ffmpeg/ffmpeg.zip", "ffmpeg", progressBar)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -100,13 +100,23 @@ func downloadFile(filepath string, url string, progressBar *widget.ProgressBar)
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func unZip(fileZip string, directory string) error {
|
func unZip(fileZip string, directory string, progressBar *widget.ProgressBar) error {
|
||||||
|
progressBar.Value = 0
|
||||||
|
progressBar.Max = 100
|
||||||
|
|
||||||
archive, err := zip.OpenReader(fileZip)
|
archive, err := zip.OpenReader(fileZip)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
defer archive.Close()
|
defer archive.Close()
|
||||||
|
|
||||||
|
totalBytes := int64(0)
|
||||||
|
for _, f := range archive.File {
|
||||||
|
totalBytes += int64(f.UncompressedSize64)
|
||||||
|
}
|
||||||
|
|
||||||
|
unpackedBytes := int64(0)
|
||||||
|
|
||||||
for _, f := range archive.File {
|
for _, f := range archive.File {
|
||||||
filePath := filepath.Join(directory, f.Name)
|
filePath := filepath.Join(directory, f.Name)
|
||||||
|
|
||||||
@@ -132,10 +142,15 @@ func unZip(fileZip string, directory string) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if _, err := io.Copy(dstFile, fileInArchive); err != nil {
|
bytesRead, err := io.Copy(dstFile, fileInArchive)
|
||||||
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unpackedBytes += bytesRead
|
||||||
|
progressBar.Value = float64(unpackedBytes) / float64(totalBytes) * 100
|
||||||
|
progressBar.Refresh()
|
||||||
|
|
||||||
dstFile.Close()
|
dstFile.Close()
|
||||||
fileInArchive.Close()
|
fileInArchive.Close()
|
||||||
}
|
}
|
||||||
|
@@ -22,7 +22,8 @@ type Window struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func newWindow(w fyne.Window, layout LayoutContract) Window {
|
func newWindow(w fyne.Window, layout LayoutContract) Window {
|
||||||
w.Resize(fyne.Size{Width: 1039, Height: 599})
|
windowSize := fyne.Size{Width: 1039, Height: 599}
|
||||||
|
w.Resize(windowSize)
|
||||||
w.CenterOnScreen()
|
w.CenterOnScreen()
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
@@ -30,11 +31,10 @@ func newWindow(w fyne.Window, layout LayoutContract) Window {
|
|||||||
* Bug fixed.
|
* Bug fixed.
|
||||||
* When starting the program, sometimes the window was displayed incorrectly.
|
* When starting the program, sometimes the window was displayed incorrectly.
|
||||||
*/
|
*/
|
||||||
|
windowSize.Width += 1
|
||||||
|
windowSize.Height += 1
|
||||||
time.Sleep(time.Millisecond * 500)
|
time.Sleep(time.Millisecond * 500)
|
||||||
size := w.Canvas().Size()
|
w.Resize(windowSize)
|
||||||
size.Width += 1
|
|
||||||
size.Height += 1
|
|
||||||
w.Resize(size)
|
|
||||||
}()
|
}()
|
||||||
|
|
||||||
return Window{
|
return Window{
|
||||||
|
1
languages/.gitignore
vendored
Normal file
1
languages/.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
translate.*.toml
|
@@ -15,8 +15,8 @@ hash = "sha1-c223c2e15171156192bc3146aee91e6094bb475b"
|
|||||||
other = "Download FFmpeg automatically"
|
other = "Download FFmpeg automatically"
|
||||||
|
|
||||||
[buttonForSelectedDirTitle]
|
[buttonForSelectedDirTitle]
|
||||||
hash = "sha1-52b13f1b13e82d22e8c4102332db5d4ec551247b"
|
hash = "sha1-8cbe5c67bcf89e4624635a79cbea104227faedda"
|
||||||
other = "Folder where it will be saved:"
|
other = "Save to folder:"
|
||||||
|
|
||||||
[cancel]
|
[cancel]
|
||||||
hash = "sha1-0ec753be8df955a117404fb634b01b45eb386e2a"
|
hash = "sha1-0ec753be8df955a117404fb634b01b45eb386e2a"
|
||||||
@@ -62,6 +62,18 @@ other = "Will be downloaded from the site:"
|
|||||||
hash = "sha1-55f87f114628fa2d5d8e67d1e1cda22c0e4f9271"
|
hash = "sha1-55f87f114628fa2d5d8e67d1e1cda22c0e4f9271"
|
||||||
other = "Downloading..."
|
other = "Downloading..."
|
||||||
|
|
||||||
|
[encoderGroupAudio]
|
||||||
|
hash = "sha1-24321cb5400df96be8f3e2131918bebdb3a01bba"
|
||||||
|
other = "Audio"
|
||||||
|
|
||||||
|
[encoderGroupImage]
|
||||||
|
hash = "sha1-a7e528bc7ac9538aec87d1593c38b80be95d4745"
|
||||||
|
other = "Images"
|
||||||
|
|
||||||
|
[encoderGroupVideo]
|
||||||
|
hash = "sha1-8e7b9894c7ef0f57ac0bf910f6a8aac1c8a53683"
|
||||||
|
other = "Video"
|
||||||
|
|
||||||
[encoder_apng]
|
[encoder_apng]
|
||||||
hash = "sha1-1cbd9abfef96d5614a7e569161b41bd6ad87bbaf"
|
hash = "sha1-1cbd9abfef96d5614a7e569161b41bd6ad87bbaf"
|
||||||
other = "APNG image"
|
other = "APNG image"
|
||||||
@@ -251,8 +263,12 @@ hash = "sha1-45f772b2eca5098cd6d31f2d1dc6edec1987a617"
|
|||||||
other = "**FFmpeg** is a trademark of **[Fabrice Bellard](http://bellard.org/)**, originator of the **[FFmpeg](https://ffmpeg.org/about.html)** project."
|
other = "**FFmpeg** is a trademark of **[Fabrice Bellard](http://bellard.org/)**, originator of the **[FFmpeg](https://ffmpeg.org/about.html)** project."
|
||||||
|
|
||||||
[fileForConversionTitle]
|
[fileForConversionTitle]
|
||||||
hash = "sha1-981bf090072a487e538d00780d337b47ca877372"
|
hash = "sha1-96ac799e1086b31fd8f5f8d4c801829d6c853f08"
|
||||||
other = "File to convert:"
|
other = "File:"
|
||||||
|
|
||||||
|
[formPreset]
|
||||||
|
hash = "sha1-7759891ba1ef9f7adc70defc7ac18fbf149c1a68"
|
||||||
|
other = "Preset"
|
||||||
|
|
||||||
[help]
|
[help]
|
||||||
hash = "sha1-6a45cef900c668effcb2ab10da05855c1fd10f6f"
|
hash = "sha1-6a45cef900c668effcb2ab10da05855c1fd10f6f"
|
||||||
@@ -278,6 +294,10 @@ other = "License information"
|
|||||||
hash = "sha1-359fff328717c05104e51a2d29f05bf1875d26b7"
|
hash = "sha1-359fff328717c05104e51a2d29f05bf1875d26b7"
|
||||||
other = "Licenses from other products used in the program"
|
other = "Licenses from other products used in the program"
|
||||||
|
|
||||||
|
[parameterCheckbox]
|
||||||
|
hash = "sha1-9e35221d454870996fd51d576249cf47d1784a3c"
|
||||||
|
other = "Enable option"
|
||||||
|
|
||||||
[pathToFfmpeg]
|
[pathToFfmpeg]
|
||||||
hash = "sha1-fafc50f1db0f720fe83a96cd70a9e1ad824e96b6"
|
hash = "sha1-fafc50f1db0f720fe83a96cd70a9e1ad824e96b6"
|
||||||
other = "Path to FFmpeg:"
|
other = "Path to FFmpeg:"
|
||||||
@@ -286,6 +306,46 @@ other = "Path to FFmpeg:"
|
|||||||
hash = "sha1-b872edc9633a2e81ef678dc46fe46a7e91732024"
|
hash = "sha1-b872edc9633a2e81ef678dc46fe46a7e91732024"
|
||||||
other = "Path to FFprobe:"
|
other = "Path to FFprobe:"
|
||||||
|
|
||||||
|
[preset_fast]
|
||||||
|
hash = "sha1-935e1ac9d3c8ba4478326c909ba66662acb0540e"
|
||||||
|
other = "fast (slower than \"faster\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_faster]
|
||||||
|
hash = "sha1-98620b73c896440c39ea6ec4b9b19d41301c9a7e"
|
||||||
|
other = "faster (slower than \"veryfast\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_medium]
|
||||||
|
hash = "sha1-f7d1c30135c22c2f07c247075c0df103bb3c3ea5"
|
||||||
|
other = "medium (slower than \"fast\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_placebo]
|
||||||
|
hash = "sha1-7bcff099104bb192881139e6404981bd426b3f91"
|
||||||
|
other = "placebo (not recommended)"
|
||||||
|
|
||||||
|
[preset_slow]
|
||||||
|
hash = "sha1-681bf587275a45b48af49bb2ad8f0947919530e7"
|
||||||
|
other = "slow (slower than \"medium\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_slower]
|
||||||
|
hash = "sha1-d1c692ee2b7643ae2c71a48bea880327a3c6b1e3"
|
||||||
|
other = "slower (slower than \"slow\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_superfast]
|
||||||
|
hash = "sha1-41c39959e8f1547cc9259a5b459c4ccbf368cc23"
|
||||||
|
other = "superfast (slower than \"ultrafast\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_ultrafast]
|
||||||
|
hash = "sha1-dfed981573ac2046832f9a9450bc9388958753fa"
|
||||||
|
other = "ultrafast (fast, but the file will weigh a lot)"
|
||||||
|
|
||||||
|
[preset_veryfast]
|
||||||
|
hash = "sha1-370b82509887d02d7a2ef9b110df4616b16123ce"
|
||||||
|
other = "veryfast (slower than \"superfast\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_veryslow]
|
||||||
|
hash = "sha1-d428bfa6deea9dd5c7c1f80ceba24e123ae96d0d"
|
||||||
|
other = "veryslow (slower than \"slower\", but the file will weigh less)"
|
||||||
|
|
||||||
[programmLink]
|
[programmLink]
|
||||||
hash = "sha1-18f9a3fad6aacefe1b05eed23122800b391ff5ca"
|
hash = "sha1-18f9a3fad6aacefe1b05eed23122800b391ff5ca"
|
||||||
other = "Project website"
|
other = "Project website"
|
||||||
@@ -303,16 +363,16 @@ hash = "sha1-4864057d626a868fa60f999bed3191d61d045ddc"
|
|||||||
other = "Save"
|
other = "Save"
|
||||||
|
|
||||||
[selectEncoder]
|
[selectEncoder]
|
||||||
hash = "sha1-07beb734a090830bedf8e038e3b45c73d64b5696"
|
hash = "sha1-88f3670b09758a3336057520a215058d61006abd"
|
||||||
other = "Select a converter"
|
other = "Encoder:"
|
||||||
|
|
||||||
[selectFFPathTitle]
|
[selectFFPathTitle]
|
||||||
hash = "sha1-95581446a28d968ff1a027c623159a7eb08654cf"
|
hash = "sha1-95581446a28d968ff1a027c623159a7eb08654cf"
|
||||||
other = "Specify the path to FFmpeg and FFprobe"
|
other = "Specify the path to FFmpeg and FFprobe"
|
||||||
|
|
||||||
[selectFormat]
|
[selectFormat]
|
||||||
hash = "sha1-5e59b9376d321a49e73063eb7355b555d89bdd55"
|
hash = "sha1-f3809b0b48886570cd4cf1d7099de6da5b6d4524"
|
||||||
other = "Select file extension"
|
other = "File extension:"
|
||||||
|
|
||||||
[settings]
|
[settings]
|
||||||
hash = "sha1-7f17c7c62a7fd8d1a508481f4778688927734c2f"
|
hash = "sha1-7f17c7c62a7fd8d1a508481f4778688927734c2f"
|
||||||
|
@@ -15,8 +15,8 @@ hash = "sha1-c223c2e15171156192bc3146aee91e6094bb475b"
|
|||||||
other = "FFmpeg автоматты түрде жүктеп алыңыз"
|
other = "FFmpeg автоматты түрде жүктеп алыңыз"
|
||||||
|
|
||||||
[buttonForSelectedDirTitle]
|
[buttonForSelectedDirTitle]
|
||||||
hash = "sha1-52b13f1b13e82d22e8c4102332db5d4ec551247b"
|
hash = "sha1-8cbe5c67bcf89e4624635a79cbea104227faedda"
|
||||||
other = "Файлды сақтауға арналған каталог:"
|
other = "Қалтаға сақтаңыз:"
|
||||||
|
|
||||||
[cancel]
|
[cancel]
|
||||||
hash = "sha1-0ec753be8df955a117404fb634b01b45eb386e2a"
|
hash = "sha1-0ec753be8df955a117404fb634b01b45eb386e2a"
|
||||||
@@ -62,6 +62,18 @@ other = "Сайттан жүктеледі:"
|
|||||||
hash = "sha1-55f87f114628fa2d5d8e67d1e1cda22c0e4f9271"
|
hash = "sha1-55f87f114628fa2d5d8e67d1e1cda22c0e4f9271"
|
||||||
other = "Жүктеп алынуда..."
|
other = "Жүктеп алынуда..."
|
||||||
|
|
||||||
|
[encoderGroupAudio]
|
||||||
|
hash = "sha1-24321cb5400df96be8f3e2131918bebdb3a01bba"
|
||||||
|
other = "Аудио"
|
||||||
|
|
||||||
|
[encoderGroupImage]
|
||||||
|
hash = "sha1-a7e528bc7ac9538aec87d1593c38b80be95d4745"
|
||||||
|
other = "Суреттер"
|
||||||
|
|
||||||
|
[encoderGroupVideo]
|
||||||
|
hash = "sha1-8e7b9894c7ef0f57ac0bf910f6a8aac1c8a53683"
|
||||||
|
other = "Бейне"
|
||||||
|
|
||||||
[encoder_apng]
|
[encoder_apng]
|
||||||
hash = "sha1-1cbd9abfef96d5614a7e569161b41bd6ad87bbaf"
|
hash = "sha1-1cbd9abfef96d5614a7e569161b41bd6ad87bbaf"
|
||||||
other = "APNG image"
|
other = "APNG image"
|
||||||
@@ -251,8 +263,12 @@ hash = "sha1-45f772b2eca5098cd6d31f2d1dc6edec1987a617"
|
|||||||
other = "FFmpeg — **[FFmpeg](https://ffmpeg.org/about.html)** жобасын жасаушы **[Fabrice Bellard](http://bellard.org/)** сауда белгісі."
|
other = "FFmpeg — **[FFmpeg](https://ffmpeg.org/about.html)** жобасын жасаушы **[Fabrice Bellard](http://bellard.org/)** сауда белгісі."
|
||||||
|
|
||||||
[fileForConversionTitle]
|
[fileForConversionTitle]
|
||||||
hash = "sha1-981bf090072a487e538d00780d337b47ca877372"
|
hash = "sha1-96ac799e1086b31fd8f5f8d4c801829d6c853f08"
|
||||||
other = "Түрлендіруге арналған файл:"
|
other = "Файл:"
|
||||||
|
|
||||||
|
[formPreset]
|
||||||
|
hash = "sha1-7759891ba1ef9f7adc70defc7ac18fbf149c1a68"
|
||||||
|
other = "Алдын ала орнатылған"
|
||||||
|
|
||||||
[help]
|
[help]
|
||||||
hash = "sha1-6a45cef900c668effcb2ab10da05855c1fd10f6f"
|
hash = "sha1-6a45cef900c668effcb2ab10da05855c1fd10f6f"
|
||||||
@@ -278,6 +294,10 @@ other = "Лицензия туралы ақпарат"
|
|||||||
hash = "sha1-359fff328717c05104e51a2d29f05bf1875d26b7"
|
hash = "sha1-359fff328717c05104e51a2d29f05bf1875d26b7"
|
||||||
other = "Бағдарламада пайдаланылатын басқа өнімдердің лицензиялары"
|
other = "Бағдарламада пайдаланылатын басқа өнімдердің лицензиялары"
|
||||||
|
|
||||||
|
[parameterCheckbox]
|
||||||
|
hash = "sha1-9e35221d454870996fd51d576249cf47d1784a3c"
|
||||||
|
other = "Опцияны қосу"
|
||||||
|
|
||||||
[pathToFfmpeg]
|
[pathToFfmpeg]
|
||||||
hash = "sha1-fafc50f1db0f720fe83a96cd70a9e1ad824e96b6"
|
hash = "sha1-fafc50f1db0f720fe83a96cd70a9e1ad824e96b6"
|
||||||
other = "FFmpeg жол:"
|
other = "FFmpeg жол:"
|
||||||
@@ -286,6 +306,46 @@ other = "FFmpeg жол:"
|
|||||||
hash = "sha1-b872edc9633a2e81ef678dc46fe46a7e91732024"
|
hash = "sha1-b872edc9633a2e81ef678dc46fe46a7e91732024"
|
||||||
other = "FFprobe жол:"
|
other = "FFprobe жол:"
|
||||||
|
|
||||||
|
[preset_fast]
|
||||||
|
hash = "sha1-935e1ac9d3c8ba4478326c909ba66662acb0540e"
|
||||||
|
other = "fast («faster» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_faster]
|
||||||
|
hash = "sha1-98620b73c896440c39ea6ec4b9b19d41301c9a7e"
|
||||||
|
other = "faster («veryfast» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_medium]
|
||||||
|
hash = "sha1-f7d1c30135c22c2f07c247075c0df103bb3c3ea5"
|
||||||
|
other = "medium («fast» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_placebo]
|
||||||
|
hash = "sha1-7bcff099104bb192881139e6404981bd426b3f91"
|
||||||
|
other = "placebo (ұсынылмайды)"
|
||||||
|
|
||||||
|
[preset_slow]
|
||||||
|
hash = "sha1-681bf587275a45b48af49bb2ad8f0947919530e7"
|
||||||
|
other = "slow («medium» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_slower]
|
||||||
|
hash = "sha1-d1c692ee2b7643ae2c71a48bea880327a3c6b1e3"
|
||||||
|
other = "slower («slow» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_superfast]
|
||||||
|
hash = "sha1-41c39959e8f1547cc9259a5b459c4ccbf368cc23"
|
||||||
|
other = "superfast («ultrafast» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_ultrafast]
|
||||||
|
hash = "sha1-dfed981573ac2046832f9a9450bc9388958753fa"
|
||||||
|
other = "ultrafast (жылдам, бірақ файлдың салмағы көп болады)"
|
||||||
|
|
||||||
|
[preset_veryfast]
|
||||||
|
hash = "sha1-370b82509887d02d7a2ef9b110df4616b16123ce"
|
||||||
|
other = "veryfast («superfast» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_veryslow]
|
||||||
|
hash = "sha1-d428bfa6deea9dd5c7c1f80ceba24e123ae96d0d"
|
||||||
|
other = "veryslow («slower» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
[programmLink]
|
[programmLink]
|
||||||
hash = "sha1-18f9a3fad6aacefe1b05eed23122800b391ff5ca"
|
hash = "sha1-18f9a3fad6aacefe1b05eed23122800b391ff5ca"
|
||||||
other = "Жобаның веб-сайты"
|
other = "Жобаның веб-сайты"
|
||||||
@@ -303,16 +363,16 @@ hash = "sha1-4864057d626a868fa60f999bed3191d61d045ddc"
|
|||||||
other = "Сақтау"
|
other = "Сақтау"
|
||||||
|
|
||||||
[selectEncoder]
|
[selectEncoder]
|
||||||
hash = "sha1-07beb734a090830bedf8e038e3b45c73d64b5696"
|
hash = "sha1-88f3670b09758a3336057520a215058d61006abd"
|
||||||
other = "Түрлендіргішті таңдаңыз"
|
other = "Кодировщик:"
|
||||||
|
|
||||||
[selectFFPathTitle]
|
[selectFFPathTitle]
|
||||||
hash = "sha1-95581446a28d968ff1a027c623159a7eb08654cf"
|
hash = "sha1-95581446a28d968ff1a027c623159a7eb08654cf"
|
||||||
other = "FFmpeg және FFprobe жолын көрсетіңіз"
|
other = "FFmpeg және FFprobe жолын көрсетіңіз"
|
||||||
|
|
||||||
[selectFormat]
|
[selectFormat]
|
||||||
hash = "sha1-5e59b9376d321a49e73063eb7355b555d89bdd55"
|
hash = "sha1-f3809b0b48886570cd4cf1d7099de6da5b6d4524"
|
||||||
other = "Файл кеңейтімін таңдаңыз"
|
other = "Файл кеңейтімі:"
|
||||||
|
|
||||||
[settings]
|
[settings]
|
||||||
hash = "sha1-7f17c7c62a7fd8d1a508481f4778688927734c2f"
|
hash = "sha1-7f17c7c62a7fd8d1a508481f4778688927734c2f"
|
||||||
|
@@ -2,7 +2,7 @@ AlsoUsedProgram = "Также в программе используется:"
|
|||||||
about = "О программе"
|
about = "О программе"
|
||||||
aboutText = "Простенький интерфейс для консольной утилиты FFmpeg. \nНо я не являюсь автором самой утилиты FFmpeg."
|
aboutText = "Простенький интерфейс для консольной утилиты FFmpeg. \nНо я не являюсь автором самой утилиты FFmpeg."
|
||||||
buttonDownloadFFmpeg = "Скачать автоматически FFmpeg"
|
buttonDownloadFFmpeg = "Скачать автоматически FFmpeg"
|
||||||
buttonForSelectedDirTitle = "Папка куда будет сохраняться:"
|
buttonForSelectedDirTitle = "Сохранить в папку:"
|
||||||
cancel = "Отмена"
|
cancel = "Отмена"
|
||||||
changeFFPath = "FFmpeg и FFprobe"
|
changeFFPath = "FFmpeg и FFprobe"
|
||||||
changeLanguage = "Поменять язык"
|
changeLanguage = "Поменять язык"
|
||||||
@@ -14,6 +14,9 @@ converterVideoFilesTitle = "Конвертер видео, аудио и кар
|
|||||||
download = "Скачать"
|
download = "Скачать"
|
||||||
downloadFFmpegFromSite = "Будет скачано с сайта:"
|
downloadFFmpegFromSite = "Будет скачано с сайта:"
|
||||||
downloadRun = "Скачивается..."
|
downloadRun = "Скачивается..."
|
||||||
|
encoderGroupAudio = "Аудио"
|
||||||
|
encoderGroupImage = "Картинки"
|
||||||
|
encoderGroupVideo = "Видео"
|
||||||
encoder_apng = "APNG image"
|
encoder_apng = "APNG image"
|
||||||
encoder_bmp = "BMP image"
|
encoder_bmp = "BMP image"
|
||||||
encoder_flv = "FLV"
|
encoder_flv = "FLV"
|
||||||
@@ -61,22 +64,34 @@ errorSelectedFormat = "Расширение файла не выбрана"
|
|||||||
exit = "Выход"
|
exit = "Выход"
|
||||||
ffmpegLGPL = "Это программное обеспечение использует библиотеки из проекта **FFmpeg** под **[LGPLv2.1](http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html)**."
|
ffmpegLGPL = "Это программное обеспечение использует библиотеки из проекта **FFmpeg** под **[LGPLv2.1](http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html)**."
|
||||||
ffmpegTrademark = "**FFmpeg** — торговая марка **[Fabrice Bellard](http://bellard.org/)** , создателя проекта **[FFmpeg](https://ffmpeg.org/about.html)**."
|
ffmpegTrademark = "**FFmpeg** — торговая марка **[Fabrice Bellard](http://bellard.org/)** , создателя проекта **[FFmpeg](https://ffmpeg.org/about.html)**."
|
||||||
fileForConversionTitle = "Файл для конвертации:"
|
fileForConversionTitle = "Файл:"
|
||||||
|
formPreset = "Предустановка"
|
||||||
help = "Справка"
|
help = "Справка"
|
||||||
inProgressQueue = "Выполняется"
|
inProgressQueue = "Выполняется"
|
||||||
languageSelectionFormHead = "Переключить язык"
|
languageSelectionFormHead = "Переключить язык"
|
||||||
languageSelectionHead = "Выберите язык"
|
languageSelectionHead = "Выберите язык"
|
||||||
licenseLink = "Сведения о лицензии"
|
licenseLink = "Сведения о лицензии"
|
||||||
licenseLinkOther = "Лицензии от других продуктов, которые используются в программе"
|
licenseLinkOther = "Лицензии от других продуктов, которые используются в программе"
|
||||||
|
parameterCheckbox = "Включить параметр"
|
||||||
pathToFfmpeg = "Путь к FFmpeg:"
|
pathToFfmpeg = "Путь к FFmpeg:"
|
||||||
pathToFfprobe = "Путь к FFprobe:"
|
pathToFfprobe = "Путь к FFprobe:"
|
||||||
|
preset_fast = "fast (медленней чем faster, но будет файл и меньше весить)"
|
||||||
|
preset_faster = "faster (медленней чем veryfast, но будет файл и меньше весить)"
|
||||||
|
preset_medium = "medium (медленней чем fast, но будет файл и меньше весить)"
|
||||||
|
preset_placebo = "placebo (не рекомендуется)"
|
||||||
|
preset_slow = "slow (медленней чем medium, но будет файл и меньше весить)"
|
||||||
|
preset_slower = "slower (медленней чем slow, но будет файл и меньше весить)"
|
||||||
|
preset_superfast = "superfast (медленней чем ultrafast, но будет файл и меньше весить)"
|
||||||
|
preset_ultrafast = "ultrafast (быстро, но файл будет много весить)"
|
||||||
|
preset_veryfast = "veryfast (медленней чем superfast, но будет файл и меньше весить)"
|
||||||
|
preset_veryslow = "veryslow (медленней чем slower, но будет файл и меньше весить)"
|
||||||
programmLink = "Сайт проекта"
|
programmLink = "Сайт проекта"
|
||||||
programmVersion = "**Версия программы:** {{.Version}}"
|
programmVersion = "**Версия программы:** {{.Version}}"
|
||||||
queue = "Очередь"
|
queue = "Очередь"
|
||||||
save = "Сохранить"
|
save = "Сохранить"
|
||||||
selectEncoder = "Выберите конвертер"
|
selectEncoder = "Кодировщик:"
|
||||||
selectFFPathTitle = "Укажите путь к FFmpeg и к FFprobe"
|
selectFFPathTitle = "Укажите путь к FFmpeg и к FFprobe"
|
||||||
selectFormat = "Выберите расширение файла"
|
selectFormat = "Расширение файла:"
|
||||||
settings = "Настройки"
|
settings = "Настройки"
|
||||||
testFF = "Проверка FFmpeg на работоспособность..."
|
testFF = "Проверка FFmpeg на работоспособность..."
|
||||||
titleDownloadLink = "Скачать можно от сюда"
|
titleDownloadLink = "Скачать можно от сюда"
|
||||||
|
@@ -1,139 +0,0 @@
|
|||||||
[encoder_apng]
|
|
||||||
hash = "sha1-1cbd9abfef96d5614a7e569161b41bd6ad87bbaf"
|
|
||||||
other = "APNG image"
|
|
||||||
|
|
||||||
[encoder_bmp]
|
|
||||||
hash = "sha1-e0b9c16b016961a5abdc2217e8ffd1ba7ddebc40"
|
|
||||||
other = "BMP image"
|
|
||||||
|
|
||||||
[encoder_flv]
|
|
||||||
hash = "sha1-3602bbf1cc90e48254f81975c7879b5fc0c4d602"
|
|
||||||
other = "FLV"
|
|
||||||
|
|
||||||
[encoder_gif]
|
|
||||||
hash = "sha1-d092a779172291b5215aa095390a5b11659128a4"
|
|
||||||
other = "GIF image"
|
|
||||||
|
|
||||||
[encoder_h264_nvenc]
|
|
||||||
hash = "sha1-169389f8c4a2518410159c363378ab5c978c32e5"
|
|
||||||
other = "H.264 with NVIDIA support"
|
|
||||||
|
|
||||||
[encoder_libmp3lame]
|
|
||||||
hash = "sha1-cd2c8d6f246c8bc18554b7105cb50b78d3cb2b98"
|
|
||||||
other = "libmp3lame MP3 (MPEG audio layer 3)"
|
|
||||||
|
|
||||||
[encoder_libshine]
|
|
||||||
hash = "sha1-891d56c85857e5d83ef5a1fe077c1f1540788f49"
|
|
||||||
other = "libshine MP3 (MPEG audio layer 3)"
|
|
||||||
|
|
||||||
[encoder_libtwolame]
|
|
||||||
hash = "sha1-b2f53be810b74edc3c454ac75de7ddecfee322ca"
|
|
||||||
other = "libtwolame MP2 (MPEG audio layer 2)"
|
|
||||||
|
|
||||||
[encoder_libvpx]
|
|
||||||
hash = "sha1-b85c923aecfb48de0e87e71b6a21bfc2c547c70e"
|
|
||||||
other = "libvpx VP8 (codec vp8)"
|
|
||||||
|
|
||||||
[encoder_libvpx-vp9]
|
|
||||||
hash = "sha1-3106417bd89bee87daa691e87614caf78cb934fe"
|
|
||||||
other = "libvpx VP9 (codec vp9)"
|
|
||||||
|
|
||||||
[encoder_libwebp]
|
|
||||||
hash = "sha1-1d590d47d46f7880246061fce0e0de6d743db39e"
|
|
||||||
other = "libwebp WebP image"
|
|
||||||
|
|
||||||
[encoder_libwebp_anim]
|
|
||||||
hash = "sha1-f141a9c8f23d79c13d44c30d8f34e05b363771ad"
|
|
||||||
other = "libwebp_anim WebP image"
|
|
||||||
|
|
||||||
[encoder_libx264]
|
|
||||||
hash = "sha1-6d764ac459c0bf3c819d76618418cdfbb7a749eb"
|
|
||||||
other = "H.264 libx264"
|
|
||||||
|
|
||||||
[encoder_libx265]
|
|
||||||
hash = "sha1-55544c166b1e15fd71a58096518e528109599eea"
|
|
||||||
other = "H.265 libx265"
|
|
||||||
|
|
||||||
[encoder_libxvid]
|
|
||||||
hash = "sha1-d4bed46d6cdd2bfa8fd1689801164a83ab10c3f5"
|
|
||||||
other = "libxvidcore MPEG-4 part 2"
|
|
||||||
|
|
||||||
[encoder_mjpeg]
|
|
||||||
hash = "sha1-94ba63a322b493a04da65e566781fe1cf8bb0d50"
|
|
||||||
other = "MJPEG (Motion JPEG)"
|
|
||||||
|
|
||||||
[encoder_mp2]
|
|
||||||
hash = "sha1-a9154b7203349e5d6fbfd67d1ea97715f54b2065"
|
|
||||||
other = "MP2 (MPEG audio layer 2)"
|
|
||||||
|
|
||||||
[encoder_mp2fixed]
|
|
||||||
hash = "sha1-dd2ee670d8bc8a60a96a717ebd26f16b5748cf3f"
|
|
||||||
other = "MP2 fixed point (MPEG audio layer 2)"
|
|
||||||
|
|
||||||
[encoder_mpeg1video]
|
|
||||||
hash = "sha1-30043660719a3cb19dab5c33450665a8a9cc1c01"
|
|
||||||
other = "MPEG-1"
|
|
||||||
|
|
||||||
[encoder_mpeg2video]
|
|
||||||
hash = "sha1-ccb2dcd8510cfdc9d52e5258af1863e5f2c51e77"
|
|
||||||
other = "MPEG-2"
|
|
||||||
|
|
||||||
[encoder_mpeg4]
|
|
||||||
hash = "sha1-67fe42f18421b2f6c90fcdc579f9199bfca4b182"
|
|
||||||
other = "MPEG-4 part 2"
|
|
||||||
|
|
||||||
[encoder_msmpeg4]
|
|
||||||
hash = "sha1-313ee597e4f0d9bd63a2bc6ac1618f028aef76f4"
|
|
||||||
other = "MPEG-4 part 2 Microsoft variant version 3"
|
|
||||||
|
|
||||||
[encoder_msmpeg4v2]
|
|
||||||
hash = "sha1-adc442ce88f2717693b2da3010a1937d77ee522f"
|
|
||||||
other = "MPEG-4 part 2 Microsoft variant version 2"
|
|
||||||
|
|
||||||
[encoder_msvideo1]
|
|
||||||
hash = "sha1-00f43ac0dc162bca10e0d98d6b70c0c6a902f66f"
|
|
||||||
other = "Microsoft Video-1"
|
|
||||||
|
|
||||||
[encoder_png]
|
|
||||||
hash = "sha1-6715d4b82f5d9dfe3e53e30b402ffa1a6fbf30a5"
|
|
||||||
other = "PNG image"
|
|
||||||
|
|
||||||
[encoder_qtrle]
|
|
||||||
hash = "sha1-31bf155cffaf6842ebc54084e4337ca08fdd9848"
|
|
||||||
other = "QuickTime Animation (RLE) video"
|
|
||||||
|
|
||||||
[encoder_sgi]
|
|
||||||
hash = "sha1-f4510e237f7fc3c02caa728f9e500f4b069f9c11"
|
|
||||||
other = "SGI image"
|
|
||||||
|
|
||||||
[encoder_tiff]
|
|
||||||
hash = "sha1-ed09d78c38e0b17ed695f35740c756dd7340eeac"
|
|
||||||
other = "TIFF image"
|
|
||||||
|
|
||||||
[encoder_wmav1]
|
|
||||||
hash = "sha1-cd4a4c5eeac694b6699d55d0f9b477b3b50f18c7"
|
|
||||||
other = "Windows Media Audio 1"
|
|
||||||
|
|
||||||
[encoder_wmav2]
|
|
||||||
hash = "sha1-eb2e5306cb33a702577ecfbdca0461862c66c053"
|
|
||||||
other = "Windows Media Audio 2"
|
|
||||||
|
|
||||||
[encoder_wmv1]
|
|
||||||
hash = "sha1-f9b748554c590c36a56bcba2cd317196b7bdeddb"
|
|
||||||
other = "Windows Media Video 7"
|
|
||||||
|
|
||||||
[encoder_wmv2]
|
|
||||||
hash = "sha1-5b21c87f5c6104797ead60b488b2948428f6b1b7"
|
|
||||||
other = "Windows Media Video 8"
|
|
||||||
|
|
||||||
[encoder_xbm]
|
|
||||||
hash = "sha1-2dfc35881da62e9a1379d8238cf7839b24f79566"
|
|
||||||
other = "XBM (X BitMap) image"
|
|
||||||
|
|
||||||
[errorSelectedFormat]
|
|
||||||
hash = "sha1-cda92c56a1ef1aabc92bbfc405ede8ab13087e66"
|
|
||||||
other = "File extension not selected"
|
|
||||||
|
|
||||||
[selectFormat]
|
|
||||||
hash = "sha1-5e59b9376d321a49e73063eb7355b555d89bdd55"
|
|
||||||
other = "Select file extension"
|
|
@@ -1,139 +0,0 @@
|
|||||||
[encoder_apng]
|
|
||||||
hash = "sha1-1cbd9abfef96d5614a7e569161b41bd6ad87bbaf"
|
|
||||||
other = "APNG image"
|
|
||||||
|
|
||||||
[encoder_bmp]
|
|
||||||
hash = "sha1-e0b9c16b016961a5abdc2217e8ffd1ba7ddebc40"
|
|
||||||
other = "BMP image"
|
|
||||||
|
|
||||||
[encoder_flv]
|
|
||||||
hash = "sha1-3602bbf1cc90e48254f81975c7879b5fc0c4d602"
|
|
||||||
other = "FLV"
|
|
||||||
|
|
||||||
[encoder_gif]
|
|
||||||
hash = "sha1-d092a779172291b5215aa095390a5b11659128a4"
|
|
||||||
other = "GIF image"
|
|
||||||
|
|
||||||
[encoder_h264_nvenc]
|
|
||||||
hash = "sha1-169389f8c4a2518410159c363378ab5c978c32e5"
|
|
||||||
other = "NVIDIA қолдауымен H.264"
|
|
||||||
|
|
||||||
[encoder_libmp3lame]
|
|
||||||
hash = "sha1-cd2c8d6f246c8bc18554b7105cb50b78d3cb2b98"
|
|
||||||
other = "libmp3lame MP3 (MPEG audio layer 3)"
|
|
||||||
|
|
||||||
[encoder_libshine]
|
|
||||||
hash = "sha1-891d56c85857e5d83ef5a1fe077c1f1540788f49"
|
|
||||||
other = "libshine MP3 (MPEG audio layer 3)"
|
|
||||||
|
|
||||||
[encoder_libtwolame]
|
|
||||||
hash = "sha1-b2f53be810b74edc3c454ac75de7ddecfee322ca"
|
|
||||||
other = "libtwolame MP2 (MPEG audio layer 2)"
|
|
||||||
|
|
||||||
[encoder_libvpx]
|
|
||||||
hash = "sha1-b85c923aecfb48de0e87e71b6a21bfc2c547c70e"
|
|
||||||
other = "libvpx VP8 (codec vp8)"
|
|
||||||
|
|
||||||
[encoder_libvpx-vp9]
|
|
||||||
hash = "sha1-3106417bd89bee87daa691e87614caf78cb934fe"
|
|
||||||
other = "libvpx VP9 (codec vp9)"
|
|
||||||
|
|
||||||
[encoder_libwebp]
|
|
||||||
hash = "sha1-1d590d47d46f7880246061fce0e0de6d743db39e"
|
|
||||||
other = "libwebp WebP image"
|
|
||||||
|
|
||||||
[encoder_libwebp_anim]
|
|
||||||
hash = "sha1-f141a9c8f23d79c13d44c30d8f34e05b363771ad"
|
|
||||||
other = "libwebp_anim WebP image"
|
|
||||||
|
|
||||||
[encoder_libx264]
|
|
||||||
hash = "sha1-6d764ac459c0bf3c819d76618418cdfbb7a749eb"
|
|
||||||
other = "H.264 libx264"
|
|
||||||
|
|
||||||
[encoder_libx265]
|
|
||||||
hash = "sha1-55544c166b1e15fd71a58096518e528109599eea"
|
|
||||||
other = "H.265 libx265"
|
|
||||||
|
|
||||||
[encoder_libxvid]
|
|
||||||
hash = "sha1-d4bed46d6cdd2bfa8fd1689801164a83ab10c3f5"
|
|
||||||
other = "libxvidcore MPEG-4 part 2"
|
|
||||||
|
|
||||||
[encoder_mjpeg]
|
|
||||||
hash = "sha1-94ba63a322b493a04da65e566781fe1cf8bb0d50"
|
|
||||||
other = "MJPEG (Motion JPEG)"
|
|
||||||
|
|
||||||
[encoder_mp2]
|
|
||||||
hash = "sha1-a9154b7203349e5d6fbfd67d1ea97715f54b2065"
|
|
||||||
other = "MP2 (MPEG audio layer 2)"
|
|
||||||
|
|
||||||
[encoder_mp2fixed]
|
|
||||||
hash = "sha1-dd2ee670d8bc8a60a96a717ebd26f16b5748cf3f"
|
|
||||||
other = "MP2 fixed point (MPEG audio layer 2)"
|
|
||||||
|
|
||||||
[encoder_mpeg1video]
|
|
||||||
hash = "sha1-30043660719a3cb19dab5c33450665a8a9cc1c01"
|
|
||||||
other = "MPEG-1"
|
|
||||||
|
|
||||||
[encoder_mpeg2video]
|
|
||||||
hash = "sha1-ccb2dcd8510cfdc9d52e5258af1863e5f2c51e77"
|
|
||||||
other = "MPEG-2"
|
|
||||||
|
|
||||||
[encoder_mpeg4]
|
|
||||||
hash = "sha1-67fe42f18421b2f6c90fcdc579f9199bfca4b182"
|
|
||||||
other = "MPEG-4 part 2"
|
|
||||||
|
|
||||||
[encoder_msmpeg4]
|
|
||||||
hash = "sha1-313ee597e4f0d9bd63a2bc6ac1618f028aef76f4"
|
|
||||||
other = "MPEG-4 part 2 Microsoft variant version 3"
|
|
||||||
|
|
||||||
[encoder_msmpeg4v2]
|
|
||||||
hash = "sha1-adc442ce88f2717693b2da3010a1937d77ee522f"
|
|
||||||
other = "MPEG-4 part 2 Microsoft variant version 2"
|
|
||||||
|
|
||||||
[encoder_msvideo1]
|
|
||||||
hash = "sha1-00f43ac0dc162bca10e0d98d6b70c0c6a902f66f"
|
|
||||||
other = "Microsoft Video-1"
|
|
||||||
|
|
||||||
[encoder_png]
|
|
||||||
hash = "sha1-6715d4b82f5d9dfe3e53e30b402ffa1a6fbf30a5"
|
|
||||||
other = "PNG image"
|
|
||||||
|
|
||||||
[encoder_qtrle]
|
|
||||||
hash = "sha1-31bf155cffaf6842ebc54084e4337ca08fdd9848"
|
|
||||||
other = "QuickTime Animation (RLE) video"
|
|
||||||
|
|
||||||
[encoder_sgi]
|
|
||||||
hash = "sha1-f4510e237f7fc3c02caa728f9e500f4b069f9c11"
|
|
||||||
other = "SGI image"
|
|
||||||
|
|
||||||
[encoder_tiff]
|
|
||||||
hash = "sha1-ed09d78c38e0b17ed695f35740c756dd7340eeac"
|
|
||||||
other = "TIFF image"
|
|
||||||
|
|
||||||
[encoder_wmav1]
|
|
||||||
hash = "sha1-cd4a4c5eeac694b6699d55d0f9b477b3b50f18c7"
|
|
||||||
other = "Windows Media Audio 1"
|
|
||||||
|
|
||||||
[encoder_wmav2]
|
|
||||||
hash = "sha1-eb2e5306cb33a702577ecfbdca0461862c66c053"
|
|
||||||
other = "Windows Media Audio 2"
|
|
||||||
|
|
||||||
[encoder_wmv1]
|
|
||||||
hash = "sha1-f9b748554c590c36a56bcba2cd317196b7bdeddb"
|
|
||||||
other = "Windows Media Video 7"
|
|
||||||
|
|
||||||
[encoder_wmv2]
|
|
||||||
hash = "sha1-5b21c87f5c6104797ead60b488b2948428f6b1b7"
|
|
||||||
other = "Windows Media Video 8"
|
|
||||||
|
|
||||||
[encoder_xbm]
|
|
||||||
hash = "sha1-2dfc35881da62e9a1379d8238cf7839b24f79566"
|
|
||||||
other = "XBM (X BitMap) image"
|
|
||||||
|
|
||||||
[errorSelectedFormat]
|
|
||||||
hash = "sha1-cda92c56a1ef1aabc92bbfc405ede8ab13087e66"
|
|
||||||
other = "Файл кеңейтімі таңдалмаған"
|
|
||||||
|
|
||||||
[selectFormat]
|
|
||||||
hash = "sha1-5e59b9376d321a49e73063eb7355b555d89bdd55"
|
|
||||||
other = "Файл кеңейтімін таңдаңыз"
|
|
24
main.go
24
main.go
@@ -4,6 +4,7 @@ import (
|
|||||||
"errors"
|
"errors"
|
||||||
"fyne.io/fyne/v2"
|
"fyne.io/fyne/v2"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor"
|
||||||
|
dberror "git.kor-elf.net/kor-elf/gui-for-ffmpeg/db"
|
||||||
error2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/error"
|
error2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/error"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/handler"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/handler"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
@@ -12,10 +13,10 @@ import (
|
|||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/migration"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/migration"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/setting"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/setting"
|
||||||
_ "github.com/mattn/go-sqlite3"
|
_ "github.com/mattn/go-sqlite3"
|
||||||
|
"go.etcd.io/bbolt"
|
||||||
"golang.org/x/text/language"
|
"golang.org/x/text/language"
|
||||||
"gorm.io/driver/sqlite"
|
|
||||||
"gorm.io/gorm"
|
|
||||||
"os"
|
"os"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
var application kernel.AppContract
|
var application kernel.AppContract
|
||||||
@@ -26,7 +27,7 @@ func init() {
|
|||||||
appMetadata := &fyne.AppMetadata{
|
appMetadata := &fyne.AppMetadata{
|
||||||
ID: "net.kor-elf.projects.gui-for-ffmpeg",
|
ID: "net.kor-elf.projects.gui-for-ffmpeg",
|
||||||
Name: "GUI for FFmpeg",
|
Name: "GUI for FFmpeg",
|
||||||
Version: "0.5.0",
|
Version: "0.7.0",
|
||||||
Icon: iconResource,
|
Icon: iconResource,
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -50,20 +51,20 @@ func init() {
|
|||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
errorView := error2.NewView(application)
|
errorView := error2.NewView(application)
|
||||||
if canCreateFile("data/database") != true {
|
if canCreateFile("data/database.db") != true {
|
||||||
errorView.PanicErrorWriteDirectoryData()
|
errorView.PanicErrorWriteDirectoryData()
|
||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
db, err := gorm.Open(sqlite.Open("data/database"), &gorm.Config{})
|
db, err := bbolt.Open("data/database.db", 0600, &bbolt.Options{Timeout: 3 * time.Second})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
errorView.PanicError(err)
|
errorView.PanicError(err)
|
||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
defer appCloseWithDb(db)
|
defer db.Close()
|
||||||
|
|
||||||
err = migration.Run(db)
|
err = migration.Run(db)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -75,7 +76,7 @@ func main() {
|
|||||||
settingRepository := setting.NewRepository(db)
|
settingRepository := setting.NewRepository(db)
|
||||||
convertorRepository := convertor.NewRepository(settingRepository)
|
convertorRepository := convertor.NewRepository(settingRepository)
|
||||||
pathFFmpeg, err := convertorRepository.GetPathFfmpeg()
|
pathFFmpeg, err := convertorRepository.GetPathFfmpeg()
|
||||||
if err != nil && errors.Is(err, gorm.ErrRecordNotFound) == false {
|
if err != nil && errors.Is(err, dberror.ErrRecordNotFound) == false {
|
||||||
errorView.PanicError(err)
|
errorView.PanicError(err)
|
||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
return
|
return
|
||||||
@@ -83,7 +84,7 @@ func main() {
|
|||||||
ffPathUtilities.FFmpeg = pathFFmpeg
|
ffPathUtilities.FFmpeg = pathFFmpeg
|
||||||
|
|
||||||
pathFFprobe, err := convertorRepository.GetPathFfprobe()
|
pathFFprobe, err := convertorRepository.GetPathFfprobe()
|
||||||
if err != nil && errors.Is(err, gorm.ErrRecordNotFound) == false {
|
if err != nil && errors.Is(err, dberror.ErrRecordNotFound) == false {
|
||||||
errorView.PanicError(err)
|
errorView.PanicError(err)
|
||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
return
|
return
|
||||||
@@ -108,13 +109,6 @@ func main() {
|
|||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
}
|
}
|
||||||
|
|
||||||
func appCloseWithDb(db *gorm.DB) {
|
|
||||||
sqlDB, err := db.DB()
|
|
||||||
if err == nil {
|
|
||||||
_ = sqlDB.Close()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func canCreateFile(path string) bool {
|
func canCreateFile(path string) bool {
|
||||||
file, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY, 0666)
|
file, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY, 0666)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@@ -1,15 +1,12 @@
|
|||||||
package migration
|
package migration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/setting"
|
"go.etcd.io/bbolt"
|
||||||
"gorm.io/gorm"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func Run(db *gorm.DB) error {
|
func Run(db *bbolt.DB) error {
|
||||||
err := db.AutoMigrate(&setting.Setting{})
|
return db.Update(func(tx *bbolt.Tx) error {
|
||||||
if err != nil {
|
_, err := tx.CreateBucketIfNotExists([]byte("settings"))
|
||||||
return err
|
return err
|
||||||
}
|
})
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
@@ -1,7 +1,6 @@
|
|||||||
package setting
|
package setting
|
||||||
|
|
||||||
type Setting struct {
|
type Setting struct {
|
||||||
ID uint `gorm:"primary_key"`
|
Code string `json:"code"`
|
||||||
Code string `gorm:"type:varchar(100);uniqueIndex;not null"`
|
Value string `json:"value"`
|
||||||
Value string `gorm:"type:text"`
|
|
||||||
}
|
}
|
||||||
|
@@ -1,8 +1,10 @@
|
|||||||
package setting
|
package setting
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"gorm.io/gorm"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/db"
|
||||||
|
"go.etcd.io/bbolt"
|
||||||
)
|
)
|
||||||
|
|
||||||
type RepositoryContract interface {
|
type RepositoryContract interface {
|
||||||
@@ -12,44 +14,69 @@ type RepositoryContract interface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type Repository struct {
|
type Repository struct {
|
||||||
db *gorm.DB
|
db *bbolt.DB
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewRepository(db *gorm.DB) *Repository {
|
func NewRepository(db *bbolt.DB) *Repository {
|
||||||
return &Repository{db}
|
return &Repository{db}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r Repository) GetValue(code string) (value string, err error) {
|
func (r Repository) GetValue(code string) (value string, err error) {
|
||||||
var setting Setting
|
var setting Setting
|
||||||
err = r.db.Where("code = ?", code).First(&setting).Error
|
|
||||||
|
err = r.db.View(func(tx *bbolt.Tx) error {
|
||||||
|
b := tx.Bucket([]byte("settings"))
|
||||||
|
if b == nil {
|
||||||
|
return errors.New("bucket 'settings' not found")
|
||||||
|
}
|
||||||
|
val := b.Get([]byte(code))
|
||||||
|
if val == nil {
|
||||||
|
return db.ErrRecordNotFound
|
||||||
|
}
|
||||||
|
return json.Unmarshal(val, &setting)
|
||||||
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
return setting.Value, err
|
|
||||||
|
return setting.Value, nil
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r Repository) Create(setting Setting) (Setting, error) {
|
func (r Repository) Create(setting Setting) (Setting, error) {
|
||||||
err := r.db.Create(&setting).Error
|
err := r.db.Update(func(tx *bbolt.Tx) error {
|
||||||
if err != nil {
|
b := tx.Bucket([]byte("settings"))
|
||||||
return setting, err
|
if b == nil {
|
||||||
|
return errors.New("bucket 'settings' not found")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
data, err := json.Marshal(setting)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return b.Put([]byte(setting.Code), data)
|
||||||
|
})
|
||||||
return setting, err
|
return setting, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r Repository) CreateOrUpdate(code string, value string) (Setting, error) {
|
func (r Repository) CreateOrUpdate(code string, value string) (Setting, error) {
|
||||||
var setting Setting
|
var setting Setting
|
||||||
err := r.db.Where("code = ?", code).First(&setting).Error
|
setting.Code = code
|
||||||
|
setting.Value = value
|
||||||
|
|
||||||
|
err := r.db.Update(func(tx *bbolt.Tx) error {
|
||||||
|
b := tx.Bucket([]byte("settings"))
|
||||||
|
if b == nil {
|
||||||
|
return errors.New("bucket 'settings' not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
data, err := json.Marshal(setting)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if errors.Is(err, gorm.ErrRecordNotFound) == true {
|
return err
|
||||||
setting = Setting{Code: code, Value: value}
|
|
||||||
return r.Create(setting)
|
|
||||||
} else {
|
|
||||||
return setting, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
err = r.db.Model(&setting).UpdateColumn("value", value).Error
|
|
||||||
if err != nil {
|
|
||||||
return setting, err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return b.Put([]byte(code), data)
|
||||||
|
})
|
||||||
return setting, err
|
return setting, err
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user