You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
210 lines
4.4 KiB
Plaintext
210 lines
4.4 KiB
Plaintext
go run .
|
|
cmp stderr main.stderr
|
|
cp stderr normal.stderr
|
|
garble -literals build
|
|
exec ./main$exe
|
|
cmp stderr main.stderr
|
|
cmp stderr normal.stderr
|
|
! binsubstr main$exe 'garbleDecrypt' 'Lorem' 'ipsum' 'dolor' 'first assign' 'second assign' 'First Line' 'Second Line' 'map value' 'to obfuscate' 'also obfuscate' 'stringTypeField String' 'stringTypeStruct'
|
|
|
|
binsubstr main$exe 'also skip this' 'skip typed const' 'skip typed var' 'skip typed var assign' 'stringTypeField strType' 'stringType lambda func return' 'testMap1 key' 'testMap2 key' 'testMap3 key' 'testMap1 value' 'testMap3 value' 'testMap1 new value' 'testMap3 new value' 'stringType func param' 'stringType return'
|
|
[short] stop # checking that the build is reproducible is slow
|
|
|
|
# Also check that the binary is reproducible.
|
|
cp main$exe main_old$exe
|
|
rm main$exe
|
|
garble -literals build
|
|
bincmp main$exe main_old$exe
|
|
|
|
-- go.mod --
|
|
module test/main
|
|
-- main.go --
|
|
package main
|
|
|
|
type strucTest struct {
|
|
field string
|
|
anotherfield string
|
|
}
|
|
|
|
const (
|
|
cnst string = "Lorem"
|
|
multiline = `First Line
|
|
Second Line`
|
|
)
|
|
|
|
const (
|
|
i = 1
|
|
boolean = true
|
|
)
|
|
|
|
const (
|
|
foo = iota
|
|
bar
|
|
|
|
skip2 = "also skip this"
|
|
)
|
|
|
|
const arrayLen = 4
|
|
|
|
var array [arrayLen]byte
|
|
|
|
type typeAlias [arrayLen]byte
|
|
|
|
func main() {
|
|
empty := ""
|
|
|
|
localVar := "dolor"
|
|
|
|
reassign := "first assign"
|
|
reassign = "second assign"
|
|
|
|
add := "total" + " string"
|
|
|
|
println(cnst, boolean)
|
|
println(multiline, add)
|
|
println(localVar)
|
|
println(reassign)
|
|
println(empty)
|
|
|
|
x := strucTest{
|
|
field: "to obfuscate",
|
|
anotherfield: "also obfuscate",
|
|
}
|
|
|
|
lambda := func() string {
|
|
return "😅 😅"
|
|
}()
|
|
println(lambda)
|
|
|
|
println(x.field, x.anotherfield)
|
|
|
|
testMap := map[string]string{"map key": "map value"}
|
|
testMap["map key"] = "new value"
|
|
println(testMap["map key"])
|
|
println("another literal")
|
|
println(skip2)
|
|
println(i, foo, bar)
|
|
typedTest()
|
|
constantTest()
|
|
byteTest()
|
|
}
|
|
|
|
type stringType string
|
|
|
|
type stringTypeStruct struct {
|
|
str string
|
|
strType stringType
|
|
}
|
|
|
|
// typedTest types defined from string broke previously
|
|
func typedTest() {
|
|
const skipTypedConst stringType = "skip typed const" // skip
|
|
var skipTypedVar stringType = "skip typed var" // skip
|
|
|
|
var skipTypedVarAssign stringType
|
|
skipTypedVarAssign = "skip typed var assign" // skip
|
|
|
|
println(skipTypedConst, skipTypedVar, skipTypedVarAssign)
|
|
|
|
y := stringTypeStruct{
|
|
str: "stringTypeField String", // obfuscate
|
|
strType: "stringTypeField strType", // skip
|
|
}
|
|
println(y.str, y.strType)
|
|
|
|
z := func(s stringType) stringType {
|
|
return "stringType lambda func return" // skip
|
|
}("lambda call") // skip
|
|
println(z)
|
|
|
|
testMap1 := map[string]stringType{"testMap1 key": "testMap1 value"} // skip
|
|
testMap1["testMap1 key"] = "testMap1 new value" // skip
|
|
|
|
testMap2 := map[stringType]string{"testMap2 key": "testMap2 value"} // skip key
|
|
testMap2["testMap2 key"] = "testMap2 new value" // skip key
|
|
|
|
testMap3 := map[stringType]stringType{"testMap3 key": "testMap3 value"} // skip
|
|
testMap3["testMap3 key"] = "testMap3 new value" // skip
|
|
|
|
println(stringTypeFunc("stringType func param")) // skip
|
|
}
|
|
|
|
// constantTest tests that string constants which need to be constant are skipped
|
|
func constantTest() {
|
|
const a = "foo" // skip
|
|
const length = len(a)
|
|
|
|
const b = "bar" // skip
|
|
type T [len(b)]byte
|
|
|
|
const c = "foo" // skip
|
|
var _ [len(c)]byte
|
|
|
|
const d = "foo" // skip
|
|
var arr = [5]string{len(d): "foo"}
|
|
for _, elm := range arr {
|
|
if elm != "" {
|
|
println(elm)
|
|
}
|
|
}
|
|
|
|
const e = "foo" // skip
|
|
var slice = []string{len(e): "foo"}
|
|
for _, elm := range slice {
|
|
if elm != "" {
|
|
println(elm)
|
|
}
|
|
}
|
|
|
|
const f = "foo" // skip
|
|
const i = length + len(f)
|
|
}
|
|
|
|
func byteTest() {
|
|
a := []byte{12, 13}
|
|
for _, elm := range a {
|
|
print(elm, ", ")
|
|
}
|
|
println()
|
|
var b = []byte{12, 13}
|
|
for _, elm := range b {
|
|
print(elm, ", ")
|
|
}
|
|
println()
|
|
|
|
var c = [2]byte{12, 13}
|
|
for _, elm := range c {
|
|
print(elm, ", ")
|
|
}
|
|
println()
|
|
}
|
|
|
|
func stringTypeFunc(s stringType) stringType {
|
|
println(s)
|
|
return "stringType return" // skip
|
|
}
|
|
|
|
-- main.stderr --
|
|
Lorem true
|
|
First Line
|
|
Second Line total string
|
|
dolor
|
|
second assign
|
|
|
|
😅 😅
|
|
to obfuscate also obfuscate
|
|
new value
|
|
another literal
|
|
also skip this
|
|
1 0 1
|
|
skip typed const skip typed var skip typed var assign
|
|
stringTypeField String stringTypeField strType
|
|
stringType lambda func return
|
|
stringType func param
|
|
stringType return
|
|
foo
|
|
foo
|
|
12, 13,
|
|
12, 13,
|
|
12, 13,
|