當前位置: 首頁>>代碼示例>>Golang>>正文


Golang gcfg.ReadInto函數代碼示例

本文整理匯總了Golang中github.com/scalingdata/gcfg.ReadInto函數的典型用法代碼示例。如果您正苦於以下問題:Golang ReadInto函數的具體用法?Golang ReadInto怎麽用?Golang ReadInto使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了ReadInto函數的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: newOVirtCloud

func newOVirtCloud(config io.Reader) (*OVirtCloud, error) {
	if config == nil {
		return nil, fmt.Errorf("missing configuration file for ovirt cloud provider")
	}

	oVirtConfig := OVirtApiConfig{}

	/* defaults */
	oVirtConfig.Connection.Username = "[email protected]"

	if err := gcfg.ReadInto(&oVirtConfig, config); err != nil {
		return nil, err
	}

	if oVirtConfig.Connection.ApiEntry == "" {
		return nil, fmt.Errorf("missing ovirt uri in cloud provider configuration")
	}

	request, err := url.Parse(oVirtConfig.Connection.ApiEntry)
	if err != nil {
		return nil, err
	}

	request.Path = path.Join(request.Path, "vms")
	request.User = url.UserPassword(oVirtConfig.Connection.Username, oVirtConfig.Connection.Password)
	request.RawQuery = url.Values{"search": {oVirtConfig.Filters.VmsQuery}}.Encode()

	return &OVirtCloud{VmsRequest: request}, nil
}
開發者ID:previousnext,項目名稱:kube-ingress,代碼行數:29,代碼來源:ovirt.go

示例2: ReadConfiguration

func ReadConfiguration(reader io.Reader, config *Config) error {
	wrapper := configWrapper{Default: *config}
	wrapper.Default.ResyncPeriod = 0

	buffer := readSection(reader, "default")
	err := gcfg.ReadInto(&wrapper, bytes.NewReader(buffer.Bytes()))
	if err != nil {
		return err
	}

	if wrapper.Default.ResyncPeriod != 0 {
		wrapper.Default.ResyncPeriod = wrapper.Default.ResyncPeriod * time.Second
	} else {
		wrapper.Default.ResyncPeriod = config.ResyncPeriod
	}

	if clusterIp := wrapper.Default.ClusterIpRange; clusterIp != "" {
		if _, _, err := net.ParseCIDR(clusterIp); err != nil {
			return err
		}
	}

	*config = wrapper.Default
	return nil
}
開發者ID:michaelkuty,項目名稱:contrail-kubernetes,代碼行數:25,代碼來源:config.go

示例3: readConfig

func readConfig(config io.Reader) (Config, error) {
	if config == nil {
		err := fmt.Errorf("no OpenStack cloud provider config file given")
		return Config{}, err
	}

	var cfg Config
	err := gcfg.ReadInto(&cfg, config)
	return cfg, err
}
開發者ID:mataihang,項目名稱:kubernetes,代碼行數:10,代碼來源:openstack.go

示例4: Read

func (c *Config) Read(configReader io.Reader) error {
	wrapper := &ConfigWrapper{Scheduler: *c}
	if configReader != nil {
		if err := gcfg.ReadInto(wrapper, configReader); err != nil {
			return err
		}
		*c = wrapper.Scheduler
	}
	return nil
}
開發者ID:qinguoan,項目名稱:vulcan,代碼行數:10,代碼來源:config.go

示例5: readConfig

func readConfig(configReader io.Reader) (*Config, error) {
	config := createDefaultConfig()
	wrapper := &ConfigWrapper{Mesos_Cloud: *config}
	if configReader != nil {
		if err := gcfg.ReadInto(wrapper, configReader); err != nil {
			return nil, err
		}
		config = &(wrapper.Mesos_Cloud)
	}
	return config, nil
}
開發者ID:johndmulhausen,項目名稱:kubernetes,代碼行數:11,代碼來源:config.go

示例6: readConfig

func readConfig(configFile string) (openStackConfig, error) {
	var config *os.File
	config, err := os.Open(configFile)
	if err != nil {
		return openStackConfig{}, err
	}
	defer config.Close()

	if config == nil {
		err := fmt.Errorf("no OpenStack cloud provider config file given")
		return openStackConfig{}, err
	}

	var cfg openStackConfig
	err = gcfg.ReadInto(&cfg, config)
	return cfg, err
}
開發者ID:thed00de,項目名稱:hypernetes,代碼行數:17,代碼來源:cinder_client.go

示例7: ReadConfiguration

func (c *Config) ReadConfiguration(global *network.Config, reader io.Reader) error {
	if global != nil && c.ServiceSubnet == DefaultServiceSubnet {
		c.ServiceSubnet = global.ClusterIpRange
	}

	if reader == nil {
		return nil
	}

	wrapper := configWrapper{OpenContrail: *c}
	if err := gcfg.ReadInto(&wrapper, reader); err != nil {
		return err
	}
	if err := wrapper.OpenContrail.Validate(); err != nil {
		return err
	}
	*c = wrapper.OpenContrail
	return nil
}
開發者ID:michaelkuty,項目名稱:contrail-kubernetes,代碼行數:19,代碼來源:config.go

示例8: newGCECloud

// newGCECloud creates a new instance of GCECloud.
func newGCECloud(config io.Reader) (*GCECloud, error) {
	projectID, zone, err := getProjectAndZone()
	if err != nil {
		return nil, err
	}
	// TODO: if we want to use this on a machine that doesn't have the http://metadata server
	// e.g. on a user's machine (not VM) somewhere, we need to have an alternative for
	// instance id lookup.
	instanceID, err := getInstanceID()
	if err != nil {
		return nil, err
	}
	externalID, err := getCurrentExternalID()
	if err != nil {
		return nil, err
	}
	networkName, err := getNetworkName()
	if err != nil {
		return nil, err
	}
	networkURL := gceNetworkURL(projectID, networkName)
	tokenSource := google.ComputeTokenSource("")
	if config != nil {
		var cfg Config
		if err := gcfg.ReadInto(&cfg, config); err != nil {
			glog.Errorf("Couldn't read config: %v", err)
			return nil, err
		}
		if cfg.Global.ProjectID != "" {
			projectID = cfg.Global.ProjectID
		}
		if cfg.Global.NetworkName != "" {
			if strings.Contains(cfg.Global.NetworkName, "/") {
				networkURL = cfg.Global.NetworkName
			} else {
				networkURL = gceNetworkURL(cfg.Global.ProjectID, cfg.Global.NetworkName)
			}
		}
		if cfg.Global.TokenURL != "" {
			tokenSource = newAltTokenSource(cfg.Global.TokenURL, cfg.Global.TokenBody)
		}
	}
	client := oauth2.NewClient(oauth2.NoContext, tokenSource)
	svc, err := compute.New(client)
	if err != nil {
		return nil, err
	}
	containerSvc, err := container.New(client)
	if err != nil {
		return nil, err
	}
	return &GCECloud{
		service:          svc,
		containerService: containerSvc,
		projectID:        projectID,
		zone:             zone,
		instanceID:       instanceID,
		externalID:       externalID,
		networkURL:       networkURL,
	}, nil
}
開發者ID:pyk,項目名稱:kubernetes,代碼行數:62,代碼來源:gce.go


注:本文中的github.com/scalingdata/gcfg.ReadInto函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。