代码拉取完成,页面将自动刷新
/*
Copyright IBM Corp. All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package golang
import (
"errors"
"fmt"
"os"
"path/filepath"
"strings"
"github.com/hyperledger/fabric/common/flogging"
ccutil "github.com/hyperledger/fabric/core/chaincode/platforms/util"
)
var includeFileTypes = map[string]bool{
".c": true,
".h": true,
".s": true,
".go": true,
".yaml": true,
".json": true,
}
var logger = flogging.MustGetLogger("chaincode.platform.golang")
func getCodeFromFS(path string) (codegopath string, err error) {
logger.Debugf("getCodeFromFS %s", path)
gopath, err := getGopath()
if err != nil {
return "", err
}
tmppath := filepath.Join(gopath, "src", path)
if err := ccutil.IsCodeExist(tmppath); err != nil {
return "", fmt.Errorf("code does not exist %s", err)
}
return gopath, nil
}
type CodeDescriptor struct {
Gopath, Pkg string
Cleanup func()
}
// collectChaincodeFiles collects chaincode files. If path is a HTTP(s) url it
// downloads the code first.
//
//NOTE: for dev mode, user builds and runs chaincode manually. The name provided
//by the user is equivalent to the path.
func getCode(path string) (*CodeDescriptor, error) {
if path == "" {
return nil, errors.New("Cannot collect files from empty chaincode path")
}
// code root will point to the directory where the code exists
var gopath string
gopath, err := getCodeFromFS(path)
if err != nil {
return nil, fmt.Errorf("Error getting code %s", err)
}
return &CodeDescriptor{Gopath: gopath, Pkg: path, Cleanup: nil}, nil
}
type SourceDescriptor struct {
Name, Path string
IsMetadata bool
Info os.FileInfo
}
type SourceMap map[string]SourceDescriptor
type Sources []SourceDescriptor
func (s Sources) Len() int {
return len(s)
}
func (s Sources) Swap(i, j int) {
s[i], s[j] = s[j], s[i]
}
func (s Sources) Less(i, j int) bool {
return strings.Compare(s[i].Name, s[j].Name) < 0
}
func findSource(gopath, pkg string) (SourceMap, error) {
sources := make(SourceMap)
tld := filepath.Join(gopath, "src", pkg)
walkFn := func(path string, info os.FileInfo, err error) error {
if err != nil {
return err
}
if info.IsDir() {
// Allow import of the top level chaincode directory into chaincode code package
if path == tld {
return nil
}
// Allow import of META-INF metadata directories into chaincode code package tar.
// META-INF directories contain chaincode metadata artifacts such as statedb index definitions
if isMetadataDir(path, tld) {
logger.Debug("Files in META-INF directory will be included in code package tar:", path)
return nil
}
// Do not import any other directories into chaincode code package
logger.Debugf("skipping dir: %s", path)
return filepath.SkipDir
}
ext := filepath.Ext(path)
// we only want 'fileTypes' source files at this point
if _, ok := includeFileTypes[ext]; ok != true {
return nil
}
name, err := filepath.Rel(gopath, path)
if err != nil {
return fmt.Errorf("error obtaining relative path for %s: %s", path, err)
}
sources[name] = SourceDescriptor{Name: name, Path: path, IsMetadata: isMetadataDir(path, tld), Info: info}
return nil
}
if err := filepath.Walk(tld, walkFn); err != nil {
return nil, fmt.Errorf("Error walking directory: %s", err)
}
return sources, nil
}
// isMetadataDir checks to see if the current path is in the META-INF directory at the root of the chaincode directory
func isMetadataDir(path, tld string) bool {
return strings.HasPrefix(path, filepath.Join(tld, "META-INF"))
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。