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


Golang yaml.ReadFile函數代碼示例

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


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

示例1: assembleConfigFiles

func assembleConfigFiles(configFile string) (map[string]interface{}, error) {
	logs.Info("Reading config file : %s", configFile)
	doc, err := yaml.ReadFile(configFile)
	if err != nil {
		return nil, err
	}

	mapping := YamlUnmarshal(doc.Root).(map[string]interface{})

	confD_path := path.Dir(configFile) + "/conf.d/*.yaml"
	logs.Info("Reading config folder : %s", confD_path)
	entries, err := filepath.Glob(confD_path)
	if err != nil {
		logs.Warn("Can't read relevant conf.d: %s", err)
	} else {
		for _, path := range entries {
			logs.Info("Reading config file : %s", path)
			doc, err := yaml.ReadFile(path)
			if err != nil {
				logs.Warn("Can't read relevant conf.d: %s", err)
			} else {
				inner := YamlUnmarshal(doc.Root).(map[string]interface{})
				RecursiveMergeNoConflict(mapping, inner, "")
			}
		}
	}
	return mapping, nil
}
開發者ID:Benoss,項目名稱:dendrite,代碼行數:28,代碼來源:config.go

示例2: ReadConfig

func ReadConfig(filename string) (*Config, error) {
	config, err := yaml.ReadFile(filename)
	if err != nil {
		return nil, err
	}
	return ParseConfig(config)
}
開發者ID:posix4e,項目名稱:capstan,代碼行數:7,代碼來源:config.go

示例3: init

func init() {
	Objects = make(map[string]*Object)
	Keys = []string{}
	file, _ := yaml.ReadFile("models/variant/data.yml")

	for key, node := range file.Root.(yaml.Map) {
		name := node.(yaml.Map)["name"].(yaml.Scalar).String()

		source, err := ioutil.ReadFile(fmt.Sprintf("models/variant/data/%s", key))
		snippet := ""
		if err == nil {
			snippet = string(source[:])
		}

		variants := []string{}
		variants = append(variants, key)
		if list, ok := node.(yaml.Map)["variants"]; ok {
			for _, variant := range list.(yaml.List) {
				variants = append(variants, variant.(yaml.Scalar).String())
			}
		}

		Objects[key] = &Object{key, name, snippet, variants, []*Option{}}
		Keys = append(Keys, key)
	}
}
開發者ID:gkrania,項目名稱:helloworldquiz,代碼行數:26,代碼來源:main.go

示例4: LoadConf

func LoadConf() {
	var err error
	conf, err = yaml.ReadFile("botconf.yaml")
	if err != nil {
		log.Panic(err)
	}
	Categories = List2SliceInConf("catagoris")
	CategoriesSet = set.New(set.NonThreadSafe)
	Groups = []Group{}
	for _, v := range Categories {
		CategoriesSet.Add(v)
		for _, i := range List2SliceInConf(v) {
			reg := regexp.MustCompile("^(.+) (http(s)?://(.*))$")
			strs := reg.FindAllStringSubmatch(i, -1)
			if !reg.MatchString(i) {
				Groups = append(Groups,
					Group{GroupName: i,
						GroupURL: ""})
			}
			if len(strs) > 0 {
				Groups = append(Groups,
					Group{GroupName: strs[0][1],
						GroupURL: strs[0][2]})
			}
		}
	}
}
開發者ID:XyzalZhang,項目名稱:Jqs7Bot,代碼行數:27,代碼來源:conf.go

示例5: init

// init function, load the configs
// fill english_ignore_words_map
func init() {
	// load config file
	cfg_filename := "config.yaml"
	config, err := yaml.ReadFile(cfg_filename)
	if err != nil {
		log.Fatalf("readfile(%s): %s", cfg_filename, err)
	}

	// get english ignore entire string
	english_ignore, err := config.Get("english_ignore")
	if err != nil {
		log.Fatalf("%s parse error: %s\n", english_ignore, err)
	}

	// get each separated words
	english_ignore_words_list := strings.Fields(english_ignore)
	for _, word := range english_ignore_words_list {
		word = strings.TrimSpace(word)
		english_ignore_words_map[word] = 1
	}

	// get redis connection info
	redis_config, err := yaml.Child(config.Root, "redis_server")
	if err != nil {
		log.Fatalf("redis config parse error: %s\n", err)
	}

	redis_config_m := redis_config.(yaml.Map)
	host, port := redis_config_m["host"], redis_config_m["port"]
	redis_conn, err = redis.Dial("tcp", fmt.Sprintf("%s:%s", host, port))
	//defer redis_conn.Close()
	if err != nil {
		log.Fatalf("Can not connect to Redis Server: %s", err)
	}
}
開發者ID:huuzkee-foundation,項目名稱:antispam,代碼行數:37,代碼來源:redisbayes.go

示例6: MakeFileInfo

func MakeFileInfo(path, ns, name string) *FileInfo {
	file, err := yaml.ReadFile(filepath.Join(path, ns, name, "index.yaml"))
	if err != nil {
		return nil
	}
	return yamlToInfo(ns, name, file.Root)
}
開發者ID:posix4e,項目名稱:capstan,代碼行數:7,代碼來源:s3_repository.go

示例7: LoadConfig

func LoadConfig() {
	configPath := flag.String("config", "./config.yml", "config file path")
	port := flag.String("port", "default", "port to bind to")
	duration := flag.Int64("duration", 0, "duration to operation on")
	cpuprofile := flag.Bool("cpuprofile", false, "write cpu profile to file")
	flag.Parse()

	absolutePath, _ := filepath.Abs(*configPath)
	c, err := yaml.ReadFile(absolutePath)
	if err != nil {
		panic(err)
	}
	root, _ := c.Get("root")
	if *port == "default" {
		*port, _ = c.Get("port")
	}
	numRetentions, _ := c.Count("retentions")
	retentions := make([]Retention, numRetentions)
	for i := 0; i < numRetentions; i++ {
		retention, _ := c.Get("retentions[" + strconv.Itoa(i) + "]")
		parts := strings.Split(retention, " ")
		d, _ := strconv.ParseInt(parts[0], 0, 64)
		n, _ := strconv.ParseInt(parts[1], 0, 64)
		retentions[i] = Retention{d, n, d * n}
	}
	p, _ := c.Get("redis.port")
	redisPort, _ := strconv.Atoi(p)
	redisHost, _ := c.Get("redis.host")
	Config = Configuration{*port, root, retentions, redisHost, redisPort, *duration}

	ProfileCPU = *cpuprofile
}
開發者ID:jalons,項目名稱:go-batsd,代碼行數:32,代碼來源:config.go

示例8: newDataSourceFromPath

func newDataSourceFromPath(path string) *DataSource {
	file, _ := yaml.ReadFile(path)
	fName := filepath.Base(path)
	extName := filepath.Ext(path)
	bName := fName[:len(fName)-len(extName)]
	id := bName

	name, _ := file.Get("name")
	length, _ := file.Count("webhooks")
	if length < 0 {
		length = 0
	}
	webhooks := make([]string, length)
	for i := 0; i < length; i++ {
		it := strconv.Itoa(i)
		webhooks[i], _ = file.Get("webhooks[" + it + "]")
	}
	dataSource := new(DataSource)
	dataSource.ID = id
	dataSource.Name = name
	dataSource.Webhooks = webhooks
	dataSource.propagateTimedEvent = make(chan TimedEvent)
	dataSource.registerPersistor = make(chan *Persistor)
	dataSource.registerConnection = make(chan *connection)
	dataSource.unregisterConnection = make(chan *connection)
	dataSource.persistors = make(map[*Persistor]bool)
	dataSource.connections = make(map[*connection]bool)
	return dataSource
}
開發者ID:Wiredcraft,項目名稱:dashy,代碼行數:29,代碼來源:dashy.go

示例9: main

func main() {
	// parse config file
	file := "config.yaml"
	config, err := yaml.ReadFile(file)
	if err != nil {
		log.Fatal("Error load config", err)
	}

	wsaddr, _ = config.Get("ws.address")
	zmqaddr, _ = config.Get("zmq.address")
	zmqsubject, _ = config.Get("zmq.subject")

	// connect to ZMQ broker
	responder, _ = zmq.NewSocket(zmq.SUB)
	defer responder.Close()
	responder.Connect(zmqaddr)
	responder.SetSubscribe(zmqsubject)

	// start handle ws
	http.HandleFunc("/ws", handler)
	err = http.ListenAndServe(wsaddr, nil)
	if err != nil {
		log.Fatal("ListenAndServe: ", err)
	}
}
開發者ID:horechek,項目名稱:gowebsockets,代碼行數:25,代碼來源:main.go

示例10: GetSQLConfFromFile

// Attempts to read from the passed in filename and creates a SQLconf as described therin.
// Retruns the DefaultSQLConf if the file cannot be found, or an error
// if one arises during the process of parsing the configuration file.
func GetSQLConfFromFile(filename string) (*SQLConf, error) {
	DefaultSQLConf := sqlConfFromEnv()
	configPath := path.Join(filename)
	_, err := os.Stat(configPath)

	if err != nil && os.IsNotExist(err) {
		return DefaultSQLConf, nil
	} else {

		// Defaults to development environment, you can override
		// by changing the $GO_ENV variable:
		// `$ export GO_ENV=environment` (where environment
		// can be "production", "test", "staging", etc.)
		// TODO: Potentially find a better solution to handling environments
		// Perhaps: https://github.com/adeven/goenv ?
		goEnv := os.Getenv("GO_ENV")
		if goEnv == "" {
			goEnv = "development"
		}

		config, readYamlErr := yaml.ReadFile(configPath)
		if readYamlErr != nil {
			return nil, readYamlErr
		}

		return confFromYamlFile(config, goEnv)
	}

	return nil, err
}
開發者ID:skariuki,項目名稱:state-server,代碼行數:33,代碼來源:sql_conf.go

示例11: main

func main() {
	config, err := yaml.ReadFile("conf.yaml")
	if err != nil {
		fmt.Println(err)
	}
	fmt.Println(config.Get("path"))
	fmt.Println(config.GetBool("enabled"))
}
開發者ID:cention-mujibur-rahman,項目名稱:go-in-practice,代碼行數:8,代碼來源:yaml_config.go

示例12: GetConfig

// 獲取配置信息
func GetConfig(configFile string, env string) (map[string]string, map[string]map[string]string) {

	// 裝在配置文件對象
	file := flag.String("file", configFile, "(Simple) YAML file to read")

	// 讀取配置文件內容
	configHandle, err := yaml.ReadFile(*file)

	if err != nil {
		log.Fatalf("readfile %q: %s", *file, err)
	}

	serviceTotal, err := configHandle.Count("services")

	mainConfig := make(map[string]string)
	serviceConfig := map[string]map[string]string{}

	for i := 0; i < serviceTotal; i++ {
		serviceConf := make(map[string]string)

		// 循環獲取Service配置字段值.
		for key, defaultVal := range serviceFieldNames {
			serviceVal, err := configHandle.Get("services[" + fmt.Sprintf("%d", i) + "]." + key)
			if err != nil {
				serviceVal = defaultVal
			}

			if serviceVal == "" && defaultVal != "" {
				serviceVal = defaultVal
			}

			serviceConf[key] = serviceVal
		}

		serviceConfig[serviceConf["name"]] = serviceConf
	}

	// 獲取Env環境變量.
	for key, defaultVal := range configFieldName {
		configVal, err := configHandle.Get(key)
		if err != nil {
			if key == "env" {
				mainConfig[key] = env
			} else {
				mainConfig[key] = defaultVal
			}
		} else {
			if key == "env" {
				env = configVal
			}
			mainConfig[key] = configVal
		}
	}

	log.Printf("current ENV: %s", env)

	return mainConfig, serviceConfig
}
開發者ID:nangong92t,項目名稱:go_src,代碼行數:59,代碼來源:config.go

示例13: LoadConf

func LoadConf() {
	var err error
	conf, err = yaml.ReadFile("botconf.yaml")
	if err != nil {
		log.Panic(err)
	}
	turingAPI, _ = conf.Get("turingBotKey")
	ydTransAPI, _ = conf.Get("yandexTransAPI")
}
開發者ID:zhangf911,項目名稱:telegram-chinese-groups,代碼行數:9,代碼來源:init.go

示例14: NewDBConf

func NewDBConf(conf, p, env string) (*DBConf, error) {
	if !filepath.IsAbs(conf) {
		dir, file := filepath.Split(conf)
		if dir == "" {
			// Path is neither relative nor absolute (just filename)
			conf = filepath.Join(p, file)
		}
	}

	f, err := yaml.ReadFile(conf)
	if err != nil {
		return nil, err
	}

	drv, err := f.Get(fmt.Sprintf("%s.driver", env))
	if err != nil {
		return nil, err
	}

	open, err := f.Get(fmt.Sprintf("%s.open", env))
	if err != nil {
		return nil, err
	}
	open = os.ExpandEnv(open)

	// Automatically parse postgres urls
	if drv == "postgres" {

		// Assumption: If we can parse the URL, we should
		if parsedURL, err := pq.ParseURL(open); err == nil && parsedURL != "" {
			open = parsedURL
		}
	}

	d := newDBDriver(drv, open)

	// allow the configuration to override the Import for this driver
	if imprt, err := f.Get(fmt.Sprintf("%s.import", env)); err == nil {
		d.Import = imprt
	}

	// allow the configuration to override the Dialect for this driver
	if dialect, err := f.Get(fmt.Sprintf("%s.dialect", env)); err == nil {
		d.Dialect = dialectByName(dialect)
	}

	if !d.IsValid() {
		return nil, errors.New(fmt.Sprintf("Invalid DBConf: %v", d))
	}

	return &DBConf{
		MigrationsDir: filepath.Join(p, "migrations"),
		Env:           env,
		Driver:        d,
	}, nil
}
開發者ID:simonz05,項目名稱:goose,代碼行數:56,代碼來源:dbconf.go

示例15: main

/**
 * Main program.
 */
func main() {
	log.Print("Starting up concentrator")

	var file string = "config.yml"
	log.Print("Loading config file: ", file)

	config, err := yaml.ReadFile("config.yml")
	if err != nil {
		log.Fatalf("Error reading config.yml (%q): %s", file, err)
	}

	// Get the backends config list.
	servers, err := yaml.Child(config.Root, "backends")
	server_lst, ok := servers.(yaml.List)
	if !ok {
		log.Fatalf("Could not parse backends list")
		return
	}

	// Load the stats backends.
	for i := 0; i < server_lst.Len(); i++ {
		node := server_lst.Item(i)
		vals := node.(yaml.Map)

		for index, element := range vals {
			backend_host := fmt.Sprintf("%s", index)
			backend_port := fmt.Sprintf("%s", element)
			log.Print(fmt.Sprintf("Adding backend %s:%s", backend_host, backend_port))
			Backends = append(Backends, fmt.Sprintf("%s:%s", backend_host, backend_port))
		}
	}

	for _, backserver := range Backends {
		log.Print(fmt.Sprintf("New server is: %s", backserver))
	}

	port, err := config.GetInt("port")
	host, err := config.Get("host")
	log.Print(fmt.Sprintf("Trying to listen on %s:%v", host, port))

	relay_method, err := config.Get("relay_method")
	log.Print(fmt.Sprintf("We want to relay using %s", relay_method))

	listener, err := net.Listen("tcp", fmt.Sprintf("%s:%v", host, port))
	if err != nil {
		println("Error starting net.Listen: ", err.Error())
		os.Exit(1)
	}

	log.Print("Server started, awaiting connections...")

	conns := clientConnections(listener)
	for {
		go handleConnections(<-conns)
	}
}
開發者ID:syrneus,項目名稱:concentrator,代碼行數:59,代碼來源:concentrator.go


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