fssort.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package fssort
  2. import (
  3. "fmt"
  4. "io/fs"
  5. "path/filepath"
  6. "sort"
  7. "strings"
  8. )
  9. type sortBufferedStructure struct {
  10. Filename string
  11. Filepath string
  12. Filesize int64
  13. ModTime int64
  14. }
  15. /*
  16. Quick utilties to sort file list according to different modes
  17. */
  18. func SortFileList(filelistRealpath []string, fileInfos []fs.FileInfo, sortMode string) []string {
  19. //Build a filelist with information based on the given filelist
  20. parsedFilelist := []*sortBufferedStructure{}
  21. if len(filelistRealpath) != len(fileInfos) {
  22. //Invalid usage
  23. fmt.Println("[fssort] Invalid Usage!")
  24. return filelistRealpath
  25. }
  26. for i, file := range filelistRealpath {
  27. thisFileInfo := sortBufferedStructure{
  28. Filename: filepath.Base(file),
  29. Filepath: file,
  30. }
  31. //Get Filesize
  32. fi := fileInfos[i]
  33. thisFileInfo.Filesize = fi.Size()
  34. thisFileInfo.ModTime = fi.ModTime().Unix()
  35. parsedFilelist = append(parsedFilelist, &thisFileInfo)
  36. }
  37. //Sort the filelist
  38. if sortMode == "default" {
  39. //Sort by name, convert filename to window sorting methods
  40. sort.Slice(parsedFilelist, func(i, j int) bool {
  41. return strings.ToLower(parsedFilelist[i].Filename) < strings.ToLower(parsedFilelist[j].Filename)
  42. })
  43. } else if sortMode == "reverse" {
  44. //Sort by reverse name
  45. sort.Slice(parsedFilelist, func(i, j int) bool {
  46. return strings.ToLower(parsedFilelist[i].Filename) > strings.ToLower(parsedFilelist[j].Filename)
  47. })
  48. } else if sortMode == "smallToLarge" {
  49. sort.Slice(parsedFilelist, func(i, j int) bool { return parsedFilelist[i].Filesize < parsedFilelist[j].Filesize })
  50. } else if sortMode == "largeToSmall" {
  51. sort.Slice(parsedFilelist, func(i, j int) bool { return parsedFilelist[i].Filesize > parsedFilelist[j].Filesize })
  52. } else if sortMode == "mostRecent" {
  53. sort.Slice(parsedFilelist, func(i, j int) bool { return parsedFilelist[i].ModTime > parsedFilelist[j].ModTime })
  54. } else if sortMode == "leastRecent" {
  55. sort.Slice(parsedFilelist, func(i, j int) bool { return parsedFilelist[i].ModTime < parsedFilelist[j].ModTime })
  56. } else if sortMode == "smart" {
  57. parsedFilelist = SortNaturalFilelist(parsedFilelist)
  58. }
  59. results := []string{}
  60. for _, sortedFile := range parsedFilelist {
  61. results = append(results, sortedFile.Filepath)
  62. }
  63. return results
  64. }
  65. func SortModeIsSupported(sortMode string) bool {
  66. return contains(sortMode, []string{"default", "reverse", "smallToLarge", "largeToSmall", "mostRecent", "leastRecent", "smart"})
  67. }
  68. func contains(item string, slice []string) bool {
  69. set := make(map[string]struct{}, len(slice))
  70. for _, s := range slice {
  71. set[s] = struct{}{}
  72. }
  73. _, ok := set[item]
  74. return ok
  75. }