subParserHub.go 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. package ChineseSubFinder
  2. import (
  3. "github.com/allanpk716/ChineseSubFinder/common"
  4. "github.com/allanpk716/ChineseSubFinder/sub_parser"
  5. "path/filepath"
  6. "regexp"
  7. )
  8. type SubParserHub struct {
  9. Parser []sub_parser.ISubParser
  10. }
  11. func NewSubParserHub(parser sub_parser.ISubParser, _inparser ...sub_parser.ISubParser) *SubParserHub {
  12. s := SubParserHub{}
  13. s.Parser = make([]sub_parser.ISubParser, 0)
  14. s.Parser = append(s.Parser, parser)
  15. if len(_inparser) > 0 {
  16. for _, one := range _inparser {
  17. s.Parser = append(s.Parser, one)
  18. }
  19. }
  20. return &s
  21. }
  22. // DetermineFileTypeFromFile 确定字幕文件的类型,是双语字幕或者某一种语言等等信息,如果返回 nil ,那么就说明都没有字幕的格式匹配上
  23. func (p SubParserHub) DetermineFileTypeFromFile(filePath string) (*sub_parser.SubFileInfo, error){
  24. for _, parser := range p.Parser {
  25. subFileInfo, err := parser.DetermineFileTypeFromFile(filePath)
  26. if err != nil {
  27. return nil, err
  28. }
  29. // 文件的格式不匹配解析器就是 nil
  30. if subFileInfo == nil {
  31. continue
  32. } else {
  33. // 正常至少应该匹配一个吧,不然就是最外层继续返回 nil 出去了
  34. // 简体和繁体字幕的判断,通过文件名来做到的,基本就算个补判而已
  35. newLang := common.IsChineseSimpleOrTraditional(filePath, subFileInfo.Lang)
  36. subFileInfo.Name = filepath.Base(filePath)
  37. subFileInfo.Lang = newLang
  38. subFileInfo.FromWhereSite = p.getFromWhereSite(filePath)
  39. return subFileInfo, nil
  40. }
  41. }
  42. // 如果返回 nil ,那么就说明都没有字幕的格式匹配上
  43. return nil, nil
  44. }
  45. // getFromWhereSite 从文件名找出是从那个网站下载的。这里的文件名的前缀是下载时候标记好的,比较特殊
  46. func (p SubParserHub) getFromWhereSite(filePath string) string {
  47. fileName := filepath.Base(filePath)
  48. var re = regexp.MustCompile(`^\[(\w+)\]_`)
  49. matched := re.FindStringSubmatch(fileName)
  50. if len(matched) < 1 {
  51. return ""
  52. }
  53. return matched[1]
  54. }