Compare commits

..

16 Commits

Author SHA1 Message Date
Sergey Penkovsky
fc43167756 added license header for src. Added changelog 2021-04-26 10:40:27 +03:00
Sergey Penkovsky
e726e3bf30 refactored di library. 2021-04-26 09:44:04 +03:00
Sergey Penkovsky
9032abe21a fixed binding and writed unit tests 2021-04-23 17:52:33 +03:00
Sergey Penkovsky
0708b87753 fixed binding and writed unit tests 2021-04-23 17:29:42 +03:00
Sergey Penkovsky
b1973ca418 refactored code and implemented unit tests 2021-04-23 10:34:33 +03:00
Sergey Penkovsky
52c7786a49 implemented doc 2021-04-23 08:43:10 +03:00
Sergey Penkovsky
45f81225b0 added documentation 2021-04-22 17:30:32 +03:00
Sergey Penkovsky
475ca5aedc added documents 2021-04-22 15:22:09 +03:00
Sergey Penkovsky
dce2f4f7a9 added documentation 2021-04-22 10:25:38 +03:00
Sergey Penkovsky
6d7a52f0fa added documentation 2021-04-22 10:10:34 +03:00
Sergey Penkovsky
b1c4f908fe added documentation 2021-04-22 09:56:37 +03:00
Sergey Penkovsky
666221199d fixed resolve method 2021-04-21 08:25:55 +03:00
Sergey Penkovsky
3868bdb0a7 fixed example 2021-04-21 08:12:23 +03:00
Sergey Penkovsky
b46cfc36a2 implemented expiremental di with new api 2021-04-21 08:05:38 +03:00
Sergey Penkovsky
1aa0ae045e Добавить .gitlab-ci.yml 2021-04-14 17:19:35 +03:00
Sergey Penkovsky
12d877333a upgraded code for nullsafety 2021-03-27 19:48:03 +03:00
15 changed files with 33 additions and 179 deletions

View File

@@ -1,14 +1,6 @@
---
0.1.1+1 Updated pubspec and readme.md
---
0.1.1 Updated pubspec
---
0.1.0 Initial release
---

View File

@@ -1,4 +1,4 @@
# cherrypick
# dart_di
Experimental development of DI in the Dart language
@@ -10,4 +10,4 @@ Experimental development of DI in the Dart language
- [x] Scope
- [x] Sub scope
- [x] Initialization instance with name
- [x] Initialization instance with name

View File

@@ -65,7 +65,7 @@ Example:
```dart
// open main scope
final rootScope = Cherrypick.openRootScope();
final rootScope = DartDi.openRootScope();
// initializing scope with a custom module
rootScope.installModules([AppModule()]);
@@ -76,7 +76,7 @@ Example:
final str = rootScope.tryResolve<String>();
// close main scope
Cherrypick.closeRootScope();
DartDi.closeRootScope();
```
## Example app
@@ -85,8 +85,8 @@ Example:
```dart
import 'dart:async';
import 'package:meta/meta.dart';
import 'package:cherrypick/scope.dart';
import 'package:cherrypick/module.dart';
import 'package:dart_di/experimental/scope.dart';
import 'package:dart_di/experimental/module.dart';
class AppModule extends Module {
@override

View File

@@ -65,7 +65,7 @@ Scope - это контейнер, который хранит все дерев
```dart
// открыть главный scope
final rootScope = CherryPick.openRootScope();
final rootScope = DartDi.openRootScope();
// инициализация scope пользовательским модулем
rootScope.installModules([AppModule()]);
@@ -76,7 +76,7 @@ Scope - это контейнер, который хранит все дерев
final str = rootScope.tryResolve<String>();
// закрыть главный scope
Cherrypick.closeRootScope();
DartDi.closeRootScope();
```
## Пример приложения
@@ -85,8 +85,8 @@ Scope - это контейнер, который хранит все дерев
```dart
import 'dart:async';
import 'package:meta/meta.dart';
import 'package:cherrypick/scope.dart';
import 'package:cherrypick/module.dart';
import 'package:dart_di/experimental/scope.dart';
import 'package:dart_di/experimental/module.dart';
class AppModule extends Module {
@override
@@ -192,4 +192,4 @@ class ApiClientImpl implements ApiClient {
return 'Network data';
}
}
```
```

View File

@@ -1,136 +0,0 @@
## Example
pubspec.yaml:
```yaml
name: example
version: 1.0.0
environment:
sdk: ">=2.12.0 <3.0.0"
dependencies:
cherrypick:
path: ../
dev_dependencies:
test: ^1.16.8
```
main.dart:
```dart
import 'dart:async';
import 'package:meta/meta.dart';
import 'package:cherrypick/scope.dart';
import 'package:cherrypick/module.dart';
class AppModule extends Module {
@override
void builder(Scope currentScope) {
bind<ApiClient>().withName("apiClientMock").toInstance(ApiClientMock());
bind<ApiClient>().withName("apiClientImpl").toInstance(ApiClientImpl());
}
}
class FeatureModule extends Module {
bool isMock;
FeatureModule({required this.isMock});
@override
void builder(Scope currentScope) {
bind<DataRepository>()
.withName("networkRepo")
.toProvide(
() => NetworkDataRepository(
currentScope.resolve<ApiClient>(
named: isMock ? "apiClientMock" : "apiClientImpl",
),
),
)
.singeltone();
bind<DataBloc>().toProvide(
() => DataBloc(
currentScope.resolve<DataRepository>(named: "networkRepo"),
),
);
}
}
void main() async {
final scope = openRootScope().installModules([
AppModule(),
]);
final subScope = scope
.openSubScope("featureScope")
.installModules([FeatureModule(isMock: true)]);
final dataBloc = subScope.resolve<DataBloc>();
dataBloc.data.listen((d) => print('Received data: $d'),
onError: (e) => print('Error: $e'), onDone: () => print('DONE'));
await dataBloc.fetchData();
}
class DataBloc {
final DataRepository _dataRepository;
Stream<String> get data => _dataController.stream;
StreamController<String> _dataController = new StreamController.broadcast();
DataBloc(this._dataRepository);
Future<void> fetchData() async {
try {
_dataController.sink.add(await _dataRepository.getData());
} catch (e) {
_dataController.sink.addError(e);
}
}
void dispose() {
_dataController.close();
}
}
abstract class DataRepository {
Future<String> getData();
}
class NetworkDataRepository implements DataRepository {
final ApiClient _apiClient;
final _token = 'token';
NetworkDataRepository(this._apiClient);
@override
Future<String> getData() async => await _apiClient.sendRequest(
url: 'www.google.com', token: _token, requestBody: {'type': 'data'});
}
abstract class ApiClient {
Future sendRequest({@required String url, String token, Map requestBody});
}
class ApiClientMock implements ApiClient {
@override
Future sendRequest(
{@required String? url, String? token, Map? requestBody}) async {
return 'Local Data';
}
}
class ApiClientImpl implements ApiClient {
@override
Future sendRequest(
{@required String? url, String? token, Map? requestBody}) async {
return 'Network data';
}
}
```

View File

@@ -1,7 +1,7 @@
import 'dart:async';
import 'package:meta/meta.dart';
import 'package:cherrypick/scope.dart';
import 'package:cherrypick/module.dart';
import 'package:dart_di/scope.dart';
import 'package:dart_di/module.dart';
class AppModule extends Module {
@override

View File

@@ -8,7 +8,7 @@ environment:
dependencies:
cherrypick:
dart_di:
path: ../
dev_dependencies:

View File

@@ -13,7 +13,7 @@
library dart_di;
export 'package:cherrypick/scope.dart';
export 'package:cherrypick/module.dart';
export 'package:cherrypick/binding.dart';
export 'package:cherrypick/di.dart';
export 'package:dart_di/scope.dart';
export 'package:dart_di/module.dart';
export 'package:dart_di/binding.dart';
export 'package:dart_di/di.dart';

View File

@@ -10,11 +10,11 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import 'package:cherrypick/scope.dart';
import 'package:dart_di/scope.dart';
Scope? _rootScope = null;
class CherryPick {
class DartDi {
/// RU: Метод открывает главный [Scope].
/// ENG: The method opens the main [Scope].
///

View File

@@ -11,7 +11,7 @@
* limitations under the License.
*/
import 'package:cherrypick/scope.dart';
import 'package:dart_di/scope.dart';
abstract class Factory<T> {
T createInstance(Scope scope);

View File

@@ -13,8 +13,8 @@
import 'dart:collection';
import 'package:cherrypick/binding.dart';
import 'package:cherrypick/scope.dart';
import 'package:dart_di/binding.dart';
import 'package:dart_di/scope.dart';
/// RU: Класс Module является основой для пользовательских модулей.
/// Этот класс нужен для инициализации [Scope].

View File

@@ -13,8 +13,8 @@
import 'dart:collection';
import 'package:cherrypick/binding.dart';
import 'package:cherrypick/module.dart';
import 'package:dart_di/binding.dart';
import 'package:dart_di/module.dart';
Scope openRootScope() => Scope(null);

View File

@@ -1,10 +1,8 @@
name: cherrypick
description: Cherrypick is a small dependency injection (DI) library for dart/flutter projects.
version: 0.1.1+1
homepage: https://github.com/pese-git/cherrypick
documentation: https://github.com/pese-git/cherrypick/wiki
repository: https://github.com/pese-git/cherrypick
issue_tracker: https://github.com/pese-git/cherrypick/issues
name: dart_di
description: Experimental Dependency Injection library.
version: 0.1.0
author: Sergey Penkovsky <sergey.penkovsky@gmail.com>
homepage: locahost
environment:
sdk: ">=2.12.0 <3.0.0"

View File

@@ -1,4 +1,4 @@
import 'package:cherrypick/binding.dart';
import 'package:dart_di/binding.dart';
import 'package:test/test.dart';
void main() {

View File

@@ -1,5 +1,5 @@
import 'package:cherrypick/module.dart';
import 'package:cherrypick/scope.dart';
import 'package:dart_di/module.dart';
import 'package:dart_di/scope.dart';
import 'package:test/test.dart';
void main() {