Я использую 2 go-привязки для tdlib: каждая из них создается за 270 секунд каждый раз, когда я меняю строку в своем файле main.go. TDLib построен с использованием gcc. Есть ли способ не восстанавливать его каждый раз, когда я меняю строку? Я использую команду go build -v main.go для этого. Я строю TDLib, используя руководство из https://tdlib.github.io/td/build.html
Go. Пример, который я строю:
package main
import (
"log"
"path/filepath"
"github.com/zelenin/go-tdlib/client"
)
func main() {
authorizer := client.ClientAuthorizer()
go client.CliInteractor(authorizer)
const (
// apiId = MyApiID from my.telegram.org
// apiHash = "My hash from my.telegram.org"
)
authorizer.TdlibParameters <- &client.TdlibParameters{
UseTestDc: false,
DatabaseDirectory: filepath.Join(".tdlib", "database"),
FilesDirectory: filepath.Join(".tdlib", "files"),
UseFileDatabase: true,
UseChatInfoDatabase: true,
UseMessageDatabase: true,
UseSecretChats: false,
ApiId: apiId,
ApiHash: apiHash,
SystemLanguageCode: "en",
DeviceModel: "Server",
SystemVersion: "1.0.0",
ApplicationVersion: "1.0.0",
EnableStorageOptimizer: true,
IgnoreFileNames: false,
}
logVerbosity := client.WithLogVerbosity(&client.SetLogVerbosityLevelRequest{
NewVerbosityLevel: 0,
})
tdlibClient, err := client.NewClient(authorizer, logVerbosity)
if err != nil {
log.Fatalf("NewClient error: %s", err)
}
optionValue, err := tdlibClient.GetOption(&client.GetOptionRequest{
Name: "version",
})
if err != nil {
log.Fatalf("GetOption error: %s", err)
}
log.Printf("TDLib version: %s", optionValue.(*client.OptionValueString).Value)
me, err := tdlibClient.GetMe()
if err != nil {
log.Fatalf("GetMe error: %s", err)
}
log.Printf("Me: %s %s [%s]", me.FirstName, me.LastName, me.Username)
listener := tdlibClient.GetListener()
defer listener.Close()
for update := range listener.Updates {
if update.GetClass() == client.ClassUpdate {
log.Printf("%#v", update)
}
}
}
Затем я использую time go build -v main.go, и получаю такой результат:
time go build -v main.go
command-line-arguments
go build -v main.go 257.16s user 9.45s system 99% cpu 4:28.81 total
Можно ли строить одновременно (не с 1 процессором)? Во время перестройки он получает тот же результат, что и я добавляю несколько новых строк. Я хочу, чтобы он строился намного быстрее, чем 257 с за одно изменение строки.