refactor!: change api

This commit is contained in:
Aleksey Kulikov 2021-06-04 17:41:52 +03:00
parent 3aa322ea59
commit 570e5bad52
2 changed files with 16 additions and 9 deletions

View file

@ -217,7 +217,7 @@ void setString(Pointer<git_config> cfg, String name, String value) {
}
/// Iterate over all the config variables.
Map<String, dynamic> getEntries(Pointer<git_config> cfg) {
Map<String, dynamic> getVariables(Pointer<git_config> cfg) {
final iterator = calloc<Pointer<git_config_iterator>>();
final entry = calloc<Pointer<git_config_entry>>();
libgit2.git_config_iterator_new(iterator, cfg);

View file

@ -1,4 +1,5 @@
import 'dart:ffi';
import 'dart:io';
import 'package:ffi/ffi.dart';
import 'bindings/libgit2_bindings.dart';
import 'bindings/config.dart' as config;
@ -7,6 +8,8 @@ import 'util.dart';
/// [Config] provides management of global configuration options
/// (system, global, XDG, excluding repository config)
class Config {
Config();
/// Initializes a new instance of [Config] class.
///
/// If [path] isn't provided, opens global, XDG and system config files.
@ -15,7 +18,7 @@ class Config {
/// Git config file following the default Git config syntax (see man git-config).
///
/// [Config] object should be closed with [close] function to release allocated memory.
Config({this.path}) {
Config.open({this.path}) {
libgit2.git_libgit2_init();
if (path == null) {
@ -26,13 +29,17 @@ class Config {
}
} else {
try {
if (File(path!).existsSync()) {
configPointer = config.open(path!);
} else {
throw Exception('File not found');
}
} catch (e) {
rethrow;
}
}
entries = config.getEntries(configPointer.value);
variables = config.getVariables(configPointer.value);
libgit2.git_libgit2_shutdown();
}
@ -48,7 +55,7 @@ class Config {
try {
final systemPath = config.findSystem();
configPointer = config.open(systemPath);
entries = config.getEntries(configPointer.value);
variables = config.getVariables(configPointer.value);
} catch (e) {
configPointer = nullptr;
rethrow;
@ -68,7 +75,7 @@ class Config {
try {
final globalPath = config.findGlobal();
configPointer = config.open(globalPath);
entries = config.getEntries(configPointer.value);
variables = config.getVariables(configPointer.value);
} catch (e) {
configPointer = nullptr;
rethrow;
@ -88,7 +95,7 @@ class Config {
try {
final xdgPath = config.findXdg();
configPointer = config.open(xdgPath);
entries = config.getEntries(configPointer.value);
variables = config.getVariables(configPointer.value);
} catch (e) {
configPointer = nullptr;
rethrow;
@ -104,7 +111,7 @@ class Config {
late Pointer<Pointer<git_config>> configPointer;
/// Map of key/value entries from config file.
Map<String, dynamic> entries = {};
Map<String, dynamic> variables = {};
/// Sets value of config key
void setEntry(String key, dynamic value) {
@ -116,7 +123,7 @@ class Config {
} else {
config.setString(configPointer.value, key, value);
}
entries = config.getEntries(configPointer.value);
variables = config.getVariables(configPointer.value);
} catch (e) {
rethrow;
}