草庐IT

scan-build

全部标签

go - 为什么 Go +build 标签会引入作用域问题?

我正在用Golang编写一个web服务器,需要在服务器启动前将一个配置文件读入内存。我无法访问我的Settings类型、几个变量和一个在settings.go中定义的函数。同一包中的其他文件需要可以访问这些文件,但我不断收到“未定义”错误,这表明我遇到了某种范围错误。下面是演示我的问题的最小代码示例。每个文件的第一行都定义了//+buildgo1.8标签。如果存在这些标记,编译将失败并出现如下所述的错误。如果没有这些标签,编译将按预期进行。ma​​in.go//+buildgo1.8packagemainimport("myapp/srv")funcmain(){srv.StartSe

谷歌容器生成器 : How to install govendor dependencies during build step?

我正在尝试使用GoogleCloudContainerBuilder通过GCPBuildTriggers自动构建我的容器我的代码在Go中,我的项目根目录中有一个vendor文件夹,其中包含我所有的Go依赖项(我使用govendor)。但是,此vendor文件夹未checkin源代码管理。我有一个cloudbuild.yaml文件,我首先将Go源代码构建到main可执行文件中,然后使用该可执行文件构建Docker镜像。ContainerBuilder确保这些构建步骤可以访问我的主分支。问题是Go编译步骤失败,因为vendor文件夹未checkin源代码管理,所以我的任何依赖项都不可用于任

go - 在 go build 中包含一个共享库

在为linux构建时如何包含SO文件?对于Windows,我只是将dll放在同一个文件夹中,但这不适用于linux构建。特别是,我正在构建一个gosciter项目,需要在可执行文件/包中包含libsciter-gtk-64.so。 最佳答案 我解决这个问题的方法是使用一个额外的工具,它具有可选桌面文件和其他元数据的额外好处。AppImage解决了库问题,我所要做的就是用/usr/lib/中的so文件创建一个AppImage并通过他们的命令构建。 关于go-在gobuild中包含一个共享库

go - 每当我使用 go 尝试任何命令时,输出都会说我的 go-build 已损坏且无法读取

无论何时我运行任何go命令(gohelp除外),输出都是这样的:mkdirC:\Users\LUCAS_~1\AppData\Local\Temp\go-build268335003:Thefileordirectoryiscorruptedandunreadable.我不确定为什么会这样,我试过重新启动,并暂时修复了它,但是在执行了几个命令后,这种情况又开始发生了。我不确定这是否有帮助,但我的用户名不是LUCAS_~1,而是Lucas_000。另外,我检查了我的Temp文件夹,似乎没有任何名为“go-build268335003”的东西。任何帮助将不胜感激,谢谢!

go - 使用 Scan 将数据库值强制转换为特定类型

我正在尝试使用github.com/jackc/pgx将从Postgres检索到的UUID读取到uuid.UUID类型的变量中(来自github.com/google/uuid包)。示例代码可以是:vardbId=uuid.UUIDerr=db.Pool.QueryRow("SELECTidFROMusersWHEREobjectname=$1;",objectUUID.String()).Scan(&dbId)iferr!=nil{log.Printf("Failedtofetchfromdatabase:%v",err)return}快速修复是将dbId存储在一个临时变量中,然后将

go - bufio.NewScanner(r) 从 r 调用 Scan() 排出缓冲区

我想从同一个阅读器r创建2个扫描仪。但是,当从第一个扫描器调用Scan()时,它会耗尽r的缓冲区,因此第二个扫描器正在读取零缓冲区。这是一种常见的行为吗?如何修复它以便第二个扫描仪正确读取原始r?r:=bytes.NewReader([]byte("ninebytes"))fmt.Println(r.Len())//9sc1:=bufio.NewScanner(r)sc1.Scan()fmt.Printf("scanner1:%s\n",sc1.Text())//scanner1:ninebytes//iwantcreatenewscannerfromrtoofmt.Println(r

go - 使用 go sql 时,在每种类型中重写 Scan 和 Value 方法时避免重复代码

GolanSQL和Gorp期望所有类型都包含附加到该类型的Scan和Value方法,以便将行读取到结构中。这会在我的项目中添加大量样板代码,即使这些方法可以通用化也是如此,因为我正在将JSON写入此列。typeType1struct{Type2Type2Type3Type3Type4Type4}typeType2struct{someprimitives...}typeType3struct{someprimitives...}typeType4struct{someprimitives...}func(qType2)Value()(driver.Value,error){return

docker - 如何在不运行的情况下从 docker build 复制结果

我想对我的go文件等进行一些编译,我想将生成的二进制文件等传输到主机。因此每个人都不需要进行本地设置,他们只需运行docker命令,输出在docker中编译并传输到主机。FROMgolang:1.11-alpineasbuilderCOPYsrc/go/src/project/srcRUNcd/go/src/project/src&&gobuild-omyBin现在我要将myBin传输到主机。有任何想法吗?PS:我希望在不运行容器的情况下完成它。如果只是运行构建就可以做到,那是最好的! 最佳答案 您不必运行一个容器,但您必须创建一个

sql-server - sql : Scan error on column index 0, name "": unsupported Scan, 将 driver.Value 类型 int64 存储到类型 *main.SMSBlast 中?

我现在正在尝试restfulapi,其中列SequenceID不是自动增量,因为故意的,当我像这样计数时,我的问题是库gormcountSequenceId:=db.Debug().Table("SMSBlast2").Count(&smsblast1),结果是sql:列索引0上的扫描错误,名称“”:不支持的扫描,将driver.Value类型int64存储到类型*main.SMSBlastpackagemainimport("encoding/json""fmt""github.com/gorilla/mux""github.com/jinzhu/gorm"_"github.com/

go - 如何将 row.Scan() int32 转换为 Golang gRPC protobuf Enum 字段?

//agent.protomessageAgent{Permissionpermission=1;google.protobuf.Timestampborn_time=2;messagePermission{Typetype=1;enumType{KILLNONE=0;KILLALL=1;DANCE=2;}}}然后将SQL行扫描到代理protobuf结构中://main.govaraproto.Agent........row.Scan(&a.Permission.Type,...)对于默认类型,该权限类型存储为简单的MariaDBINT()value=0。所以,我不能直接扫描它。因此