Skip to content
/ mergo Public
forked from darccio/mergo

Mergo: merging Go structs and maps since 2013.

License

Notifications You must be signed in to change notification settings

Fang-Li/mergo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Mergo

A helper to merge structs in Golang. Useful for configuration default values, avoiding messy if-statements.

Also a lovely comune (municipality) in the Province of Ancona in the Italian region Marche.

Mergo dall'alto

Status

It is quick hack to scratch my own itch around how to handle configuration default values. It works fine but it needs a lot more of testing and real world usage.

Build Status

Installation

go get github.com/imdario/mergo

// use in your .go code
import (
    "github.com/imdario/mergo"
)

Usage

You can only merge same-type structs with exported fields initialized as zero value of their type and same-types maps. Mergo won't merge unexported (private) fields but will do recursively any exported one. In maps Mergo won't merge equal keys values, because they are not addressable under reflection.

if err := mergo.Merge(&dst, src); err != nil {
    // ...
}

More information and examples in godoc documentation.

Contact me

If I can help you, you have an idea or you are using Mergo in your projects, don't hesitate to drop me a line (or a pull request): @im_dario

About

Written by Dario Castañé.

License

BSD 3-Clause license, as Go language.

About

Mergo: merging Go structs and maps since 2013.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 100.0%