From 6024dfb8fdc1ffdf9afb172717e69b220f16f662 Mon Sep 17 00:00:00 2001 From: nafiskabbo Date: Tue, 7 May 2024 06:27:21 +0600 Subject: [PATCH 1/3] fix: if inside string ignore text-delimiters --- lib/src/csv_asset_loader.dart | 2 +- pubspec.yaml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/src/csv_asset_loader.dart b/lib/src/csv_asset_loader.dart index e363570..7e420e5 100644 --- a/lib/src/csv_asset_loader.dart +++ b/lib/src/csv_asset_loader.dart @@ -51,7 +51,7 @@ class CSVParser { this.csvString, { this.fieldDelimiter, this.eol, - this.useAutodetect = true, + this.useAutodetect = false, }) : lines = CsvToListConverter().convert( csvString, fieldDelimiter: fieldDelimiter, diff --git a/pubspec.yaml b/pubspec.yaml index f4e9b0c..fa54fa9 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -11,7 +11,7 @@ environment: dependencies: connectivity_plus: ^5.0.1 - csv: ^5.0.1 + csv: ^6.0.0 easy_localization: ^3.0.3 flutter: { sdk: flutter } http: ^1.1.0 From 8b95f11c51937824759c36e0f2d45ffb6d222014 Mon Sep 17 00:00:00 2001 From: nafiskabbo Date: Tue, 7 May 2024 06:53:03 +0600 Subject: [PATCH 2/3] test cases added --- test/easy_localization_loader_test.dart | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/test/easy_localization_loader_test.dart b/test/easy_localization_loader_test.dart index 184340f..10b2bdb 100644 --- a/test/easy_localization_loader_test.dart +++ b/test/easy_localization_loader_test.dart @@ -13,6 +13,8 @@ void main() { 'str\ten_US\t$localeName\r\nscreen_language\tInterface language\tЯзык интерфейса\r\n'; const testCommaCRLFString = 'str,en_US,$localeName\r\nscreen_language,Interface language,Язык интерфейса\r\n'; + const testCommaQuotesInsideCRLFString = + 'str,en_US,$localeName\r\nscreen_language,"Interface language, Test","Язык интерфейса, Тест"\r\n'; Map getResult( String testString, @@ -45,6 +47,11 @@ void main() { {'screen_language': 'Язык интерфейса'}, getResult(testCommaCRLFString, localeName), ); + output( + 'testCommaQuotesInsideCRLFString'.toUpperCase(), + {'screen_language': 'Язык интерфейса, Тест'}, + getResult(testCommaQuotesInsideCRLFString, localeName, false), + ); output( 'testTabLFString, autodetect = false'.toUpperCase(), {}, From 1c348e5b08af4786e669c497cce810b294fa76ea Mon Sep 17 00:00:00 2001 From: nafiskabbo Date: Tue, 7 May 2024 17:57:56 +0600 Subject: [PATCH 3/3] added useAutodetect as optional parameter --- lib/src/csv_asset_loader.dart | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/lib/src/csv_asset_loader.dart b/lib/src/csv_asset_loader.dart index 7e420e5..2a7ecfb 100644 --- a/lib/src/csv_asset_loader.dart +++ b/lib/src/csv_asset_loader.dart @@ -11,12 +11,20 @@ import 'package:flutter/services.dart'; // class CsvAssetLoader extends AssetLoader { CSVParser? csvParser; + final bool useAutodetect; + + CsvAssetLoader({ + this.useAutodetect = true, + }); @override Future> load(String path, Locale locale) async { if (csvParser == null) { log('easy localization loader: load csv file $path'); - csvParser = CSVParser(await rootBundle.loadString(path)); + csvParser = CSVParser( + await rootBundle.loadString(path), + useAutodetect: useAutodetect, + ); } else { log('easy localization loader: CSV parser already loaded, read cache'); } @@ -51,7 +59,7 @@ class CSVParser { this.csvString, { this.fieldDelimiter, this.eol, - this.useAutodetect = false, + this.useAutodetect = true, }) : lines = CsvToListConverter().convert( csvString, fieldDelimiter: fieldDelimiter,