此頁面上有簡單的 cgo 項目。它依賴于預(yù)先構(gòu)建的c共享庫,并且在使用時效果很好,只需稍作更改即可使其可構(gòu)建。go build我想用Bazel做同樣的事情。使用的源代碼與此github鏈接相同,不使用hello.c文件。綜上所述,最終代碼如下所示。/* * person.c * Copyright (C) 2019 Tim Hughes * * Distributed under terms of the MIT license. */#include <stdlib.h>#include "person.h"APerson *get_person(const char *name, const char *long_name){ APerson *fmt = malloc(sizeof(APerson)); fmt->name = name; fmt->long_name = long_name; return fmt;};/* * person.h * Copyright (C) 2019 Tim Hughes * * Distributed under terms of the MIT license. */#ifndef PERSON_H#define PERSON_Htypedef struct APerson{ const char *name; const char *long_name;} APerson;APerson *get_person(const char *name, const char *long_name);#endif /* !PERSON_H */package main/*#cgo CFLAGS: -g -Wall#cgo LDFLAGS: -L. -lperson#include "person.h"*/import "C"import ( "github.com/kubernetes/klog")type ( Person C.struct_APerson)func GetPerson(name string, long_name string) *Person { return (*Person)(C.get_person(C.CString(name), C.CString(long_name)))}func main() { klog.Info("it is running") var f *Person f = GetPerson("tim", "tim hughes") klog.Infof("Hello Go world: My name is %s, %s.\n", C.GoString(f.name), C.GoString(f.long_name))}Bazel 構(gòu)建文件如下。load("@io_bazel_rules_go//go:def.bzl", "go_binary", "go_library")go_library( name = "listing_lib", srcs = [ "person.c", "person.h", "runner.go", ], cgo = True, clinkopts = ["-Lpersons/listing -lperson"], copts = ["-g -Wall"], importpath = "github.com/example/project/persons/listing", visibility = ["//visibility:private"], deps = ["@com_github_kubernetes_klog//:klog"],)go_binary( name = "listing", embed = [":listing_lib"], visibility = ["//visibility:public"],)我需要一些事情來清除。c庫是自動構(gòu)建的嗎?我的假設(shè)是,這些都不是。如果不是,那么如果構(gòu)建的lib與go文件是同一文件夾,那么為什么不工作?假設(shè) bazel 在源文件夾中看不到庫,但在錯誤的位置查找。-L.是否可以使用cc_library規(guī)則來構(gòu)建可在 cgo 中使用的共享庫?如果是這樣,如何連接它們?
- 1 回答
- 0 關(guān)注
- 179 瀏覽
添加回答
舉報
0/150
提交
取消