frp/pkg/config/legacy
fatedier 3e0c78233a
use std slices package (#4008)
2024-02-20 12:01:41 +08:00
..
README.md support yaml/json/toml configuration format, make ini deprecated (#3599) 2023-09-06 10:18:02 +08:00
client.go use std slices package (#4008) 2024-02-20 12:01:41 +08:00
conversion.go fix nil map error when using plugin headers in legacy format (#3996) 2024-02-19 13:03:37 +08:00
parse.go optimize some code (#3801) 2023-11-27 15:47:49 +08:00
proxy.go code optimization (#3625) 2023-09-20 15:18:50 +08:00
server.go Fix various typos (#3783) 2023-11-22 14:30:22 +08:00
utils.go support yaml/json/toml configuration format, make ini deprecated (#3599) 2023-09-06 10:18:02 +08:00
value.go support yaml/json/toml configuration format, make ini deprecated (#3599) 2023-09-06 10:18:02 +08:00
visitor.go code optimization (#3625) 2023-09-20 15:18:50 +08:00

README.md

So far, there is no mature Go project that does well in parsing *.ini files.

By comparison, we have selected an open source project: https://github.com/go-ini/ini.

This library helped us solve most of the key-value matching, but there are still some problems, such as not supporting parsing map.

We add our own logic on the basis of this library. In the current situationwhich, we need to complete the entire Unmarshal in two steps:

  • Step#1, use go-ini to complete the basic parameter matching;
  • Step#2, parse our custom parameters to realize parsing special structure, like map, array.

Some of the keywords in tag(like inline, extends, etc.) may be different from standard libraries such as json and protobuf in Go. For details, please refer to the library documentation: https://ini.unknwon.io/docs/intro.