mirror of
https://github.com/HACKERALERT/Picocrypt.git
synced 2025-01-02 12:52:17 +00:00
Update code with latest changes
This commit is contained in:
parent
3d4836b449
commit
e3a7cdf63c
3 changed files with 94 additions and 65 deletions
123
src/Picocrypt.go
123
src/Picocrypt.go
|
@ -2,7 +2,7 @@ package main
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
||||||
Picocrypt v1.25
|
Picocrypt v1.26
|
||||||
Copyright (c) Evan Su (https://evansu.cc)
|
Copyright (c) Evan Su (https://evansu.cc)
|
||||||
Released under a GNU GPL v3 License
|
Released under a GNU GPL v3 License
|
||||||
https://github.com/HACKERALERT/Picocrypt
|
https://github.com/HACKERALERT/Picocrypt
|
||||||
|
@ -48,7 +48,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
// Generic variables
|
// Generic variables
|
||||||
var version = "v1.25"
|
var version = "v1.26"
|
||||||
var window *giu.MasterWindow
|
var window *giu.MasterWindow
|
||||||
var dpi float32
|
var dpi float32
|
||||||
var mode string
|
var mode string
|
||||||
|
@ -100,7 +100,7 @@ var reedsolo bool
|
||||||
var deleteWhenDone bool
|
var deleteWhenDone bool
|
||||||
var split bool
|
var split bool
|
||||||
var splitSize string
|
var splitSize string
|
||||||
var splitUnits = []string{"KiB", "MiB", "GiB"}
|
var splitUnits = []string{"KiB", "MiB", "GiB", "TiB"}
|
||||||
var splitSelected int32 = 1
|
var splitSelected int32 = 1
|
||||||
var compress bool
|
var compress bool
|
||||||
var keep bool
|
var keep bool
|
||||||
|
@ -393,7 +393,7 @@ func draw() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fout, _ := os.Create(file)
|
fout, _ := os.Create(file)
|
||||||
data := make([]byte, 1048576)
|
data := make([]byte, 1<<20)
|
||||||
rand.Read(data)
|
rand.Read(data)
|
||||||
fout.Write(data)
|
fout.Write(data)
|
||||||
fout.Close()
|
fout.Close()
|
||||||
|
@ -401,14 +401,16 @@ func draw() {
|
||||||
giu.Tooltip("Generate a cryptographically secure keyfile."),
|
giu.Tooltip("Generate a cryptographically secure keyfile."),
|
||||||
),
|
),
|
||||||
giu.Style().SetDisabled(true).To(
|
giu.Style().SetDisabled(true).To(
|
||||||
giu.Button(keyfilePrompt).Size(giu.Auto, 0),
|
giu.InputText(&keyfilePrompt).Size(giu.Auto),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|
||||||
giu.Separator(),
|
giu.Separator(),
|
||||||
giu.Style().SetDisabled(password == "" || (password != cpassword && mode == "encrypt")).To(
|
giu.Style().SetDisabled((len(keyfiles) == 0 && password == "") ||
|
||||||
|
(mode == "encrypt" && password != cpassword)).To(
|
||||||
|
|
||||||
giu.Label(commentsPrompt),
|
giu.Label(commentsPrompt),
|
||||||
giu.Style().SetDisabled(commentsDisabled).To(
|
giu.Style().SetDisabled(commentsDisabled).To(
|
||||||
giu.InputText(&comments).Size(giu.Auto),
|
giu.InputText(&comments).Size(giu.Auto),
|
||||||
|
@ -465,7 +467,14 @@ func draw() {
|
||||||
bw += p * 2
|
bw += p * 2
|
||||||
dw := w - bw - p
|
dw := w - bw - p
|
||||||
giu.Style().SetDisabled(true).To(
|
giu.Style().SetDisabled(true).To(
|
||||||
giu.InputText(&outputFile).Size(dw / dpi / dpi).Flags(16384),
|
giu.InputText(func() *string {
|
||||||
|
tmp := ""
|
||||||
|
if outputFile == "" {
|
||||||
|
return &tmp
|
||||||
|
}
|
||||||
|
tmp = filepath.Base(outputFile)
|
||||||
|
return &tmp
|
||||||
|
}()).Size(dw / dpi / dpi).Flags(16384),
|
||||||
).Build()
|
).Build()
|
||||||
|
|
||||||
giu.SameLine()
|
giu.SameLine()
|
||||||
|
@ -585,6 +594,7 @@ func onDrop(names []string) {
|
||||||
onlyFolders = nil
|
onlyFolders = nil
|
||||||
allFiles = nil
|
allFiles = nil
|
||||||
files, folders := 0, 0
|
files, folders := 0, 0
|
||||||
|
size := 0
|
||||||
resetUI()
|
resetUI()
|
||||||
|
|
||||||
// One item dropped
|
// One item dropped
|
||||||
|
@ -732,6 +742,7 @@ func onDrop(names []string) {
|
||||||
// Add the file
|
// Add the file
|
||||||
onlyFiles = append(onlyFiles, names[0])
|
onlyFiles = append(onlyFiles, names[0])
|
||||||
inputFile = names[0]
|
inputFile = names[0]
|
||||||
|
size += int(stat.Size())
|
||||||
}
|
}
|
||||||
} else { // There are multiple dropped items
|
} else { // There are multiple dropped items
|
||||||
mode = "encrypt"
|
mode = "encrypt"
|
||||||
|
@ -746,6 +757,7 @@ func onDrop(names []string) {
|
||||||
files++
|
files++
|
||||||
onlyFiles = append(onlyFiles, name)
|
onlyFiles = append(onlyFiles, name)
|
||||||
allFiles = append(allFiles, name)
|
allFiles = append(allFiles, name)
|
||||||
|
size += int(stat.Size())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -778,10 +790,13 @@ func onDrop(names []string) {
|
||||||
stat, _ := os.Stat(path)
|
stat, _ := os.Stat(path)
|
||||||
if !stat.IsDir() {
|
if !stat.IsDir() {
|
||||||
allFiles = append(allFiles, path)
|
allFiles = append(allFiles, path)
|
||||||
|
size += int(stat.Size())
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inputLabel = fmt.Sprintf("%s (%s)", inputLabel, sizeify(int64(size)))
|
||||||
}
|
}
|
||||||
|
|
||||||
func work() {
|
func work() {
|
||||||
|
@ -907,7 +922,7 @@ func work() {
|
||||||
for i := 0; i < total; i++ {
|
for i := 0; i < total; i++ {
|
||||||
fin, _ := os.Open(fmt.Sprintf("%s.%d", inputFile, i))
|
fin, _ := os.Open(fmt.Sprintf("%s.%d", inputFile, i))
|
||||||
for {
|
for {
|
||||||
data := make([]byte, 1048576)
|
data := make([]byte, 1<<20)
|
||||||
read, err := fin.Read(data)
|
read, err := fin.Read(data)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
break
|
break
|
||||||
|
@ -932,16 +947,6 @@ func work() {
|
||||||
total -= 789
|
total -= 789
|
||||||
}
|
}
|
||||||
|
|
||||||
// XChaCha20's max input is 256 GiB, panic at one block less
|
|
||||||
if total >= int64((math.Pow(2, 32)-1)*64) {
|
|
||||||
mainStatus = "The input data is too big to encrypt."
|
|
||||||
mainStatusColor = color.RGBA{0xff, 0x00, 0x00, 0xff}
|
|
||||||
if len(allFiles) > 1 || len(onlyFolders) > 0 {
|
|
||||||
os.Remove(inputFile)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// Open input file in read-only mode
|
// Open input file in read-only mode
|
||||||
fin, err := os.Open(inputFile)
|
fin, err := os.Open(inputFile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -1008,7 +1013,7 @@ func work() {
|
||||||
if reedsolo { // Full Reed-Solomon encoding is selected
|
if reedsolo { // Full Reed-Solomon encoding is selected
|
||||||
flags[3] = 1
|
flags[3] = 1
|
||||||
}
|
}
|
||||||
if total%1048576 >= 1048448 { // Reed-Solomon internals
|
if total%(1<<20) >= 1<<20-128 { // Reed-Solomon internals
|
||||||
flags[4] = 1
|
flags[4] = 1
|
||||||
}
|
}
|
||||||
flags = rsEncode(rs5, flags)
|
flags = rsEncode(rs5, flags)
|
||||||
|
@ -1111,7 +1116,7 @@ func work() {
|
||||||
[]byte(password),
|
[]byte(password),
|
||||||
salt,
|
salt,
|
||||||
8, // 8 passes
|
8, // 8 passes
|
||||||
1048576, // 1 GiB memory
|
1<<20, // 1 GiB memory
|
||||||
8, // 8 threads
|
8, // 8 threads
|
||||||
32, // 32-byte output key
|
32, // 32-byte output key
|
||||||
)
|
)
|
||||||
|
@ -1120,7 +1125,7 @@ func work() {
|
||||||
[]byte(password),
|
[]byte(password),
|
||||||
salt,
|
salt,
|
||||||
4,
|
4,
|
||||||
1048576,
|
1<<20,
|
||||||
4,
|
4,
|
||||||
32,
|
32,
|
||||||
)
|
)
|
||||||
|
@ -1251,9 +1256,10 @@ func work() {
|
||||||
}
|
}
|
||||||
|
|
||||||
done := 0
|
done := 0
|
||||||
|
counterDone := 0
|
||||||
counter := 0
|
counter := 0
|
||||||
startTime := time.Now()
|
startTime := time.Now()
|
||||||
chacha20, _ := chacha20.NewUnauthenticatedCipher(key, nonce)
|
chacha, _ := chacha20.NewUnauthenticatedCipher(key, nonce)
|
||||||
|
|
||||||
// Use HKDF-SHA3 to generate a subkey
|
// Use HKDF-SHA3 to generate a subkey
|
||||||
var mac hash.Hash
|
var mac hash.Hash
|
||||||
|
@ -1269,8 +1275,8 @@ func work() {
|
||||||
// Generate another subkey and cipher (not used unless paranoid mode is checked)
|
// Generate another subkey and cipher (not used unless paranoid mode is checked)
|
||||||
serpentKey := make([]byte, 32)
|
serpentKey := make([]byte, 32)
|
||||||
hkdf.Read(serpentKey)
|
hkdf.Read(serpentKey)
|
||||||
srpnt, _ := serpent.NewCipher(serpentKey)
|
s, _ := serpent.NewCipher(serpentKey)
|
||||||
serpent := cipher.NewCTR(srpnt, serpentSalt)
|
serpent := cipher.NewCTR(s, serpentSalt)
|
||||||
|
|
||||||
for {
|
for {
|
||||||
// If the user cancels the process, stop and clean up
|
// If the user cancels the process, stop and clean up
|
||||||
|
@ -1292,9 +1298,9 @@ func work() {
|
||||||
// Read in data from the file
|
// Read in data from the file
|
||||||
var src []byte
|
var src []byte
|
||||||
if mode == "decrypt" && reedsolo {
|
if mode == "decrypt" && reedsolo {
|
||||||
src = make([]byte, 1114112)
|
src = make([]byte, 1<<20/128*136)
|
||||||
} else {
|
} else {
|
||||||
src = make([]byte, 1048576)
|
src = make([]byte, 1<<20)
|
||||||
}
|
}
|
||||||
size, err := fin.Read(src)
|
size, err := fin.Read(src)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -1310,16 +1316,16 @@ func work() {
|
||||||
copy(src, dst)
|
copy(src, dst)
|
||||||
}
|
}
|
||||||
|
|
||||||
chacha20.XORKeyStream(dst, src)
|
chacha.XORKeyStream(dst, src)
|
||||||
mac.Write(dst)
|
mac.Write(dst)
|
||||||
|
|
||||||
if reedsolo {
|
if reedsolo {
|
||||||
copy(src, dst)
|
copy(src, dst)
|
||||||
dst = nil
|
dst = nil
|
||||||
// If a full MiB is available
|
// If a full MiB is available
|
||||||
if len(src) == 1048576 {
|
if len(src) == 1<<20 {
|
||||||
// Encode every chunk
|
// Encode every chunk
|
||||||
for i := 0; i < 1048576; i += 128 {
|
for i := 0; i < 1<<20; i += 128 {
|
||||||
dst = append(dst, rsEncode(rs128, src[i:i+128])...)
|
dst = append(dst, rsEncode(rs128, src[i:i+128])...)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -1338,9 +1344,9 @@ func work() {
|
||||||
copy(dst, src)
|
copy(dst, src)
|
||||||
src = nil
|
src = nil
|
||||||
// If a complete 1 MiB block is available
|
// If a complete 1 MiB block is available
|
||||||
if len(dst) == 1114112 {
|
if len(dst) == 1<<20/128*136 {
|
||||||
// Decode every chunk
|
// Decode every chunk
|
||||||
for i := 0; i < 1114112; i += 136 {
|
for i := 0; i < 1<<20/128*136; i += 136 {
|
||||||
tmp, err := rsDecode(rs128, dst[i:i+136])
|
tmp, err := rsDecode(rs128, dst[i:i+136])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if keep {
|
if keep {
|
||||||
|
@ -1353,7 +1359,7 @@ func work() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if i == 1113976 && done+1114112 >= int(total) && padded {
|
if i == 1113976 && done+1<<20/128*136 >= int(total) && padded {
|
||||||
tmp = unpad(tmp)
|
tmp = unpad(tmp)
|
||||||
}
|
}
|
||||||
src = append(src, tmp...)
|
src = append(src, tmp...)
|
||||||
|
@ -1396,7 +1402,7 @@ func work() {
|
||||||
}
|
}
|
||||||
|
|
||||||
mac.Write(src)
|
mac.Write(src)
|
||||||
chacha20.XORKeyStream(dst, src)
|
chacha.XORKeyStream(dst, src)
|
||||||
|
|
||||||
if paranoid {
|
if paranoid {
|
||||||
copy(src, dst)
|
copy(src, dst)
|
||||||
|
@ -1407,21 +1413,29 @@ func work() {
|
||||||
|
|
||||||
// Update stats
|
// Update stats
|
||||||
if mode == "decrypt" && reedsolo {
|
if mode == "decrypt" && reedsolo {
|
||||||
done += 1114112
|
done += 1 << 20 / 128 * 136
|
||||||
} else {
|
} else {
|
||||||
done += 1048576
|
done += 1 << 20
|
||||||
}
|
}
|
||||||
|
counterDone += 1 << 20
|
||||||
counter++
|
counter++
|
||||||
progress = float32(done) / float32(total)
|
progress = float32(done) / float32(total)
|
||||||
elapsed := float64(time.Since(startTime)) / math.Pow(10, 9)
|
elapsed := float64(time.Since(startTime)) / (1 << 20) / 1000
|
||||||
speed := float64(done) / elapsed / math.Pow(10, 6)
|
speed := float64(done) / elapsed / (1 << 20)
|
||||||
eta := int(math.Floor(float64(total-int64(done)) / (speed * math.Pow(10, 6))))
|
eta := int(math.Floor(float64(total-int64(done)) / (speed * (1 << 20))))
|
||||||
if progress > 1 { // If the progress bar ever goes out of bounds, cap it at 100%
|
progress = float32(math.Min(float64(progress), 1)) // Cap progress to 100%
|
||||||
progress = 1
|
|
||||||
}
|
|
||||||
progressInfo = fmt.Sprintf("%.2f%%", progress*100)
|
progressInfo = fmt.Sprintf("%.2f%%", progress*100)
|
||||||
popupStatus = fmt.Sprintf("Working at %.2f MB/s (ETA: %s)", speed, humanize(eta))
|
popupStatus = fmt.Sprintf("Working at %.2f MiB/s (ETA: %s)", speed, humanize(eta))
|
||||||
giu.Update()
|
giu.Update()
|
||||||
|
|
||||||
|
// If more than 256 GiB passed, change the nonce to prevent counter overflow
|
||||||
|
blocks := counterDone/64 + 1
|
||||||
|
if blocks+(1<<20/64) > 1<<32 {
|
||||||
|
nonce = make([]byte, 24)
|
||||||
|
hkdf.Read(nonce)
|
||||||
|
chacha, _ = chacha20.NewUnauthenticatedCipher(key, nonce)
|
||||||
|
counterDone = 0
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if mode == "encrypt" {
|
if mode == "encrypt" {
|
||||||
|
@ -1457,13 +1471,15 @@ func work() {
|
||||||
finishedRaw := 0
|
finishedRaw := 0
|
||||||
chunkSize, _ := strconv.Atoi(splitSize)
|
chunkSize, _ := strconv.Atoi(splitSize)
|
||||||
|
|
||||||
// User can choose KiB, MiB, and GiB
|
// User can choose KiB, MiB, GiB, or TiB
|
||||||
if splitSelected == 0 {
|
if splitSelected == 0 {
|
||||||
chunkSize *= 1024
|
chunkSize *= 1 << 10
|
||||||
} else if splitSelected == 1 {
|
} else if splitSelected == 1 {
|
||||||
chunkSize *= 1048576
|
chunkSize *= 1 << 20
|
||||||
|
} else if splitSelected == 2 {
|
||||||
|
chunkSize *= 1 << 30
|
||||||
} else {
|
} else {
|
||||||
chunkSize *= 1073741824
|
chunkSize *= 1 << 40
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the number of required chunks
|
// Get the number of required chunks
|
||||||
|
@ -1478,7 +1494,7 @@ func work() {
|
||||||
|
|
||||||
// Copy data into the chunk
|
// Copy data into the chunk
|
||||||
for {
|
for {
|
||||||
data := make([]byte, 1048576)
|
data := make([]byte, 1<<20)
|
||||||
read, err := fin.Read(data)
|
read, err := fin.Read(data)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
break
|
break
|
||||||
|
@ -1714,6 +1730,19 @@ func humanize(seconds int) string {
|
||||||
return fmt.Sprintf("%02d:%02d:%02d", hours, minutes, seconds)
|
return fmt.Sprintf("%02d:%02d:%02d", hours, minutes, seconds)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Convert bytes to KiB, MiB, etc.
|
||||||
|
func sizeify(size int64) string {
|
||||||
|
if size >= int64(1<<40) {
|
||||||
|
return fmt.Sprintf("%.2fT", float64(size)/(1<<40))
|
||||||
|
} else if size >= int64(1<<30) {
|
||||||
|
return fmt.Sprintf("%.2fG", float64(size)/(1<<30))
|
||||||
|
} else if size >= int64(1<<20) {
|
||||||
|
return fmt.Sprintf("%.0fM", float64(size)/(1<<20))
|
||||||
|
} else {
|
||||||
|
return fmt.Sprintf("%.0fK", float64(size)/(1<<10))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
// Create the main window
|
// Create the main window
|
||||||
window = giu.NewMasterWindow("Picocrypt", 318, 479, giu.MasterWindowFlagsNotResizable)
|
window = giu.NewMasterWindow("Picocrypt", 318, 479, giu.MasterWindowFlagsNotResizable)
|
||||||
|
|
10
src/go.mod
10
src/go.mod
|
@ -5,17 +5,17 @@ go 1.17
|
||||||
require (
|
require (
|
||||||
github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca
|
github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca
|
||||||
github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7
|
github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7
|
||||||
github.com/HACKERALERT/dialog v0.0.0-20220410221520-a9e6303eda42
|
github.com/HACKERALERT/dialog v0.0.0-20220415015354-cd2cf9c423ec
|
||||||
github.com/HACKERALERT/giu v0.5.7-0.20220411212054-a37934efe9a9
|
github.com/HACKERALERT/giu v0.5.7-0.20220418211504-32988b007704
|
||||||
github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749
|
github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749
|
||||||
github.com/HACKERALERT/serpent v0.0.0-20210716182301-293b29869c66
|
github.com/HACKERALERT/serpent v0.0.0-20210716182301-293b29869c66
|
||||||
github.com/HACKERALERT/zxcvbn-go v0.0.0-20210927200100-f131a4666ad5
|
github.com/HACKERALERT/zxcvbn-go v0.0.0-20210927200100-f131a4666ad5
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/HACKERALERT/gl v0.0.0-20220411210853-402fdd216609 // indirect
|
github.com/HACKERALERT/gl v0.0.0-20220417032545-0e093e3300ba // indirect
|
||||||
github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20211216001154-d0da149b3bef // indirect
|
github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20220418211004-bfe86c8a6804 // indirect
|
||||||
github.com/HACKERALERT/imgui-go v1.12.1-0.20220411211703-da7cd33ca753 // indirect
|
github.com/HACKERALERT/imgui-go v1.12.1-0.20220418211401-490889e6f8b6 // indirect
|
||||||
github.com/HACKERALERT/mainthread v0.0.0-20211027212305-2ec9e701cc14 // indirect
|
github.com/HACKERALERT/mainthread v0.0.0-20211027212305-2ec9e701cc14 // indirect
|
||||||
github.com/HACKERALERT/sys v0.0.0-20220412020404-2e09c491f471 // indirect
|
github.com/HACKERALERT/sys v0.0.0-20220412020404-2e09c491f471 // indirect
|
||||||
github.com/HACKERALERT/w32 v0.0.0-20211215215707-4b84c2675d8d // indirect
|
github.com/HACKERALERT/w32 v0.0.0-20211215215707-4b84c2675d8d // indirect
|
||||||
|
|
20
src/go.sum
20
src/go.sum
|
@ -2,16 +2,16 @@ github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca h1:yZj12M2
|
||||||
github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca/go.mod h1:kkjR9AGvIlIUJdjd/CBL1VfQvyPDE5kL31rAzY/r0s4=
|
github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca/go.mod h1:kkjR9AGvIlIUJdjd/CBL1VfQvyPDE5kL31rAzY/r0s4=
|
||||||
github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7 h1:vOy0zRm74+1hPiUJ6R2EQl+agZBo+KcGQR85OWCzEZQ=
|
github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7 h1:vOy0zRm74+1hPiUJ6R2EQl+agZBo+KcGQR85OWCzEZQ=
|
||||||
github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7/go.mod h1:XjuRsuBwllqVRs7DqJrbpPeUsT3qebqANdKSBJnNn0s=
|
github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7/go.mod h1:XjuRsuBwllqVRs7DqJrbpPeUsT3qebqANdKSBJnNn0s=
|
||||||
github.com/HACKERALERT/dialog v0.0.0-20220410221520-a9e6303eda42 h1:YdKzDcpjykZRSVQSah9gLMxY7H7DAbk+L/AHKypYwSI=
|
github.com/HACKERALERT/dialog v0.0.0-20220415015354-cd2cf9c423ec h1:BT5dOJ3xggkQOHAJTko58Fjs7/QuyBP6o3PKYWZ8N+M=
|
||||||
github.com/HACKERALERT/dialog v0.0.0-20220410221520-a9e6303eda42/go.mod h1:GxPIEf2nKp6Gx+sdpjwTdFIGmW5kj6Jta7rRO50TgpU=
|
github.com/HACKERALERT/dialog v0.0.0-20220415015354-cd2cf9c423ec/go.mod h1:GxPIEf2nKp6Gx+sdpjwTdFIGmW5kj6Jta7rRO50TgpU=
|
||||||
github.com/HACKERALERT/giu v0.5.7-0.20220411212054-a37934efe9a9 h1:OkhEGzCEjVZ683etseTpDvewMXOjqkcnG6puAbX88hM=
|
github.com/HACKERALERT/giu v0.5.7-0.20220418211504-32988b007704 h1:k7R+pk5W2aNtK51zBlf1nTrLeSNT4cHh07uF9zugzS8=
|
||||||
github.com/HACKERALERT/giu v0.5.7-0.20220411212054-a37934efe9a9/go.mod h1:Mp6wVuSFEx2nI/XrHw7nce2aAh5nIbqIgozUbMVLlUs=
|
github.com/HACKERALERT/giu v0.5.7-0.20220418211504-32988b007704/go.mod h1:8b1hTZsUiy0j1LqbRSPksiUnP0AISeMGouhqXcOXLP0=
|
||||||
github.com/HACKERALERT/gl v0.0.0-20220411210853-402fdd216609 h1:AOJrzpVT3VYIpPH9BD0tXHBDMljK5FhORrz47Odc5/U=
|
github.com/HACKERALERT/gl v0.0.0-20220417032545-0e093e3300ba h1:AGAO9HNDmj3Rx/zsnmeqmZSs/d6Sm3bW9FYqgHTXmAw=
|
||||||
github.com/HACKERALERT/gl v0.0.0-20220411210853-402fdd216609/go.mod h1:ZUosVzfEKNGLMLk6aj9yo0FSAhWWsbTMjuzeIUXniB0=
|
github.com/HACKERALERT/gl v0.0.0-20220417032545-0e093e3300ba/go.mod h1:ZUosVzfEKNGLMLk6aj9yo0FSAhWWsbTMjuzeIUXniB0=
|
||||||
github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20211216001154-d0da149b3bef h1:MWA48bM0uKSblAiB51YtMDWEBhJtX+s3HcjlUN7o8cE=
|
github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20220418211004-bfe86c8a6804 h1:KnV8GLNQDt2oLnvYU0e3sPOJ2vhsJDzF3JazJ5Dnj6A=
|
||||||
github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20211216001154-d0da149b3bef/go.mod h1:aP+FSN9tk1W3UsQisFWxRLQ4WOF7T3niq68UYw0B150=
|
github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20220418211004-bfe86c8a6804/go.mod h1:aP+FSN9tk1W3UsQisFWxRLQ4WOF7T3niq68UYw0B150=
|
||||||
github.com/HACKERALERT/imgui-go v1.12.1-0.20220411211703-da7cd33ca753 h1:RfwDOJtKS2aQf4n5eGA3V8TGtmgmIwPuJThgkNa+p/o=
|
github.com/HACKERALERT/imgui-go v1.12.1-0.20220418211401-490889e6f8b6 h1:qLaFTxyT3r+oiZNuNxlY5ep/MAGX7JpSOaoYufk+5J8=
|
||||||
github.com/HACKERALERT/imgui-go v1.12.1-0.20220411211703-da7cd33ca753/go.mod h1:COMjMzefnK51DW+MwUfybQ/oCGv0zpGlP8fy6zr6oOs=
|
github.com/HACKERALERT/imgui-go v1.12.1-0.20220418211401-490889e6f8b6/go.mod h1:h8m2AFVQUhwB6Ygp98H7av+3n3X5vWsiWriGCL9SanQ=
|
||||||
github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749 h1:uZMOuYhLopMYH1E5JC4gMqWsp3aVhxUnOgvCH6cGMqo=
|
github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749 h1:uZMOuYhLopMYH1E5JC4gMqWsp3aVhxUnOgvCH6cGMqo=
|
||||||
github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749/go.mod h1:LInDG9bntPYtji6J+OLDZvv1OTWA5XpqXv19MBsWJrA=
|
github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749/go.mod h1:LInDG9bntPYtji6J+OLDZvv1OTWA5XpqXv19MBsWJrA=
|
||||||
github.com/HACKERALERT/mainthread v0.0.0-20211027212305-2ec9e701cc14 h1:DwWXverhu/dEsPM/GPykuHGh4SxW69DaGZL5t3fANG4=
|
github.com/HACKERALERT/mainthread v0.0.0-20211027212305-2ec9e701cc14 h1:DwWXverhu/dEsPM/GPykuHGh4SxW69DaGZL5t3fANG4=
|
||||||
|
|
Loading…
Reference in a new issue